服务器之家:专注于服务器技术及软件下载分享
分类导航

云服务器|WEB服务器|FTP服务器|邮件服务器|虚拟主机|服务器安全|DNS服务器|服务器知识|Nginx|IIS|Tomcat|

服务器之家 - 服务器技术 - Nginx - nginx+tomcat实现负载均衡,使用redis session共享

nginx+tomcat实现负载均衡,使用redis session共享

2019-11-16 17:51程序人生0407 Nginx

这篇文章主要介绍了nginx tomcat负载均衡 使用redis session共享,有兴趣的同学可以了解一下。

环境准备

1、准备一台nginx服务器 ip192.168.1.133 端口81

安装过程:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#首先安装依赖:
yum -y install gcc-c++
yum -y install pcre pcre-devel
yum -y install zlib zlib-devel
yum -y install openssl openssl—devel
#注意 : 安装nginx必须使用 root 用户安装
#创建一个nginx目录
mkdir /usr/local/src/nginx
#进入到nginx目录
cd /usr/local/src/nginx
#下载或上传安装包
wget http://nginx.org/download/nginx.tar.gz 或 rz上传
#解压安装包
tar -xvf nginx.tar.gz
#进入到解压后的目录
cd nginx
# 下面 才开始正式安装
#把nginx安装到指定用户的目录
mkdir -p /ucenter/soft/nginx
#安装配置 prefix为安装目录 user为用户 group为 组
./configure --prefix=/ucenter/soft/nginx --user=ucenter --group=ucenter
#编译
make
#安装
make install
#在linux系统中由于非root用户不能占用80端口,所以需要使普通用户以root身份启动nginx。
cd /ucenter/soft/nginx/sbin
#把soft文件下所有的文件所属者修改为ucener -R 表示递归
chown ucenter:ucenter ./soft/ -R
#修改 ./nginx 的所属为root
chown root nginx
#让普通用户可以使用80端口,可以使用root权限启用nginx
chmod u+s nginx
#修改配置文件 在修改配置文件之前 ,要备份该文件
cd conf/
# 要注意nginx 的工作进程,一般根据cpu的核数去修改
vim nginx.conf
#关闭防火墙,打开80端口
service iptables stop
#启动nginx
./nginx
#重启nginx
./nginx -s reload
#关闭nginx
./nginx -s stop

准备一台tomcat服务器,先准备java环境,安装jdk步骤省略

然后分别安装3个tomcat 服务器ip地址:192.168.1.143,tomcat1 8080端口,tomcat2 8081端口,tomcat3 8082端口。

nginx+tomcat实现负载均衡,使用redis session共享

apache-tomcat-7.0.64/conf/server.xml配置文件修改这三个地方,这样端口就不会冲突

?
1
2
3
4
5
<Server port="8005" shutdown="SHUTDOWN">
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

修改tomcat ROOT目录下index.jsp,分别增加每个tomcat的标识,以及在页面上显示session ID

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
<%--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
 
 http://www.apache.org/licenses/LICENSE-2.0
 
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
--%>
<!DOCTYPE html>
<%@ page session="true" %>
<%
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy");
request.setAttribute("year", sdf.format(new java.util.Date()));
request.setAttribute("tomcatUrl", "http://tomcat.apache.org/");
request.setAttribute("tomcatDocUrl", "/docs/");
request.setAttribute("tomcatExamplesUrl", "/examples/");
%>
<html lang="en">
 <head>
  <title><%=request.getServletContext().getServerInfo() %></title>
  <link href="favicon.ico" rel="icon" type="image/x-icon" />
  <link href="favicon.ico" rel="shortcut icon" type="image/x-icon" />
  <link href="tomcat.css" rel="stylesheet" type="text/css" />
 </head>
 
 <body>
  <div id="wrapper">
   <div id="navigation" class="curved container">
    <span id="nav-home"><a href="${tomcatUrl}">Home--<%=request.getSession().getId() %></a></span>
    <span id="nav-hosts"><a href="${tomcatDocUrl}">Documentation</a></span>
    <span id="nav-config"><a href="${tomcatDocUrl}config/">Configuration</a></span>
    <span id="nav-examples"><a href="${tomcatExamplesUrl}">Examples</a></span>
    <span id="nav-wiki"><a href="http://wiki.apache.org/tomcat/FrontPage">Wiki</a></span>
    <span id="nav-lists"><a href="${tomcatUrl}lists.html">Mailing Lists</a></span>
    <span id="nav-help"><a href="${tomcatUrl}findhelp.html">Find Help</a></span>
    <br class="separator" />
   </div>
   <div id="asf-box">
    <h1>${pageContext.servletContext.serverInfo}--8080</h1>
   </div>
   <div id="upper" class="curved container">
    <div id="congrats" class="curved container">
     <h2>If you're seeing this, you've successfully installed Tomcat. Congratulations!</h2>
    </div>
    <div id="notice">
     <img src="tomcat.png" alt="[tomcat logo]" />
     <div id="tasks">
      <h3>Recommended Reading:</h3>
      <h4><a href="${tomcatDocUrl}security-howto.html">Security Considerations HOW-TO</a></h4>
      <h4><a href="${tomcatDocUrl}manager-howto.html">Manager Application HOW-TO</a></h4>
      <h4><a href="${tomcatDocUrl}cluster-howto.html">Clustering/Session Replication HOW-TO</a></h4>
     </div>
    </div>
    <div id="actions">
     <div class="button">
      <a class="container shadow" href="/manager/status"><span>Server Status</span></a>
     </div>
     <div class="button">
      <a class="container shadow" href="/manager/html"><span>Manager App</span></a>
     </div>
     <div class="button">
      <a class="container shadow" href="/host-manager/html"><span>Host Manager</span></a>
     </div>
    </div>
    <!--
    <br class="separator" />
    -->
    <br class="separator" />
   </div>
   <div id="middle" class="curved container">
    <h3>Developer Quick Start</h3>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatDocUrl}setup.html">Tomcat Setup</a></p>
      <p><a href="${tomcatDocUrl}appdev/">First Web Application</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatDocUrl}realm-howto.html">Realms & AAA</a></p>
      <p><a href="${tomcatDocUrl}jndi-datasource-examples-howto.html">JDBC DataSources</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatExamplesUrl}">Examples</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="http://wiki.apache.org/tomcat/Specifications">Servlet Specifications</a></p>
      <p><a href="http://wiki.apache.org/tomcat/TomcatVersions">Tomcat Versions</a></p>
     </div>
    </div>
    <br class="separator" />
   </div>
   <div id="lower">
    <div id="low-manage" class="">
     <div class="curved container">
      <h3>Managing Tomcat</h3>
      <p>For security, access to the <a href="/manager/html">manager webapp</a> is restricted.
      Users are defined in:</p>
      <pre>$CATALINA_HOME/conf/tomcat-users.xml</pre>
      <p>In Tomcat 7.0 access to the manager application is split between
       different users.   <a href="${tomcatDocUrl}manager-howto.html">Read more...</a></p>
      <br />
      <h4><a href="${tomcatDocUrl}RELEASE-NOTES.txt">Release Notes</a></h4>
      <h4><a href="${tomcatDocUrl}changelog.html">Changelog</a></h4>
      <h4><a href="${tomcatUrl}migration.html">Migration Guide</a></h4>
      <h4><a href="${tomcatUrl}security.html">Security Notices</a></h4>
     </div>
    </div>
    <div id="low-docs" class="">
     <div class="curved container">
      <h3>Documentation</h3>
      <h4><a href="${tomcatDocUrl}">Tomcat 7.0 Documentation</a></h4>
      <h4><a href="${tomcatDocUrl}config/">Tomcat 7.0 Configuration</a></h4>
      <h4><a href="http://wiki.apache.org/tomcat/FrontPage">Tomcat Wiki</a></h4>
      <p>Find additional important configuration information in:</p>
      <pre>$CATALINA_HOME/RUNNING.txt</pre>
      <p>Developers may be interested in:</p>
      <ul>
       <li><a href="http://tomcat.apache.org/bugreport.html">Tomcat 7.0 Bug Database</a></li>
       <li><a href="${tomcatDocUrl}api/index.html">Tomcat 7.0 JavaDocs</a></li>
       <li><a href="http://svn.apache.org/repos/asf/tomcat/tc7.0.x/">Tomcat 7.0 SVN Repository</a></li>
      </ul>
     </div>
    </div>
    <div id="low-help" class="">
     <div class="curved container">
      <h3>Getting Help</h3>
      <h4><a href="${tomcatUrl}faq/">FAQ</a> and <a href="${tomcatUrl}lists.html">Mailing Lists</a></h4>
      <p>The following mailing lists are available:</p>
      <ul>
       <li id="list-announce"><strong><a href="${tomcatUrl}lists.html#tomcat-announce">tomcat-announce</a><br />
        Important announcements, releases, security vulnerability notifications. (Low volume).</strong>
       </li>
       <li><a href="${tomcatUrl}lists.html#tomcat-users">tomcat-users</a><br />
        User support and discussion
       </li>
       <li><a href="${tomcatUrl}lists.html#taglibs-user">taglibs-user</a><br />
        User support and discussion for <a href="${tomcatUrl}taglibs/">Apache Taglibs</a>
       </li>
       <li><a href="${tomcatUrl}lists.html#tomcat-dev">tomcat-dev</a><br />
        Development mailing list, including commit messages
       </li>
      </ul>
     </div>
    </div>
    <br class="separator" />
   </div>
   <div id="footer" class="curved container">
    <div class="col20">
     <div class="container">
      <h4>Other Downloads</h4>
      <ul>
       <li><a href="${tomcatUrl}download-connectors.cgi">Tomcat Connectors</a></li>
       <li><a href="${tomcatUrl}download-native.cgi">Tomcat Native</a></li>
       <li><a href="${tomcatUrl}taglibs/">Taglibs</a></li>
       <li><a href="${tomcatDocUrl}deployer-howto.html">Deployer</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Other Documentation</h4>
      <ul>
       <li><a href="${tomcatUrl}connectors-doc/">Tomcat Connectors</a></li>
       <li><a href="${tomcatUrl}connectors-doc/">mod_jk Documentation</a></li>
       <li><a href="${tomcatUrl}native-doc/">Tomcat Native</a></li>
       <li><a href="${tomcatDocUrl}deployer-howto.html">Deployer</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Get Involved</h4>
      <ul>
       <li><a href="${tomcatUrl}getinvolved.html">Overview</a></li>
       <li><a href="${tomcatUrl}svn.html">SVN Repositories</a></li>
       <li><a href="${tomcatUrl}lists.html">Mailing Lists</a></li>
       <li><a href="http://wiki.apache.org/tomcat/FrontPage">Wiki</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Miscellaneous</h4>
      <ul>
       <li><a href="${tomcatUrl}contact.html">Contact</a></li>
       <li><a href="${tomcatUrl}legal.html">Legal</a></li>
       <li><a href="http://www.apache.org/foundation/sponsorship.html">Sponsorship</a></li>
       <li><a href="http://www.apache.org/foundation/thanks.html">Thanks</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Apache Software Foundation</h4>
      <ul>
       <li><a href="${tomcatUrl}whoweare.html">Who We Are</a></li>
       <li><a href="${tomcatUrl}heritage.html">Heritage</a></li>
       <li><a href="http://www.apache.org">Apache Home</a></li>
       <li><a href="${tomcatUrl}resources.html">Resources</a></li>
      </ul>
     </div>
    </div>
    <br class="separator" />
   </div>
   <p class="copyright">Copyright ©1999-${year} Apache Software Foundation. All Rights Reserved</p>
  </div>
 </body>
 
</html>

nginx+tomcat实现负载均衡,使用redis session共享

这时候 修改nginx配置文件nginx.conf,把三台tomcat的ip地址以及端口号加入进去,使用nginx做代理

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#user nobody;
worker_processes 1;
 
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
 
#pid  logs/nginx.pid;
 
 
events {
 worker_connections 1024;
}
 
 
http {
 include  mime.types;
 default_type application/octet-stream;
 
 #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
 #     '$status $body_bytes_sent "$http_referer" '
 #     '"$http_user_agent" "$http_x_forwarded_for"';
 
 #access_log logs/access.log main;
 
 sendfile  on;
 #tcp_nopush  on;
 
 #keepalive_timeout 0;
 keepalive_timeout 65;
 
 #gzip on;
 
 upstream localhost1 {
  
   #ip_hash;
   server 192.168.1.143:8080;
   server 192.168.1.143:8081;
   server 192.168.1.143:8082;
 }
 
 server {
  listen  81;
  server_name localhost;
 
  #charset koi8-r;
 
  #access_log logs/host.access.log main;
 
  location / {
    proxy_connect_timeout 3;
    proxy_send_timeout  30;
    proxy_read_timeout  30;
    proxy_pass http://localhost1;
  }
 
  #error_page 404    /404.html;
 
  # redirect server error pages to the static page /50x.html
  #
  error_page 500 502 503 504 /50x.html;
  location = /50x.html {
   root html;
  }
 
  # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  #
  #location ~ \.php$ {
  # proxy_pass http://127.0.0.1;
  #}
 
  # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  #
  #location ~ \.php$ {
  # root   html;
  # fastcgi_pass 127.0.0.1:9000;
  # fastcgi_index index.php;
  # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  # include  fastcgi_params;
  #}
 
  # deny access to .htaccess files, if Apache's document root
  # concurs with nginx's one
  #
  #location ~ /\.ht {
  # deny all;
  #}
 }
 
 
 # another virtual host using mix of IP-, name-, and port-based configuration
 #
 #server {
 # listen  8000;
 # listen  somename:8080;
 # server_name somename alias another.alias;
 
 # location / {
 #  root html;
 #  index index.html index.htm;
 # }
 #}
 
 
 # HTTPS server
 #
 #server {
 # listen  443;
 # server_name localhost;
 
 # ssl     on;
 # ssl_certificate  cert.pem;
 # ssl_certificate_key cert.key;
 
 # ssl_session_timeout 5m;
 
 # ssl_protocols SSLv2 SSLv3 TLSv1;
 # ssl_ciphers HIGH:!aNULL:!MD5;
 # ssl_prefer_server_ciphers on;
 
 # location / {
 #  root html;
 #  index index.html index.htm;
 # }
 #}
 
}

这时候,分别启动三台tomcat以及nginx,访问http://192.168.1.133:81,这时候每次刷新页面,都会随机访问8080或者8081或者8082,而且页面上出现的session id也都是不一样的,我们应该如何让这三台tomcat共享session呢,我们使用redis来做。

这时候,在已经按照三台tomcat的服务器192.168.1.143上,安装redis,安装步骤如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ wget http://download.redis.io/releases/redis-3.2.3.tar.gz
$ tar xzf redis-3.2.3.tar.gz
$ cd redis-3.2.3
$ make MALLOC=libc
#启动redis src前面是安装的路径
$ src/redis-server &
 
#关闭redis
src/redis-cli shutdown
#使用redis 放入键值对 key value
$ src/redis-cli
127.0.0.1:6379> set foo bar
OK
127.0.0.1:6379> get foo
"bar"
$

安装完redis之后,在三个tomcat的lib文件夹内分别上传这五个所依赖的jar,分别是

commons-pool2-2.0.jar

jedis-2.5.2.jar

tomcat-redis-session-manager1.2.jar

tomcat-juli.jar

tomcat-juli-adapters.jar

所有jar在这里了,下载地址

然后分别修个三个tomcat的context.xml文件,增加如下的配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version='1.0' encoding='utf-8'?>
 
<Context>
 
 <!-- Default set of monitored resources -->
 <WatchedResource>WEB-INF/web.xml</WatchedResource>
 
 
 <!-- 这里增加redis session共享的配置 6379是redis的端口-->
 <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
 <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
 host="127.0.0.1"
 port="6379"
 database="0"
 maxInactiveInterval="60" />
</Context>

这时候,分别重启三个tomcat以及nginx,查看tomcat日志之后,发现没有任何异常报错,说明我们成功了,接下来开始测试。

我们访问nginx服务器地址:http://192.168.1.133:81/

得到的是8080端口的 tomcat1 ,session id为1A0625767F27BA95EF4D5F061FE0568D 

nginx+tomcat实现负载均衡,使用redis session共享

这时候按F5刷新页面,得到的是8081端口的 tomcat2 ,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D

nginx+tomcat实现负载均衡,使用redis session共享

再次刷新页面,得到的是8082端口的 tomcat3,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D。 、

nginx+tomcat实现负载均衡,使用redis session共享

这时候,说明我们搭建tomcat + nginx负载均衡 + redis session同步成功啦!

nginx帮助把我们的请求均匀的分发给三个tomcat --》tomcat1 、tomcat2以及tomcat3

 redis帮助我们同步session,这样一来,我们的服务器性能就会提高许多,任何一台tomcat发生故障后,对整体的服务都不会有影响了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://www.cnblogs.com/jiafuwei/p/6122369.html

延伸 · 阅读

精彩推荐
  • Nginx利用nginx和腾讯云免费证书制作https的方法

    利用nginx和腾讯云免费证书制作https的方法

    这篇文章主要介绍了利用nginx和腾讯云免费证书制作https的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...

    dalaoyang5992019-12-30
  • Nginx通过Nginx规则重写URL去掉index.php不显示index.php

    通过Nginx规则重写URL去掉index.php不显示index.php

    Nginx不仅占用内存少,并发能力强,而且拓展功能丰富,可以通过安装模板来强化功能,也能通过规则优化,优化服务器并发处理能力,是建站的不二之选...

    Genius日记5872020-10-16
  • Nginxnginx rewrite 伪静态配置参数和使用例子

    nginx rewrite 伪静态配置参数和使用例子

    nginx下伪静态配置参数详细说明,使用nginx的朋友,nginx rewrite 伪静态配置参数和使用例子 附正则使用说明 ...

    服务器之家3102019-10-08
  • NginxNginx location 和 proxy_pass路径配置问题小结

    Nginx location 和 proxy_pass路径配置问题小结

    本文是基于 location 的匹配末尾是否配置 / 和 proxy_pass 末尾是否配置 / ,进行测试,完全还原了整个测试过程,本文给大家介绍Nginx location 基本配置及相关配...

    自由早晚乱余生18742021-09-24
  • Nginx如何优化Nginx的处理性能

    如何优化Nginx的处理性能

    Nginx是一个很强大的高性能Web和反向代理服务,它具有很多非常优越的特性,在连接高并发的情况下,Nginx是Apache服务不错的替代品。其特点是占有内存少,...

    Dockone.io5142020-12-11
  • Nginxnginx ssl免密码重启教程详解

    nginx ssl免密码重启教程详解

    这篇文章给大家介绍了nginx 如何启动以及nginx ssl 免密码重启 的方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧 ...

    mrr4272019-11-19
  • NginxNginx Rewrite使用场景及代码案例详解

    Nginx Rewrite使用场景及代码案例详解

    这篇文章主要介绍了Nginx Rewrite使用场景及代码案例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可...

    盗哥泡茶去了11862020-09-27
  • NginxNginx动静分离实现案例代码解析

    Nginx动静分离实现案例代码解析

    这篇文章主要介绍了Nginx动静分离实现案例代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参...

    盗哥泡茶去了3382020-09-27