lnmp集群的搭建及优化

2023-11-19

lnmp

名词解释

LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python。
LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。
Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。
Mysql是一个小型关系型数据库管理系统。
PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。

我们为什么采用LNMP这种架构?
采用Linux、PHP、MySQL的优点我们不必多说。
Nginx是一个小巧而高效的Linux下的Web服务器软件,是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,已经在一些俄罗斯的大型网站上运行多年,目前很多国内外的门户网站、行业网站也都在是使用Nginx,相当的稳定。
Nginx相当的稳定、功能丰富、安装配置简单、低系统资源……
在这里插入图片描述

首先,浏览器发送http request请求到服务器(Nginx),服务器响应并处理web请求,将一些静态资源(CSS,图片,视频等)保存服务器上,然后将php脚本通过接 口传输协议(网关协议)PHP-FCGI(fast-cgi)传输给PHP-FPM(进程管理程序),PHP-FPM不做处理,然后PHP-FPM调用 PHP解析器进程,PHP解析器解析php脚本信息。PHP解析器进程可以启动多个,进行并发执行。然后将解析后的脚本返回到PHP-FPM,PHP- FPM再通过fast-cgi的形式将脚本信息传送给Nginx.服务器再通过Http response的形式传送给浏览器。浏览器再进行解析与渲染然后进行呈现。

FastCGI的主要优点是把动态语言和HTTP服务器分离开来,是Nginx专一处理静态请求和向后转发动态请求,而PHP/PHP-FPM服务器专一解析PHP动态请求。

相关原理名词解释

搭建

mysql

下载
mysql-boost-5.7.17.tar.gz
源码编译数据库
带boost库的源码包

tar zxf mysql-boost-5.7.17.tar.gz
yum install -y cmake
cd mysql-5.7.17
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ #安装目录 
      -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \  #数据库存放目录
	  -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \ #Unix socket 文件路径
	  -DWITH_MYISAM_STORAGE_ENGINE=1 \  #安装 myisam 存储引擎
	  -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装 innodb 存储引擎
	  -DDEFAULT_CHARSET=utf8 \ #使用 utf8 字符
	  -DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
	  -DEXTRA_CHARSETS=all \#安装所有扩展字符集
	  -DWITH_BOOST=boost/boost_1_59_0/
遇到报错,按提示解决依赖性
'重新编译时,需要清除原来的对象文件和缓存信息'
'rm -fr CmakeCache.txt'

后面编译会有一个warning:
CMake Warning at cmake/bison.cmake:20 (MESSAGE):
  Bison executable not found in PATH
Call Stack (most recent call first):
  sql/CMakeLists.txt:514 (INCLUDE)
##解决##
yum install -y bison

make && make install (过程较长) ##如果make还有问题,删除原来的目录,重新解压编译

制作启动脚本


[root@server5 support-files]# pwd
/root/mysql-5.7.17/support-files
[root@server5 support-files]# cp mysql.server /etc/init.d/mysqld

将原来的/etc/my.cnf备份,重新拷贝安装包里的过去

[root@server5 etc]# cp my.cnf my.cnf.bak
[root@server5 support-files]# cp my-default.cnf /etc/my.cnf
修改配置:
basedir = /usr/local/lnmp/mysql
datadir = /usr/local/lnmp/mysql/data
socket = /usr/local/lnmp/mysql/data/mysql.sock

添加用户和组:

groupadd -g 27 mysql
useradd -u 27 -g 27 mysql (id=27是因为rpm默认安装时mysql用户的id为27,并非强制)

chown mysql.mysql /usr/local/lnmp/mysql -R (修改mysql目录的权限,使其对mysql用户可写)

将mysql命令添加到环境变量

vim ~/.bash_profile
添加:PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin
生效:source ~/.bash_profile

初始化mysql:

mysqld --user=mysql --initialize(以mysql用户身份初始化)
初始化会生成一个临时密码,用于登录mysql(要记住此密码)

将mysql目录的所有者改为root

chown root /usr/local/lnmp/mysql -R
chown mysql /usr/local/lnmp/mysql/data -R  ##数据目录所有者必须是mysql,不然mysql用户不能写

启动mysql

/etc/init.d/mysqld start

进入mysql

mysql -uroot -p
执行:show databases; 会报错
需要执行:mysql_secure_installation,修改密码

nginx

下载

1)解压nginx:tar zxf nginx-1.14.0.tar.gz 
2)进入nginx解压包:
vim src/core/nginx.h 
修改:#define NGINX_VER          "nginx/"
(将此行末尾显示nginx版本号的配置删除)

vim auto/cc/gcc 
修改: 
# debug 
#CFLAGS="$CFLAGS -g" 
(将这2行注释调,关闭debug)

3)编译安装nginx: ./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --withhttp_stub_status_module --with-threads --with-file-aio --user=nginx --group=nginx

根据提示解决依赖性 ##此处应该还需要安装pcre-devel

4)make && make install

5)修改nginx配置文件,开启php模块 
vim  nginx.conf

43  location / { 
44             root   html;
45             index  index.php index.html index.htm; (添加php页面) 
46         }


65  location ~ \.php$ { 
66             root           html; 
67             fastcgi_pass   127.0.0.1:9000; 
68             fastcgi_index  index.php; 
69             #fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name; 
70             include        fastcgi.conf; 
71         }

6)将nginx启动脚本链接到/usr/local/sbin/ 
ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin/ 
[root@server5 ~]# nginx -t ##检测语法 
[root@server5 ~]# nginx ##开启nginx

7)尝试访问:http://ip 
##是nginx默认页面 在nginx默认发布目录添加 index.php 
vim /usr/local/lnmp/nginx/html/index.php 
<?
php phpinfo() 
?>

#可以看到php的默认页面

8)启动nginx并访问:http://ip

php

下载

1)tar jxf php-5.6.35.tar.bz2
yum -y install bzip2
2)进入解压后的目录,开始编译
./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --with-openssl --with-snmp --with-gd --with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --with-gmp --with-gettext --with-pear --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --enable-inline-optimization --enable-soap --enable-ftp --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-mcrypt --with-mhash
--with-config-file-path=/etc      指定php.ini位置
--with-MySQL=mysql安装目录,对mysql的支持
--with-MySQLi=mysqli文件目录,优化支持
--enable-fpm	PHP-FPM是一个PHP FastCGI管理器,是只用于PHP的,
它其实是PHP源代码的一个补丁,旨在将Fast-CGI进程管理整合进PHP包中。
必须将它patch到你的PHP源代码中,在编译安装PHP后才可以使用。
新版的PHP已经集成了php-fpm,在./configure的时候带 –enable-fpm参数即可开启PHP-FPM
#以上为php需要编译的模块,把刚才编译mysql的参数要加进来,添加mysqlnd(这是mysql的驱动,php开发的)
--with-freetype-dir  打开对freetype字体库的支持 
--with-zlib 打开zlib库支
#编译时遇到的报错就安装:yum install -y libxml2-devel libcurl-devel 
#没有jpeglib.h文件:yum whatprovides */jpeglib.h
3)编译报错,逐步解决依赖性(rhel7可以向下兼容6的包)
yum install -y re2c-0.13.5-1.el6.x86_64.rpm libmcrypt-2.5.8-9.el6.x86_64.rpm libmcrypt-devel-2.5.8-9.el6.x86_64.rpm (系统镜像没有的3个包)
4)make && make install
5)添加 nginx 用户
6)拷贝更改配置文件
[root@server5 etc]# pwd
/usr/local/lnmp/php/etc
[root@server5 etc]# cp php-fpm.conf.default php-fpm.conf
查看配置文件中以下几项是否开启:
user = nginx
group = nginx
pid = run/php-fpm.pid
7)拷贝更改php主配置文件
[root@server5 php-5.6.35]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini 
修改时区:date.timezone = Asia/Shanghai
8)拷贝php启动脚本至/etc/init.d/
[root@server5 fpm]# pwd
/root/lnmp/php-5.6.35/sapi/fpm
[root@server5 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm 
添加执行权限:chmod +x /etc/init.d/php-fpm 
9)启动php:/etc/init.d/php-fpm start

一键安装

一键安装

优化及应用

Discuz论坛搭建

下载一个写好的论坛压缩包

1)解压 Discuz_X3.2_SC_UTF8.zip
unzip Discuz_X3.2_SC_UTF8.zip -d /usr/local/lnmp/nginx/html/ 
#没有unzip命令的话需要安装:yum install -y unzip
2)将解压后的upload目录改名为bbs,便于访问 
mv upload bbs
3)浏览器访问:http://ip/bbs
4)点击同意后会出现很多目录不存在和不可写的报错
##解决##
[root@server1 bbs]# pwd 
/usr/local/lnmp/nginx/html/bbs
 
chmod 777 config/ -R 
chmod 777 data/ -R 
chmod 777 uc_server/ uc_client/  -R 
给以上目录增加权限,再刷新就可以了

5)选择全新安装--->填写数据库名(任意) 
数据库用户名:root 
数据库密码:自己设定的数据库root用户密码 
管理员帐号:admin 
密码:westos
6)下面会报数据库连接错误:No such file or directory
##解决## 
编辑php主配置文件:
vim /usr/local/lnmp/php/etc/php.ini
修改以下配置: 
pdo_mysql.default_socket= /usr/local/lnmp/mysql/data/mysql.sock 
mysql.default_socket = /usr/local/lnmp/mysql/data/mysql.sock 
mysqli.default_socket = /usr/local/lnmp/mysql/data/mysql.sock 
以上路径为mysql安装的目录,根据自己的路径填写

重新加载php 
/etc/init.d/php-fpm reload

7)再次刷新页面,还是报错:Permission denied

##解决## 
由于 nginx用户 对于 /usr/local/lnmp/mysql/data 目录没有权限 
所以:chmod 755 data/

再次刷新,成功安装

8)点击页面中“管理中心”,会出现报错:Please delete install/index.php via FTP!

##解决## 
[root@server5 bbs]# pwd 
/usr/local/lnmp/nginx/html/bbs/install 
[root@server5 install]# rm -fr index.php 

再刷新页面,成功 
'如果把nginx配置文件中php模块注释掉,再刷新页面,会让你下载,这就是打开php模块的原因'

php增加memcache模块

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

先检查客户端的请求数据是否在memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作;如果请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(memcached客户端不负责,需要程序明确实现);每次更新数据库的同时更新memcached中的数据,保证一致性;当分配给memcached内存空间用完之后,会使用LRU(Least Recently Used,最近最少使用)策略加上到期失效策略,失效数据首先被替换,然后再替换掉最近未使用的数据。

##将phpize加入环境变量 
1)将php的bin目录路径增加到 ~/.bash_profile中,为了方便调用 
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin 
source ~/.bash_profile 
2)memcache目录中本来没有configure文件,所以没法编译 
yum install autoconf 
先执行命令:phpize 
######################################################################### 
phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,
比如你想在原来编译好的php中加入 memcached或者ImageMagick等扩展模块,
可以使用phpize。或者说,phpize的作用可以这样理解:侦测环境 
(phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,
所以是要根据该php的配置情况生成对应 的configure文件),
建立一个configure文件。必须在一个目录下去运行phpize。
那么phpize就知道你的的环境 是哪个目录,并且configure文件建立在该目录下 
######################################################################### 

会生成configure文件
 
3)编译安装memcacheng 
##编译 
./configure 
##安装 
make && make install
 
4)修改php主配置文件,增加memcache模块 
vim /usr/local/lnmp/php/etc/php.ini 
873 extension=memcache.so
 
5)重新加载php 
/etc/init.d/php-fpm reload
 
6)php -m | grep memcache 
   可以查看是否加载成功   
   php -m | grep mysql
 
7)安装memcached
yum install -y memcached
 
8)查看memcached的配置文件 
[root@server5 sbin]# cat /etc/sysconfig/memcached 
PORT="11211" 
USER="memcached" 
MAXCONN="1024" ##最大链接数1024 
CACHESIZE="64" 
OPTIONS="" 
(如果写为OPTIONS="-l 127.0.0.1" 即为只监听本机的11211端口)
 
9)启动memcached 
/etc/init.d/memcached start
 
10)telnet测试 
##没有的话:yum install -y telnet 
telnet localhost 11211 
stats(查看状态) 
set name 0 0 6 (0编号 0缓存时间(此处0代表不限制时间) 6限制字符数) key:name;
编号:0;缓存时间:0 (永久)valuce值:6位 
westosawd 
CLIENT_ERROR bad data chunk 
ERROR 
westos 
STORED 
get name 
VALUE name 0 6 
westos 
END 
delete name 
DELETED 
set name 0 5 6 ##设置缓存5s,过5s再获取name,为空 
westos 
STORED 
get name END

quit #退出
 
11)拷贝php页面到nginx默认发布目录 
memcache.php监控页面;example.php测memcache命中率 
[root@server1 memcache-2.2.5]# cp memcache.php example.php /usr/local/lnmp/nginx/html/
 
修改内容 
define('ADMIN_USERNAME','memcache');    ## Admin Username(自定义) 
define('ADMIN_PASSWORD','westos');      ## Admin Password(自定义)
 
$MEMCACHE_SERVERS[] = '172.25.230.5:11211'; // add more as an array 
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array 
只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加
(因为本实验只有一个主机,其实可以添加多 个)

12)访问http://ip/memcache.php 
输入用户名密码,可以查看memcache命中率,
使用http://ip/example.php不停刷新来测试
 
13)在物理机上分别对两个页面进行压测 [root@localhost ~]# ab -c 10 -n 5000 http://ip/index.php   
#很慢,因为没有缓存, 而且failed比较多                
10个并发,5000个请求 
[root@localhost ~]# ab -c 10 -n 5000 http://ip/example.php 
#很快,因为访问缓存, 而且没有failed的

观察时间和命中率
 

nginx添加memcache模块

openresty官网

  • OpenResty® 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。
  • OpenResty® 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。
  • OpenResty® 的目标是让你的Web服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。
  • 所以对于一些高性能的服务来说,可以直接使用 OpenResty 访问 Mysql或Redis等,而不需要通过第三方语言 (PHP、Python、Ruby)等来访问数据库再返回,这大大提高了应用的性能。

原nginx不支持memcache

1)给nginx添加memc和srcache模块,让nginx直接访问memcache来提高速度 
先关闭原来的nginx,因为下面安装的openresty-1.13.6.1.tar.gz也是nginx

nginx -s stop
 
源码编译安装openresty-1.13.6.1.tar.gz(不需要加参数,使用默认) 
./configure --prefix=/usr/local/openresty gmake && gmake install
 
拷贝之前example.php和index.php到默认发布目录准备测试 
/usr/local/openresty/nginx/html 
[root@server5 html]# cp /usr/local/lnmp/nginx/html/index.php . 
[root@server5 html]# cp /usr/local/lnmp/nginx/html/example.php .
 
修改nginx配置文件:
vim /usr/local/openresty/nginx/conf/nginx.conf 
添加:    
upstream memcache {        
	server localhost:11211;
	keepalive 512;    
}
 
 
        location /memc {
            internal;  # 只接收内部访问,不接受外部http访问。比较安全            
            memc_connect_timeout 100ms;            
            memc_send_timeout 100ms;   ##后端服务器数据回传时间            
            memc_read_timeout 100ms;   ##连接成功后,后端服务器响应时间            
            set $memc_key $query_string;            
            set $memc_exptime 300;            
            memc_pass memcache;        
         }
 
        location ~ \.php$ {            
        	set $key $uri$args;    
        	##http的GET方法表示get、PUT方法表示set            
        	srcache_fetch GET /memc $key;
        	(这两个配置的作用是:请求php页面时,先会去memcache中 找,如果没有,正常访问;            
        	srcache_store PUT /memc $key; 访问结束后将结果存到memcache,下次访问时直接从缓存 中)            

			root           html;            
			fastcgi_pass   127.0.0.1:9000;            
			fastcgi_index  index.php;            
			#fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;            
			include        
			fastcgi.conf;        		
		}

再次进行压测,速度会比之前只加了php的缓存更快
 
###重点说明一下对index.php页面的访问 访问速度有了明显的差别 因为php是没有缓存的
 

tomcat

1)安装jdk和tomcat 
tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/ 
tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/
 
2)做好软连接便于访问 
cd /usr/local 
ln -s jdk1.7.0_79/ java 
ln -s apache-tomcat-7.0.37/ tomcat
 
3)配置环境变量 
vim /etc/profile 
export JAVA_HOME=/usr/local/java 
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib 
export PATH=$PATH:$JAVA_HOME/bin 
source /etc/profile 

[root@server1 local]#  echo $PATH 
/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/lnmp/ mysql/bin:/usr/local/lnmp/php/bin:/usr/local/java/bin 
[root@server1 local]#  echo $CLASSPATH 
.:/usr/local/java/lib:/usr/local/java/jre/lib 
[root@server1 local]#  echo $JAVA_HOME 
/usr/local/java 
[root@server1 local]# which java 
/usr/local/java/bin/java 
[root@server1 local]# which javac 
/usr/local/java/bin/javac
 
 vim test.java 
 public class test 
 {    
 	public static void main(String[] args)    
 	{        
 		System.out.println("Hello World1");    
 	} 
 } 

javac test.java 
java test 
cd /usr/local/tomcat 
bin/startup.sh 
网页访问:172.25.0.1:8080 
网页访问:172.25.0.2:8080 
编写页面测试: 
cd /usr/local/tomcat/webapps/ROOT/ 
vim test.jsp 
server1-The time is: <%=new java.util.Date() %>
 
测试nginx对tomcat的负载均衡 
vim nginx.conf    
	upstream tomcat {        
		server 172.25.0.1:8080;        
		server 172.25.0.2:8080;

}
location / {            
			root   /usr/local/tomcat/webapps/ROOT;            
			index  index.html index.htm;        	
		}       
		location ~ \.jsp$ { 
		    proxy_pass   http://tomcat; 
		}
 
http://172.25.0.101/test.jsp

4)增加测试页面:
vim /usr/local/apache-tomcat-7.0.37/webapps/ROOT/test.jsp 
<%@ page contentType="text/html; charset=GBK" %> 
<%@ page import="java.util.*" %> 
<html><head><title>Cluster App Test</title></head> 
<body> 
Server Info: 
<% 
out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%> 
<% 
out.println("<br> ID " + session.getId()+"<br>"); 
String dataName = request.getParameter("dataName"); 
if (dataName != null && dataName.length() > 0) { 
String dataValue = request.getParameter("dataValue"); 
session.setAttribute(dataName, dataValue); 
} 
out.print("<b>Session list</b>"); 
Enumeration e = session.getAttributeNames(); 
while (e.hasMoreElements()) { 
String name = (String)e.nextElement(); 
String value = session.getAttribute(name).toString(); 
out.println( name + " = " + value+"<br>"); 
System.out.println( name + " = " + value); 
} 
%> 
<form action="test.jsp" method="POST"> name:<input type=text size=20 name="dataName"> 
<br> 
key:<input type=text size=20 name="dataValue"> 
<br> 
<input type=submit> 
</form> 
</body> 
</html>
 
5)在nginx配置文件中增加tomcat模块,为了实现session共享,需要支持sticky(粘滞)模块,nginx-1.14不支持sticky,所以使用nginx-1.10版本,重新编译nginx 
###注意:将/usr/local/lnmp/nginx 目录全部删除 再次编译 
tar zxf nginx-sticky-module-ng.tar.gz -C /usr/local/ 
cd nginx-1.10.3 
./configure --prefix=/usr/local/lnmp/nginx   --with-http_ssl_module --withhttp_stub_status_module --with-threads --with-file-aio --add-module=/usr/local/nginxsticky-module-ng 
make && make install 
ln -s /usr/local/lnmp/nginx/sbin/nginx /sbin/ 
vim /usr/local/lnmp/nginx/conf/nginx.conf 
upstream tomcat {        
		sticky;        
		server 172.25.0.1:8080;        
		server 172.25.0.2:8080;
 
} 
gzip  on; #开启gzip 
location / {
             root   /usr/local/tomcat/webapps/ROOT;
             index  index.html index.htm;        
           }       
          location ~ \.jsp$ {
                     proxy_pass   http://tomcat;       
          }
nginx 
再次刷新页面,访问的ID号不会变,实现了sticky


 接下来实现session共享:
 
1)进入/usr/local/tomcat/lib目录(server1,2都做) 
将以下jar包拷贝到该目录: 
asm-3.2.jar 
kryo-1.04.jar 
kryo-serializers-0.10.jar 
memcached-session-manager-1.6.3.jar 
memcached-session-manager-tc7-1.6.3.jar(最重要) 
minlog-1.2.jar 
msm-kryo-serializer-1.6.3.jar 
reflectasm-1.01.jar 
spymemcached-2.7.3.jar 
##或者cp* 把tc6的删了
 
2)编辑/usr/local/tomcat/conf/context.xml文件,
加入session共享配置 context.xml 该文件的作用是配置各种数据库的连接池 
>XML概念:xml常用于数据存储和传输,文件后缀为 .xml 
>它是可扩展标记语言(Extensible Markup Language,简称XML),
>是一种标记语言 标记,指计算机所能理解的信息符号; 
>通过此种标记,计算机之间可以处理包含各种信息的文章等 
>1 标记,指计算机所能理解的信息符号; 
>2 通过此种标记,计算机之间可以处理包含各种信息的文章等。 
>XML设计用来传送及携带数据信息,不用来表现或展示数据,
>所以XML用途的焦点是它说明数据是什么,以及携带数据 信息。
>而HTML语言则用来表现数据

<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.25.230.5:11211,n2:172.25.230.6:11211" 
failoverNodes="n1" (在172.25.230.6上"n1"改为"n2") 
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" 
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
/> 
</Context>
 
server1: 
yum install memcached -y 
/etc/init.d/memcached start
 
server2: 
yum install memcached -y 
/etc/init.d/memcached start

3)保存并启动tomcat 172.25.0.1/test.jsp
 
4)再次测试,如果n1挂了,session不会被重置
 
###注意测试的时候:想更改n1 n2 的时候 可以手动停掉server1 server2上的tomcat和memcached 
##停止一端的memcache
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

lnmp集群的搭建及优化 的相关文章

  • 瞧瞧苹果OS X如何干掉Linux

    原文地址 http www csdn net article 2012 08 28 2809270 osx killed linux 摘要 如果你去过Facebook或者其它一些创业类科技公司 你会发现随处可见的Mac 无论是CEO还是开发
  • 单点登录的简单实现

    1 什么是单点登陆 单点登录 Single Sign On 简称为 SSO 是目前比较流行的企业业务整合的解决方案之一 SSO的定义是在多个应用系统中 用户只需要登录一次就可以访问所有相互信任的应用系统 较大的企业内部 一般都有很多的业务支
  • tomcat 和 jboss的热部署(热发布)问题

    所谓的热部署 热发布 下面称为 热部署 就是说 在web工程发布之后 不可避免的 会遇到修改BUG的问题 现在的热部署就是为了解决这个问题 其功能就是说 在不停止web服务的同时 对jsp和java类进行修改 修改后的效果同时还能够在页面上
  • Nginx添加SSL模块

    目录 一 SSL 概述 SSL证书 HTTPS SSL工作原理 二 创建SSL证书 安装openssl 生成证书 三 nginx配置 nginx打补丁添加模块 nginx conf配置 四 访问 一 SSL 概述 SSL Security
  • Nginx(五)Nginx入门级配置与部署及“Hello World”

    转载自 http blog csdn net poechant article details 7049027 这一次我们要学习什么 就是用Nginx在一台机器上搭建一个最简单的显示 Hello World 的Web服务器 那我们就 ste
  • 专访帝国软件的创造者:仍然在路上的80后

    全球的网站数量已经超过了一亿 并且还在以惊人的速度继续增长 CMS作为一种位于Web前端 Web 服务器 和后端办公系统或流程 内容创作 编辑 之间的软件系统为互联网应用的丰富和发展起到了至关重要的作用 最近我们注意到有一款口碑很好的CMS
  • apache编程思想--挂钩(HOOK)

    如果让你自己编写一个web服务器你会怎么设计 我曾经使用java语言实现了一个最简单的web服务器 我的做法是应用一个socket类启用去监听一个特定的端口 并根据http协议标准去解析这样一个长串 POST reg jsp HTTP CR
  • css文本换行加省略号

    overflow hidden text overflow ellipsis white space nowrap 可以显示的行数 超出部分用 表示 webkit box orient vertical 控制显示行数 webkit line
  • Tomcat性能调优方案

    Tomcat性能调优方案 一 操作系统调优 对于操作系统优化来说 是尽可能的增大可使用的内存容量 提高CPU的频率 保证文件系统的读写速率等 经过压力测试验证 在并发连接很多的情况下 CPU的处理能力越强 系统运行速度越快 适用场景 任何项
  • Memcache是什么

    Memcache是什么Memcache是danga com的一个项目 最早是为 LiveJournal 服务的 目前全世界不少人使用这个缓存项目来构建自己大负载的网站 来分担数据库的压力 它可以应对任意多个连接 使用非阻塞的网络IO 由于它
  • Apache服务一简介与安装

    一 Apache介绍 1 什么是Apache 2 Apache的特性 二 安装Apache服务 1 编译安装http服务 2 启动服务 3 关闭防火墙 se 4 通过网页查看 4 1修改首页内容 4 2网页查看 一 Apache介绍 1 什
  • 大型网站WEB服务器技术选型参考

    大型网站WEB服务器技术选型参考 网站 操作系统 WEB服务器 Google Linux Google Web Server Microsoft Windows 2003 IIS 6 0 Ebay com Windows 2000 2003
  • 什么是LAMP(LAMP概念详解)

    LAMP是 Linux Apache MySQL PHP Perl Python 的简称 1998年Michael Kunze在电脑杂志C T撰写的文章中首次使用了缩略语LAMP 它所组成的各组件都是开源软件 因此很方便自由的获取 导致这些
  • 完全免费快速搭建个人www服务器

    想拥有自己的web服务器吗 想把服务器放到自己家里吗 通过ADSL拨号也能建立个人的服务器吗 本文告诉你答案 要建立自己的web服务器 需要两个最重要的工作 1 让别人知道你的主机 目前访问Internet上主机的方式主要有两种 一是通过I
  • thttpd 运行环境

    1 基于thttpd的Web服务器的简单架设 1 0 为了给刚入门的自己少找麻烦 以下操作都是root用户 1 1 代码的编译安装 configure make and make install 注意可执行程序thttp在 usr loca
  • eclipse配置tomcat

    eclipse环境下如何配置tomcat 打开Eclipse 单击 Window 菜单 选择下方的 Preferences 单击 Server 选项 选择下方的 Runtime Environments 点击 Add 添加Tomcat 点击
  • planet-lab平台的布置

    最近需要把国家自然基金项目赶快结题 所以导师也催的紧 正好自己也在研究网格和高性能计算 所以老板就把部署planet lab环境的任务交给我 鄙人英语很烂 所以花了很长时间的去读指导书 最后基本上搞定 但是还有问题 希望网友们能给我点解答
  • WEB服务器和应用服务器有什么区别

    author skate time 2009 12 04 俗的讲 Web服务器传送 serves 页面使浏览器可以浏览 然而应用程序服务器提供的是客户端应用程序可以调用 call 的方法 methods 确切一点 你可以说 Web服务器专门
  • js时间戳转日期

    方式一 方式一 var date new Date parseInt timeStart 1000 toLocaleString replace d 1 2 最后得到的是2019 8 4 上午9 29 格式的数据 方式二 function
  • 已经设置了端口映射但是外网还是访问不了服务器

    来自于 http www tp link com cn pages article detail asp result faq d 31 已经设置了端口映射但是外网还是访问不了服务器 1 首先检查您设置的端口影射是否正确映射到您内网的服务器

随机推荐

  • 解决Opencv高低版本不兼容问题

    分享一下我老师大神的人工智能教程 零基础 通俗易懂 http blog csdn net jiangjunshow 也欢迎大家转载本篇文章 分享知识 造福人民 实现我们中华民族伟大复兴 目前OpenCV版本已更新到2 4 由此出现了一系列问
  • Qt之QSS中替代background-position的方法。

    学过css的朋友 应该都多少了解一些雪碧图相关的知识 雪碧图 用的就是background position来确定选取的素材位置 比如 素材中每张扑克的宽高分别为49px 66px 如果我要选用红桃8 我就会在css中写 backgroun
  • Gradle sync failed: A problem occurred configuring project ‘:app‘解决方法

    在terminal 中输入 gradlew i 查看详细信息 输出信息 NDK is missing a platforms directory If you are using NDK verify the ndk dir is set
  • vue项目中使用iconfont阿里图标库

    1 进入icon 官网 iconfont 阿里巴巴矢量图标库 2 根据搜索选择自己想要的图片 添加到项目中或者新建项目 如下图 3 添加之后如下图 点击下载至本地 4 下载本地解压后的文件如下图 5 在vue项目中 css新建一个文件夹 把
  • JS时间格式和时间戳的相互转换

    时间戳转化为日期的方式 var timestamp 1527521052 var newDate new Date newDate setTime timestamp 1000 Mon May 28 2018 console log new
  • 计算机视觉知识点-图像增强

    图像增强技术通过对训练图像进行一系列随机更改以生成相似但不同的训练示例来扩展训练数据集的规模 随机更改训练示例可以减少模型对某些属性的依赖 从而提高模型的泛化能力 我们可以以不同的方式裁剪图像 以使感兴趣的对象出现在不同的位置 从而减少了模
  • YoungTalk STM32入门第12步——CRC校验和芯片ID

    1 CRC 循环冗余校验 计算单元 2 96位芯片唯一序列号 1 CRC 循环冗余校验 计算单元 CRC计算单元使用一个固定的多项式发生器 从一个32位的数据字产生一个CRC码 在众多应用中 基于CRC的技术被用于验证数据传输或者存储的一致
  • Qt -信号槽实现原理

    一 简介 QT信号槽的实现实质是什么 回调函数 简要说一下信号与槽的底层原理 信号与槽的实现是借助了Qt 的元对象系统 元对象系统有一个元对象编译器 程序编译之前会有一个预处理过程 预处理将一个类 对象中的信号 槽的字符串值分别保存在一个容
  • 小白学股票基金_1

    债券要集资 利息比银行同等期限的高 但是不能随意提取现金 如果未到期就提取就不能按约定的利息给于 不可买卖 可以抵压 股票为单向交易 只能在低时进入买涨 T 1交易当天不能卖出 固定的开收盘时间 易受庄家控制 全资动作 多少钱买多少股 必须
  • lmg_Model Links and Torrents

    lmg Model Links and Torrents Changelog MDY 4 bit GPU Model Requirements 4 bit CPU llama cpp RAM Requirements LLaMA 16 bi
  • GraphicsLayer知识点

    require esri layers GraphicsLayer function GraphicsLayer code goes here 包含一个或多个图形特征的图层 每个地图都包含默认的GraphicsLayer 可以使用map g
  • 如何访问虚拟机中的Web服务

    需求 1 在虚拟机Vmware中安装了CentOS6 5 虚拟机使用NAT的方式 2 在CentOS中安装了APACHE 并且使用 http 192 168 237 128可以正常访问 3 想在其他windows机器上访问该虚拟机的web服
  • linux系统的系统性学习 (持续更新)

    分类 系统启动过程 第一步 内核的引导 第二步 运行 init 第三步 系统初始化 第四步 建立终端 第五步 用户登录系统 关机 查看系统基本信息 CPU相关 内存相关 查看网络信息 用户 服务 进程相关 磁盘管理 df 命令 du 命令
  • Thrift、Dubbo、Spring Cloud 和 gRPC

    何为RPC RPC Remote Procedure Call 远程过程调用 是一种进程间通信方式 是一种技术的思想 而不是规范 它允许程序调用另一个地址空间 通常是共享网络的另一台机器上 的过程或函数 而不用程序员显式编码这个远程调用的细
  • 计算机常用函数及写法,计算机常用的函数公式有哪些?

    01 计算机常用的函数公式包括RANK函数 COUNTIF函数 IF函数 ABS函数 AND函数 AVERAGE函数 COLUMN 函数等 RANK函数是Excel计算序数的主要工具 它的语法为 RANK number ref order
  • 现代OpenGL教程 01 - 入门指南

    文章转载自 http huangwei pro 2015 05 modern opengl1 以下是我学习opengl得到的启示最多的一篇文章 我强烈地建议大家去读一下这位大神的相关系列的文章 还有https github com tomd
  • Allegro约束管理器的设置

    1 打开约束管理器 2 设置管理器 黄色表示未打开 右击 选择analysis mode打开 3 添加物理规则 修改的数据 4 建立组 同时选中几个网络 右击选择Create New Group新建一个组 修改组的规则里面的网络也都跟着修改
  • Orangepi Zero2 全志H616 的初识

    Q 为什么要学习香橙派 A 在之前对于Linux系统的学习 其内容主要是对于系统API的掌握 而很难进行外设的交互 Linux系统很强大 如果能够结合外设 可以做出STM32 C52等单片机无法实现的复杂项目 而我们可以通过将Linux系统
  • Python 中导入csv数据的三种方法

    这篇文章主要介绍了Python 中导入csv数据的三种方法 内容比较简单 非常不错 具有一定的参考借鉴价值 需要的朋友可以参考下微点阅读小编收集的文章介绍 Python 中导入csv数据的三种方法 具体内容如下所示 1 通过标准的Pytho
  • lnmp集群的搭建及优化

    文章目录 lnmp 名词解释 搭建 mysql nginx php 一键安装 优化及应用 Discuz论坛搭建 php增加memcache模块 nginx添加memcache模块 tomcat lnmp 名词解释 LNMP是指一组通常一起使