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

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

具体步骤:

1、安装两个tomcat8,可以下载一个后,另一个复制即可,下载地址:

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

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

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

修改这个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端口和另一个不冲突。

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

解压即可使用,在启动前,必须要对nginx进行一下配置才可实现负载均衡的功能,打开conf文件夹,下面有一个nginx.conf文件,配置如下:

  1. #user nobody;
  2. worker_processes 1;
  3.  
  4. #error_log logs/error.log;
  5. #error_log logs/error.log notice;
  6. #error_log logs/error.log info;
  7.  
  8. #pid logs/nginx.pid;
  9.  
  10. events {
  11. worker_connections 1024;
  12. }
  13.  
  14. http {
  15. include mime.types;
  16. default_type application/octet-stream;
  17.  
  18. #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  19. # '$status $body_bytes_sent "$http_referer" '
  20. # '"$http_user_agent" "$http_x_forwarded_for"';
  21.  
  22. #access_log logs/access.log main;
  23.  
  24. sendfile on;
  25. #tcp_nopush on;
  26.  
  27. #keepalive_timeout 0;
  28. keepalive_timeout 65;
  29.  
  30. #gzip on;
  31.  
  32. #以下四行是新添加的,两个IP是两个tomcat的访问地址,weight表示分给该服务器的请求比重,两个都是1,则按照1:1来分配,
  33. upstream netitcast.com{
  34. server 127.0.0.1:8080 weight=1;
  35. server 127.0.0.1:9080 weight=1;
  36. }
  37.  
  38. server {
  39. listen 80;
  40. server_name localhost;
  41.  
  42. #charset koi8-r;
  43.  
  44. #access_log logs/host.access.log main;
  45.  
  46. #一下两行是进行修改的,http://netitcast.com和上面添加的要保持一致
  47. location / {
  48. proxy_pass http://netitcast.com;
  49.  
  50. proxy_connect_timeout 1; #表示是1秒后超时会连接到另外一台服务器
  51. proxy_read_timeout 1;
  52. proxy_send_timeout 1;
  53. }
  54.  
  55. #error_page 404 /404.html;
  56.  
  57. # redirect server error pages to the static page /50x.html
  58. #
  59. error_page 500 502 503 504 /50x.html;
  60. location = /50x.html {
  61. root html;
  62. }
  63.  
  64. # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  65. #
  66. #location ~ \.php$ {
  67. # proxy_pass http://127.0.0.1;
  68. #}
  69.  
  70. # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  71. #
  72. #location ~ \.php$ {
  73. # root html;
  74. # fastcgi_pass 127.0.0.1:9000;
  75. # fastcgi_index index.php;
  76. # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  77. # include fastcgi_params;
  78. #}
  79.  
  80. # deny access to .htaccess files, if Apache's document root
  81. # concurs with nginx's one
  82. #
  83. #location ~ /\.ht {
  84. # deny all;
  85. #}
  86. }
  87.  
  88. # another virtual host using mix of IP-, name-, and port-based configuration
  89. #
  90. #server {
  91. # listen 8000;
  92. # listen somename:8080;
  93. # server_name somename alias another.alias;
  94.  
  95. # location / {
  96. # root html;
  97. # index index.html index.htm;
  98. # }
  99. #}
  100.  
  101. # HTTPS server
  102. #
  103. #server {
  104. # listen 443 ssl;
  105. # server_name localhost;
  106.  
  107. # ssl_certificate cert.pem;
  108. # ssl_certificate_key cert.key;
  109.  
  110. # ssl_session_cache shared:SSL:1m;
  111. # ssl_session_timeout 5m;
  112.  
  113. # ssl_ciphers HIGH:!aNULL:!MD5;
  114. # ssl_prefer_server_ciphers on;
  115.  
  116. # location / {
  117. # root html;
  118. # index index.html index.htm;
  119. # }
  120. #}
  121.  
  122. }

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

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

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

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

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

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

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

6、启动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

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

若依项目利用nginx实现负载均衡及保持会话的更多相关文章

  1. liunx 利用nginx 实现负载均衡

    一般采用软件实现负载均衡的有Nginx.apache.nginx 近年来使用频繁,其官网上面显示可以承载5万并发访问量,太牛了. nginx 相比 apache优势明显:Nginx 服务程序比较稳定, ...

  2. Linux下利用nginx实现负载均衡

    linux下利用nginx实现负载均衡 前提条件: 1,安装好jdk 2,安装好tomcat和nginx(可以参考我前两篇文章) 满足前提条件后,要用nginx实现负载均衡,主要是靠配置nginx的配 ...

  3. [转帖]利用nginx实现负载均衡 | 哈希算法,sticky模块实现session粘滞

    利用nginx实现负载均衡 | 哈希算法,sticky模块实现session粘滞 2018年08月02日 10:06:03 Minza 阅读数 483 https://blog.csdn.net/ha ...

  4. 如何利用nginx实现负载均衡(总结)

    如何利用nginx实现负载均衡(总结) 一.总结 一句话总结: 推荐使用nginx七层(应用层)负载均衡的实现:配置那是相当的简单 1.nginx配置实例? |||-begin #这里的域名要和下面p ...

  5. 利用nginx实现负载均衡和动静分离

    1.Nginx介绍 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器 . Nginx 是由 ...

  6. 利用Nginx构建负载均衡server

    大家都知道.一个域名相应一个IP地址,而一个WebSite则相应一个IP地址上相应port服务的应用程序(或位置).而大型站点的并发訪问量很大,这些站点是怎样在一台Webserver上实现负载均衡的呢 ...

  7. 利用nginx实现负载均衡

    1.安装nginx和tomcat 我这里是使用docker安装的.安装流程可参照 dockerfile 这里安装了两个tomcat,端口分别是42000和42001.第二个tomcat的首页随便加了些 ...

  8. 利用nginx做负载均衡

    round-robin:轮询.以轮询方式将请求分配到不同服务器上,默认 least-connected:最少连接数.将下一个请求分配到连接数最少的那台服务器上 ip-hash :基于客户端的IP地址. ...

  9. windows平台下利用Nginx做负载均衡

    1.下载nginx(http://nginx.org/en/download.html)安装包,解压,并使用cmd命令转到nginx.exe所在的目录 2.执行cmd命令start nginx启动ng ...

随机推荐

  1. npm 镜像的问题

    1> cnpm(不推荐) npm install -g cnpm --registry=https://registry.npm.taobao.org 2> 推荐第二种 npm confi ...

  2. opencv 进行图像的花屏检测(模糊检测)

    参考: https://www.pyimagesearch.com/2015/09/07/blur-detection-with-opencv/ https://www.cnblogs.com/ark ...

  3. 11.1-uC/OS-III就绪列表

    准备好运行的任务被放到就绪列表中, 如图6-1.就绪列表是一个数组( OSRdyList[]),它一共有OS_CFG_PRIO_MAX条记录,记录的数据类型为OS_RDY_LIST(见OS.H).就绪 ...

  4. iis7下url重写后,已存在的html不能访问了(未能执行URL)的解决方法

    iis7下url重写后,原本存在的html不能访问了,未能执行URL(asp.net对真正的.html(但不符合重写规的)就不知道如何处理了),遇到类似情况的朋友可以参考下   当把.html的url ...

  5. AsyncHttpClient使用

    github地址:AsyncHttpClient, API:API 1.X和2.X差别很大,我用的1.X中的最新版 1.9.39. 这是一个异步请求的工具,越简单越好,不喜欢再结合netty使用.As ...

  6. html5中JavaScript删除全部节点

    如果div里有这么些内容: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type ...

  7. 20190422 T-SQL 触发器

    -- 1 数据库服务 -- 2 触发器 CREATE TRIGGER no_inserton xsAFTER INSERT ASBEGIN RAISERROR('XS不让插入数据',1,1); ROL ...

  8. 2018-2019-1 20189203《Linux内核原理与分析》第三周作业

    一.课程学习 计算机的三个法宝:存储程序计算机.函数调用堆栈.中断. 堆栈相关的寄存器:ESP(堆栈指针).EBP(基址指针). 堆栈操作:push:栈顶地址减少4个字节,并将操作数放入栈顶存储单元. ...

  9. 《linux就该这么学》第八节课:第六章存储结构与磁盘划分

     笔记 (借鉴请修改) 6.3.文件系统与数据资料 目前linux最常见的文件系统: ext3:日志文件系统.宕机时可自动恢复数据资料,容量越大恢复时间越长,且不能保证百分百不丢失.   ext4:e ...

  10. ubuntu(centos) server安装vmware tools

    Ubuntu: root登录ubutun $ sudo su vmware中选择菜单虚拟机->安装VMware Tools 命令行如下 // 将cdrom挂载到mnt $ mount -t is ...