一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

云服務(wù)器|WEB服務(wù)器|FTP服務(wù)器|郵件服務(wù)器|虛擬主機(jī)|服務(wù)器安全|DNS服務(wù)器|服務(wù)器知識(shí)|Nginx|IIS|Tomcat|

服務(wù)器之家 - 服務(wù)器技術(shù) - Nginx - nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

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

這篇文章主要介紹了nginx tomcat負(fù)載均衡 使用redis session共享,有興趣的同學(xué)可以了解一下。

環(huán)境準(zhǔn)備

1、準(zhǔn)備一臺(tái)nginx服務(wù)器 ip192.168.1.133 端口81

安裝過(guò)程:

?
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
#首先安裝依賴(lài):
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 用戶(hù)安裝
#創(chuàng)建一個(gè)nginx目錄
mkdir /usr/local/src/nginx
#進(jìn)入到nginx目錄
cd /usr/local/src/nginx
#下載或上傳安裝包
wget http://nginx.org/download/nginx.tar.gz 或 rz上傳
#解壓安裝包
tar -xvf nginx.tar.gz
#進(jìn)入到解壓后的目錄
cd nginx
# 下面 才開(kāi)始正式安裝
#把nginx安裝到指定用戶(hù)的目錄
mkdir -p /ucenter/soft/nginx
#安裝配置 prefix為安裝目錄 user為用戶(hù) group為 組
./configure --prefix=/ucenter/soft/nginx --user=ucenter --group=ucenter
#編譯
make
#安裝
make install
#在linux系統(tǒng)中由于非root用戶(hù)不能占用80端口,所以需要使普通用戶(hù)以root身份啟動(dòng)nginx。
cd /ucenter/soft/nginx/sbin
#把soft文件下所有的文件所屬者修改為ucener -R 表示遞歸
chown ucenter:ucenter ./soft/ -R
#修改 ./nginx 的所屬為root
chown root nginx
#讓普通用戶(hù)可以使用80端口,可以使用root權(quán)限啟用nginx
chmod u+s nginx
#修改配置文件 在修改配置文件之前 ,要備份該文件
cd conf/
# 要注意nginx 的工作進(jìn)程,一般根據(jù)cpu的核數(shù)去修改
vim nginx.conf
#關(guān)閉防火墻,打開(kāi)80端口
service iptables stop
#啟動(dòng)nginx
./nginx
#重啟nginx
./nginx -s reload
#關(guān)閉nginx
./nginx -s stop

準(zhǔn)備一臺(tái)tomcat服務(wù)器,先準(zhǔn)備java環(huán)境,安裝jdk步驟省略

然后分別安裝3個(gè)tomcat 服務(wù)器ip地址:192.168.1.143,tomcat1 8080端口,tomcat2 8081端口,tomcat3 8082端口。

nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

apache-tomcat-7.0.64/conf/server.xml配置文件修改這三個(gè)地方,這樣端口就不會(huì)沖突

?
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,分別增加每個(gè)tomcat的標(biāo)識(shí),以及在頁(yè)面上顯示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實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

這時(shí)候 修改nginx配置文件nginx.conf,把三臺(tái)tomcat的ip地址以及端口號(hào)加入進(jìn)去,使用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;
 # }
 #}
 
}

這時(shí)候,分別啟動(dòng)三臺(tái)tomcat以及nginx,訪(fǎng)問(wèn)http://192.168.1.133:81,這時(shí)候每次刷新頁(yè)面,都會(huì)隨機(jī)訪(fǎng)問(wèn)8080或者8081或者8082,而且頁(yè)面上出現(xiàn)的session id也都是不一樣的,我們應(yīng)該如何讓這三臺(tái)tomcat共享session呢,我們使用redis來(lái)做。

這時(shí)候,在已經(jīng)按照三臺(tái)tomcat的服務(wù)器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
#啟動(dòng)redis src前面是安裝的路徑
$ src/redis-server &
 
#關(guān)閉redis
src/redis-cli shutdown
#使用redis 放入鍵值對(duì) key value
$ src/redis-cli
127.0.0.1:6379> set foo bar
OK
127.0.0.1:6379> get foo
"bar"
$

安裝完redis之后,在三個(gè)tomcat的lib文件夾內(nèi)分別上傳這五個(gè)所依賴(lài)的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在這里了,下載地址

然后分別修個(gè)三個(gè)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>

這時(shí)候,分別重啟三個(gè)tomcat以及nginx,查看tomcat日志之后,發(fā)現(xiàn)沒(méi)有任何異常報(bào)錯(cuò),說(shuō)明我們成功了,接下來(lái)開(kāi)始測(cè)試。

我們?cè)L問(wèn)nginx服務(wù)器地址:http://192.168.1.133:81/

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

nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

這時(shí)候按F5刷新頁(yè)面,得到的是8081端口的 tomcat2 ,session id依舊是 1A0625767F27BA95EF4D5F061FE0568D

nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

再次刷新頁(yè)面,得到的是8082端口的 tomcat3,session id依舊是 1A0625767F27BA95EF4D5F061FE0568D。 、

nginx+tomcat實(shí)現(xiàn)負(fù)載均衡,使用redis session共享

這時(shí)候,說(shuō)明我們搭建tomcat + nginx負(fù)載均衡 + redis session同步成功啦!

nginx幫助把我們的請(qǐng)求均勻的分發(fā)給三個(gè)tomcat --》tomcat1 、tomcat2以及tomcat3

 redis幫助我們同步session,這樣一來(lái),我們的服務(wù)器性能就會(huì)提高許多,任何一臺(tái)tomcat發(fā)生故障后,對(duì)整體的服務(wù)都不會(huì)有影響了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久综合中文字幕佐佐木希 | 成人看片免费无限观看视频 | 77成人影院 | 好猛好紧好硬使劲好大刺激视频 | 欧美日韩一区二区综合 | 无限资源在线观看完整版免费下载 | 99久久香蕉国产综合影院 | 欧美老人与小伙子性生交 | 免费观看日本视频 | jizzjizz成熟丰满舒服 | 国内小情侣一二三区在线视频 | 日韩欧免费一区二区三区 | 翁熄性放纵交换01 | 色亚州| 天天天天天天天操 | 欧美一级高清片 | 成年人免费在线看的惊悚动作片 | 动漫美女被褥吸奶漫画漫画 | 国产亚洲精品日韩香蕉网 | 2014天堂 | 天美传媒传媒免费观看 | 国产一区二区三区欧美精品 | 成年人在线观看视频免费 | 国产里番| 免费视频专区一国产盗摄 | 日韩视频一 | 唯美 清纯 另类 亚洲制服 | 日本mature乱子视频 | 成人男女啪啪免费观看网站 | 亚洲国产精品线在线观看 | 涩涩五月天 | 四虎精品成人免费视频 | 天天拍天天色 | 91精品啪在线观看国产线免费 | 亚洲精品黄色 | 午夜片无码区在线观看 | 福利视频久久 | www视频在线免费观看 | 亚洲福利精品电影在线观看 | 欧美人与物videos另类3d | 久久99r66热这里有精品 |