日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

Windows+Nginx+Tomcat搭建负载均衡和集群环境同时实现session共享(一)

發布時間:2023/12/10 windows 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 quit

stop表示立即停止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核心配置文件中引入上面的兩個項目的集群配置,如下:

#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 5000; }http {include mime.types;default_type application/octet-stream;#隱藏nginx的版本號server_tokens off;#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;#access日志存放路徑和格式access_log logs/access.log;#提升文件傳輸性能sendfile on;#tcp_nopush on;#keepalive_timeout 0;#keepalive_timeout 65;#設置客戶端能夠請求的單個文件大小client_max_body_size 300m;keepalive_timeout 75;#proxy參數#跟后端服務器連接的超時時間,發起握手等候響應超時時間proxy_connect_timeout 5;#連接成功后,等候后端服務器的響應時間proxy_read_timeout 600;#后端服務器數據回傳時間proxy_send_timeout 600;#代理請求緩存區proxy_buffer_size 16k;#同上,告訴nginx保存單個用的幾個buffer、最大用多空間proxy_buffers 4 64k;#如果系統很忙時可以申請更大的proxy_buffers,官方推薦*2proxy_busy_buffers_size 128k;proxy_temp_file_write_size 128k;#gzip on;#開啟壓縮功能gzip on;gzip_min_length 1k;gzip_buffers 4 16k;gzip_http_version 1.1; gzip_comp_level 2;#壓縮級別從低到高1-9gzip_types text/plain application/x-javascript text/css application/xml;gzip_vary on;#qdksDemo和qdkyDemo項目的虛擬目錄(用絕對路徑表示)include D:/server/nginx-1.8.0/manyvhost/qdks.conf;include D:/server/nginx-1.8.0/manyvhost/qdky.conf;# another virtual host using mix of IP-, name-, and port-based configuration##server {# listen 80;# 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;# }#}}
五:分別部署對應的項目,來測試我們上面配置的集群環境是否正常

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共享(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。