若依项目利用nginx实现负载均衡及保持会话

记录一下若依项目利用nginx实现负载均衡及保持会话的步骤。php

这次做为试验性的测试,为了方便在本地window的环境上实现。html

具体步骤:nginx

一、安装两个tomcat8,能够下载一个后,另外一个复制便可,下载地址:git

     https://tomcat.apache.org/download-80.cgigithub

      注意为了不端口冲突的问题,须要进入D:\tomcat-9080\conf\目录,打开server.xml文件,修改下面两个地方:web

     (1)<Server port="8006" shutdown="SHUTDOWN">redis

              修改这个port=”8006”,使得它的关闭端口和另外一个关闭端口不发生冲突。数据库

   (2)<Connector port="9080" maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               enableLookups="false" redirectPort="8443" acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" />
               修改port=”9080”,使得它的链接端口和另外一个不冲突。
     (3)<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
              修改这个port=”8010”,使得它的AJP端口和另外一个不冲突。
apache

二、安装nginx,我下载的是稳定版本,地址:http://nginx.org/download/nginx-1.12.2.zip
windows

    解压便可使用,在启动前,必需要对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 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; #如下四行是新添加的,两个IP是两个tomcat的访问地址,weight表示分给该服务器的请求比重,两个都是1,则按照1:1来分配, upstream netitcast.com{ server 127.0.0.1:8080 weight=1; server 127.0.0.1:9080 weight=1; } server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main;  #一下两行是进行修改的,http://netitcast.com和上面添加的要保持一致 location / { proxy_pass http://netitcast.com; proxy_connect_timeout 1; #表示是1秒后超时会链接到另一台服务器 proxy_read_timeout 1; proxy_send_timeout 1; } #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 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} }

 

三、安装redis,redis官方没有64位的Windows下的可执行程序,目前有个开源的托管在github上, 地址:https://github.com/ServiceStack/redis-windows

    下载文件并解压到本身的电脑目录下,我这边选择的是redis-64.3.0.503版本。

四、选择若依项目,此处选择RuoYi-duzunwu512,该版本集成了Redis实现Session共享多模块(支持Cacheable缓存),地址:https://gitee.com/duzunwu512/RuoYi

     将该版本的若依在本地环境中搭建起来,修改数据库配置,将ruoyi-admin项目的pom.xml中改为<packaging>war</packaging>,即将其打成war包。

五、将war包复制到对应两个tomcat的webapp目录下,分别启动两个tomcat,在cmd中cd到对应tomcat的bin目录下,运行startup.bat便可。

      此处分别修改一下ruoyi-admin\WEB-INF\classes\templates下的login.html文件,更改此处,主要目的是为了区分后续的访问到底访问到了那个tomcat。

<h4>欢迎使用 <strong>若依 后台管理系统【Master】</strong></h4>

六、启动nginx,运行start nginx便可。详细可参考

     https://www.cnblogs.com/qianzf/p/6809427.html

     启动redis,运行redis-server redis.windows.conf,详细可参考

     https://blog.csdn.net/qq_33450681/article/details/78250664

七、本地访问http://localhost/ruoyi-admin/index,不断刷新,可看到会不断切换至不一样的tomcat项目中,登陆后,故意中止一个tomcat,仍然能够正常访问,自此基本搭建成功。

相关文章
相关标签/搜索