个人小程序,可以微信扫一扫看看。谢谢支持
链接: https://pan.baidu.com/s/1i5U3srj 密码: hkda 这个是centos网盘地址。其他的在博文底部有给出下载地址
软件版本环境截图 实践测试环境说明使用的是VMware Workstation 挂载了CentOS6.9版本的虚拟机。这个版本的虚拟机里面自带了mysql,所以不需要下载安装。
Java 安装教程 http://www.cnblogs.com/haoliansheng/p/5832979.html
Redis 安装教程 http://jingyan.baidu.com/article/6dad507510ea07a123e36e95.html
Tomcat在安装好Java之后再解压即可。为了做Nginx负载均衡。需要2个Tomcat。本人分别为8081 8082端口做2个Tomcat。需要修改server.xml 只截取了部分内容
<Server port="8015" shutdown="SHUTDOWN"><!--这里需要修改tomcat的关闭端口 默认是8005--> <Listener className="org.apache.catalina.startup.VersionLoggerListener" /> <Listener className="org.apache.catalina.core.JasperListener" /> <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> <GlobalNamingResources> <Resource name="UserDatabase" auth="Container" type="org.apache.catalina.UserDatabase" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /> </GlobalNamingResources> <Service name="Catalina"> <!--这里需要修改tomcat的访问端口 默认是8080--> <Connector port="8081" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> <!--这里需要修改tomcat的代理端口 8443不用更改--> <Connector port="7009" protocol="AJP/1.3" redirectPort="8443" />修改完即可。启动Tomcat 8081 & 8082 cd到bin目录下 执行 ./startup.sh 即可 想看启动相关内容 则执行 ./catalina.sh 命令截图如下
那么现在就可以访问Tomcat了。左图8081 右图 8082 部署了2个相同的项目。
接下来可以Nginx的安装了。
有可能需要安装一些库 命令如下
yum -y install pcre-devel openssl openssl-devel yum install gcc gcc-c++ ncurses-devel perl yum install -y zlib-develtar解压nginx。进入到nginx目录
输入 make 命令。等待执行完成后。输入make install 。基本到这里就安装完成。那么来启动一下。验证nginx是否成功。nginx默认端口为80
配置Nginx 以达到负载均衡的效果。5种配置方式 序号方式名称方式说明(1 2 3实践测试过)1轮询默认配置
upstream xsdemo{ server 192.168.110.128:8081; server 192.168.110.128:8082; }
2weight(权重)正向代理 设置权重
upstream xsdemo{ server 192.168.110.128:8081 weight=10; server 192.168.110.128:8082 weight=10; }
3ip_hash每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session(并不是共享session解决)的问题。
upstream xsdemo{
ip_hash;server 192.168.110.128:8081 weight=10; server 192.168.110.128:8082 weight=10; }
4fair按后端服务器的响应时间来分配请求,响应时间短的优先分配5url_hash按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效 博文采用第一种测试。修改nginx的配置文件 nginx.conf 大概在33行上下。upstream是固定写法后面的 xsDemo可以自定义。但是要与下面的localtion proxy_pass http://xsDemo http://后面的对应。区分大小写。保存以后。重启nginx。如果tomcat没启动。则先启动tomcat后再启动nginx upstream xsDemo { server 192.168.110.128:8081; server 192.168.110.128:8082; } server { listen 80; server_name localhost; location / { root html; index index.html index.htm; proxy_pass http://xsDemo; } 看下效果 第一次是8081 再刷新8082 来回刷新来回切换。这就是轮询配置方式的负载均衡使用ip_hash 可以解决session的问题。但是只能做唯一服务器访问。这样不算是负载均衡。所以这里不再做测试给演示看。可以自行测试。
https://github.com/jcoleman/tomcat-redis-session-manager
链接: http://pan.baidu.com/s/1i5iNDsx 密码: uyyj
commons-pool2-2.0.jar链接: http://pan.baidu.com/s/1i5iNDsx 密码: uyyjjedis-2.7.2.jar链接: http://pan.baidu.com/s/1i5iNDsx 密码: uyyj以上3个jar。需要放在tomcta的lib文件夹下面。切记是tomcat的lib下面。不是项目的lib下面。注意pool这个jar。如果有冲突会启动失败。所以要检查好
还需要修改context.xml文件 切记tomcat关闭哦 context.xml文件存在于tomcat的conf文件夹下 <?xml version='1.0' encoding='utf-8'?> <Context> <WatchedResource>WEB-INF/web.xml</WatchedResource> <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" host="192.168.110.128" port="6379" password="xiaoshuai" 如果设置了密码则在这里配置上 database="0" redis默认16个database 第一个是0 最后一个是15 maxInactiveInterval="60" /> </Context> 到此。配置全部完成。然后再次启动tomcat 8081 & 8082 再启动nginx看图是不是真的session共享了第一次登录到title为8888的tomcat服务器
第二次刷新页面不需要重新登录。但是title变成了9999的tomcat服务器
这样就实现了轮询访问服务器。并且session共享。用户不需要再次重新登录了。看下redis里面的session是否和浏览器的一致这样整个简单测试Nginx+Tomcat+Redis负载均衡Session共享实现 就已经完成了。
觉得好。可以打赏哦。是本作者亲测的。所以肯定都是运行有结果的。
https://my.oschina.net/xshuai/blog/916122