Windows+Nginx+Tomcat搭建负载均衡和集群环境同时实现session共享(一)
摘要:隨著網站的訪問量越來越多,所以就考慮給網站增加服務器了,現在比較流行的做法就是給網站做集群環境,下面我把我做的過程記錄一下,方便日后查看,同時也希望可以幫助到有需要的朋友!
一:首先是環境:
1.jdk 1.6.0_45
2.tomcat 6.0.44
3.nginx 1.8.0
二:jdk,tomcat,nginx的安裝:
1.jdk的安裝請參考:點擊打開鏈接
2.nginx的安裝步驟
(1).首先下載nginx的windows版本,我這里下載的nginx 1.8.0版本,下載地址:點擊打開鏈接
(2).下載完成后,直接解壓到一個沒有中文的路徑下,我這里是解壓到:D:\server\nginx-1.8.0
(3).通過dos命令進入nginx-1.8.0目錄下啟動nginx即可
(4)Windows下操作Nginx命令
1.啟動 nginx.exe start nginx 2.停止 nginx -s stop nginx -s quitstop表示立即停止nginx,不保存相關信息
quit表示正常退出nginx,并保存相關信息
3.重啟 nginx -s reload 重啟(因為改變了配置,需要重啟)3.tomcat的安裝(直接到tomcat的官網下載解壓縮版的即可)
三:把下載下載的tomcat分別復制3個,一共是個,其中三個做qdksDemo的集群環境用,另外三個做qdkyDemo的集群環境用,具體截圖如下:
復制完成后,要分別修改每個tomcat的端口和session共享的配置,具體的配置如下:
1.第一處要修改的端口號
<Server port="8005" shutdown="SHUTDOWN">2.第二處要修改的端口號 <Connector port="8081" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />3.第三處要修改的端口號 <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />4.第四處要增加的session共享配置,這個可以查看tomcat的官方文檔,里面有配置直接復制到server.xml中就可以,地址: http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"channelSendOptions="6"><Manager className="org.apache.catalina.ha.session.BackupManager"expireSessionsOnShutdown="false"notifyListenersOnReplication="true"mapSendOptions="6"/><!--<Manager className="org.apache.catalina.ha.session.DeltaManager"expireSessionsOnShutdown="false"notifyListenersOnReplication="true"/>--><Channel className="org.apache.catalina.tribes.group.GroupChannel"><Membership className="org.apache.catalina.tribes.membership.McastService"address="228.0.0.4"port="45564"frequency="500"dropTime="3000"/><Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"address="auto"port="5000"selectorTimeout="100"maxThreads="6"/><Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter"><Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/></Sender><Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/><Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/><Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/></Channel><Valve className="org.apache.catalina.ha.tcp.ReplicationValve"filter=".*\.gif|.*\.js|.*\.jpeg|.*\.jpg|.*\.png|.*\.htm|.*\.html|.*\.css|.*\.txt"/><Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"tempDir="/tmp/war-temp/"deployDir="/tmp/war-deploy/"watchDir="/tmp/war-listen/"watchEnabled="false"/><ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/></Cluster>這樣一個tomcat的配置文件就修改完成了,其他5個tomcat的配置和這個流程一樣,只是對于的端口不能一樣
四:nginx的配置:
1.首先在nginx的目錄下新建一個新的文件夾來存放不同項目之間的集群配置文件,如下圖:
2.在manyvhost文件夾里面新建一個配置文件,分別對于兩個項目的集群配置,如下圖:
3.qdks.conf和qdky.conf的配置內容如下:
(1).qdks.conf
upstream qdks { server localhost:8081 weight=1; server localhost:8082 weight=1;server localhost:8083 weight=1; } server {listen 8086;server_name 192.168.1.103;error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}root /data/projects/ycp/bill;# - rewrite: if( path ~ "^/assets/(.*)" ) goto "/public/assets/$1"# location ~ ^/static/assets/(.*)$# {#alias /data/projects/payment/web/public/assets/$1;# access_log off;# #expires 3d;# }location / {index index.html index.htm index.jsp;}location ~ .* {# proxy_pass_header Server;proxy_set_header Host $http_host;# proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;add_header Pragma "no-cache";proxy_pass http://qdks;}rewrite ^/admin/?$ /admin/login redirect;# for rewriterewrite ^/(channel|admin|mobile|api|web)/(.*)$ /public/index.php/$2 last;#redirect to mobile wap#rewrite ^$ /m redirect;#rewrite ^/$ /mobile/user redirect;}(2).qdky.conf
upstream qdky { server localhost:7081 weight=1; server localhost:7082 weight=1;server localhost:7083 weight=1; } server {listen 7086;server_name 192.168.1.103;error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}root /data/projects/ycp/bill;# - rewrite: if( path ~ "^/assets/(.*)" ) goto "/public/assets/$1"# location ~ ^/static/assets/(.*)$# {#alias /data/projects/payment/web/public/assets/$1;# access_log off;# #expires 3d;# }location / {index index.html index.htm index.jsp;}location ~ .* {# proxy_pass_header Server;proxy_set_header Host $http_host;# proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;add_header Pragma "no-cache";proxy_pass http://qdky;}rewrite ^/admin/?$ /admin/login redirect;# for rewriterewrite ^/(channel|admin|mobile|api|web)/(.*)$ /public/index.php/$2 last;#redirect to mobile wap#rewrite ^$ /m redirect;#rewrite ^/$ /mobile/user redirect;}這兩個配置文件就是我當前環境下的配置文件,其中qdks的項目的端口號8086,下面對應三個tomcat的端口為:8081,8082,8083;qdky的項目的端口號7086,下面對應三個tomcat的端口號為:7081,7082,7083
4.最后在nginx的conf目錄下的nginx.conf核心配置文件中引入上面的兩個項目的集群配置,如下:
五:分別部署對應的項目,來測試我們上面配置的集群環境是否正常
1.下載對應的項目源代碼,下載后解壓到你的本地workspace下面,我的路徑是:D:\workspace_qdexam\qdksDemo和D:\workspace_qdexam\qdkyDemo
qdksDemo的下載地址:http://download.csdn.net/detail/sxdtzhaoxinguo/9187453
qdkyDemo的下載地址:http://download.csdn.net/detail/sxdtzhaoxinguo/9187455
2.分別部署到對應的tomcat下面,這里我采用的是直接映射路徑的方法
(1).qdksDemo的部署方法是,在對應的三個tomcat的conf\Catalina\localhost目錄下新建一個配置文件qdksDemo.xml,該配置文件的內容如下:
<Context path="/qdksDemo" docBase="D:\workspace_qdexam\qdksDemo\WebContent" debug="0" privileged="true"> </Context>(2).qdkyDemo的部署方法是,在對應的三個tomat的conf\Catalina\localhost目錄下新建一個配置文件qdkyDemo.xml,該配置文件的內容如下: <Context path="/qdkyDemo" docBase="D:\workspace_qdexam\qdkyDemo\WebContent" debug="0" privileged="true"></Context>
3.分別啟動這6個tomcat,如下圖:
4.啟動nginx,如下圖:
5.最后通過瀏覽器訪問這兩個項目,如下圖:
分別點擊刷新,你會發現上面的實際訪問端口會變,但是下面的Session ID是不變的,這就說明基于nginx和tocmat的集群搭建成功了!
最后我把我的tomcat和nginx都打包上傳,供大家參考!
tomcat的配置壓縮包下載地址:http://download.csdn.net/detail/sxdtzhaoxinguo/9187521
nginx的配置壓縮包下載地址:http://download.csdn.net/detail/sxdtzhaoxinguo/9187527
總結
以上是生活随笔為你收集整理的Windows+Nginx+Tomcat搭建负载均衡和集群环境同时实现session共享(一)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java新增
- 下一篇: java信息管理系统总结_java实现科