Centos6.5下ngnix+tomcat+redis的集群+session共享

前端之家收集整理的这篇文章主要介绍了Centos6.5下ngnix+tomcat+redis的集群+session共享前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

环境准备

1.tomcat版本:tomcat7

tomcat下载及安装,目前很多好的资源和步骤,此处省略。

2.jdk版本:jdk1.7

jdk下载及安装,目前很多好的资源和步骤,此处省略。@H_502_23@

3.redis版本以及下载地址、安装步骤

wget http://download.redis.io/redis-stable.tar.gz@H_502_23@ tar xvzf redis-stable.tar.gz@H_502_23@ cd redis-stable@H_502_23@ make@H_502_23@ @H_502_23@ 前面3步应该没有问题,主要的问题是执行make的时候,出现了异常。@H_502_23@ 异常一:@H_502_23@ make[2]: cc: Command not found@H_502_23@ 异常原因:没有安装gcc@H_502_23@ 解决方案:yum install gcc-c++@H_502_23@ @H_502_23@ 异常二:@H_502_23@ zmalloc.h:51:31: error: jemalloc/jemalloc.h: No such file or directory@H_502_23@ 异常原因:一些编译依赖或原来编译遗留出现的问题@H_502_23@ 解决方案:make distclean。清理一下,然后再make。@H_502_23@ @H_502_23@ 在make成功以后,需要make test。在make test出现异常。@H_502_23@ @H_502_23@ 异常一:@H_502_23@ couldn't execute "tclsh8.5": no such file or directory@H_502_23@ 异常原因:没有安装tcl@H_502_23@ 解决方案:yum install -y tcl。@H_502_23@ @H_502_23@ 在make成功以后,会在src目录下多出一些可执行文件:redis-server,redis-cli等等。@H_502_23@ 方便期间用cp命令复制到usr目录下运行。@H_502_23@ cp redis-server /usr/local/bin/@H_502_23@ cp redis-cli /usr/local/bin/@H_502_23@ @H_502_23@ 然后新建目录,存放配置文件@H_502_23@ @H_502_23@ mkdir /etc/redis@H_502_23@ mkdir /var/redis@H_502_23@ mkdir /var/redis/log@H_502_23@ mkdir /var/redis/run@H_502_23@ mkdir /var/redis/6379@H_502_23@ @H_502_23@ 在redis解压根目录中找到配置文件模板,复制到如下位置。@H_502_23@ cp redis.conf /etc/redis/6379.conf@H_502_23@ 通过vim命令修改(默认的也可以,但上面已经创建了目录,最好操作这个步骤)@H_502_23@ daemonize yes@H_502_23@ @H_502_23@ pidfile /var/redis/run/redis_6379.pid@H_502_23@ logfile /var/redis/log/redis_6379.log@H_502_23@ dir /var/redis/6379@H_502_23@ @H_502_23@ 最后运行redis:@H_502_23@

$ redis-server /etc/redis/6379.conf

@H_502_23@

注意:如果redis放在服务器上,并且需要让与redis不在同一台服务器的应用访问时,需要注释掉conf文件中的

bind 127.0.0.1为#bind 127.0.0.1,默认是bind 127.0.0.1(即不注释的)@H_502_23@

4.ngnix的下载、安装、配置等步骤

1.下载地址:@H_502_23@ 下载:@H_502_23@ 加入指定存放的目录(如/home/software/ngnix)后执行下载命令,wget http://Nginx.org/download/Nginx-1.7.8.tar.gz@H_502_23@ 2.安装@H_502_23@ 解压:tar -zxvf Nginx-1.7.8.tar.gz@H_502_23@ 执行 ./configure->make->make install等命令@H_502_23@ 3.开启ngnix@H_502_23@ /usr/local/Nginx-1.7.8/sbin/Nginx@H_502_23@ 重启或关闭进程:@H_502_23@ /usr/local/Nginx-1.7.8/sbin/Nginx -s reload@H_502_23@ /usr/local/Nginx-1.7.8/sbin/Nginx -s stop@H_502_23@ 输入地址如:http://localhost/,如果出现欢迎使用ngnix,说明已经安装成功。@H_502_23@

5.配置tomcat集群

1.到此为止环境都已经准备好,下面开始编写项目,并配置相关集群@H_502_23@

修改Nginx.conf加上

[html] view plain copy
  1. upstreambackend{
  2. server10.10.49.23:8080max_fails=1fail_timeout=10s;
  3. server10.10.49.15:8081max_fails=1fail_timeout=10s;
  4. }
修改Nginx.conf的location成
copy
    location/{
  1. roothtml;
  2. indexindex.htmlindex.htm;
  3. proxy_passhttp://backend;
  4. }

启动Nginx

下载tomcat-redis-session-manager相应的jar包,主要有三个:

wget https://github.com/downloads/jcoleman/tomcat-redis-session-manager/tomcat-redis-session-manager-1.2-tomcat-7-java-7.jar@H_502_23@ wget http://central.maven.org/maven2/redis/clients/jedis/2.5.2/jedis-2.5.2.jar@H_502_23@ wget http://central.maven.org/maven2/org/apache/commons/commons-pool2/2.0/commons-pool2-2.0.jar

下载完成后拷贝到$TOMCAT_HOME/lib中

修改两tomcat的context.xml:

copy
  1. <Context>
  2. <!--Defaultsetofmonitoredresources-->
  3. @H_326_301@ WatchedResource>WEB-INF/web.xml</>
  4. @H_326_301@ <!--UncommentthistodisablesessionpersistenceacrossTomcatrestarts-->
  5. <!--
  6. <Managerpathname=""/>
  7. -->
  8. <!--UncommentthistoenableCometconnectiontacking(providesevents
  9. @H_326_301@ onsessionexpirationaswellaswebapplifecycle)--<ValveclassName="org.apache.catalina.valves.CometConnectionManagerValve"/>
  10. ValveclassName="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve"/>
  11. ManagerclassName="com.orangefunction.tomcat.redissessions.RedisSessionManager"
  12. host="10.10.49.20"
  13. @H_326_301@ port="6379"
  14. password="123456"<!-- 如果没有密码,则不用设置此项-->
  15. database="0"
  16. @H_326_301@ maxInactiveInterval="60"/>
  17. >
@H_502_23@ @H_502_23@

下面为运行结果,2张图对比,不断的刷新可以看出后面的一串数字(sessionId)不会发生变化,而端口号不断的来回切换

这说明,用户每次访问的都是同一个会话(sessionid没有变化)。

图一:

@H_502_23@

图二:

猜你在找的CentOS相关文章