• nginx+Tomcat(反向代理、动静分离、负载均衡)


    目录

    前言

    一、nginx和tomcat组合的架构

    二、案例操作


    前言

    tomcat服务既可以处理动态页面,也可以处理静态页面;但其处理静态页面的速度远远不如nginx和apache服务,但ngingx和apache服务无法直接处理动态页面,下文就讲述了nginx和tomcat组合使用,实现动静分离和负载均衡;目前很多大型网站都应用Nginx服务器作为后端网站程序的反向代理及负载均衡器,提升整个站点的负载并发能力

    一、nginx和tomcat组合的架构

    • standalone模式:Tomcat单独运行,直接接受用户的请求,不推荐。
    • 单机反向代理模式:单机运行,提供了一个Nginx作为反向代理,可以做到静态由nginx提供响应,动态jsp代理给Tomcat

    LNMT:Linux + Nginx + MySQL + Tomcat

    LAMT:Linux + Apache(Httpd)+ MySQL + Tomcat

    • 反向代理多级:前置一台Nginx,给多台Tomcat实例做反向代理和负载均衡调度,Tomcat上部署的纯动态页面更适合

    LNMT:Linux + Nginx + MySQL + Tomcat

    • 反向代理多机多级

    LNNMT:Linux + Nginx + Nginx + MySQL + Tomcat

    动态服务器的问题,往往就是并发能力太弱,往往需要多台动态服务器一起提供服务。如何把并发的压力分摊,这就需要调度,采用一定的调度策略,将请求分发给不同的服务器,这就是Load Balance负载均衡。当单机Tomcat,演化出多机多级部署的时候,一个问题便凸显出来,这就是Session。而这个问题的由来,都是由于HTTP协议在设计之初没有想到未来的发展

    二、案例操作

    前提:关闭所有设备的防火墙和核心防护

    1. [root@localhost ~]#systemctl stop firewalld
    2. [root@localhost ~]#setenforce 0

    安装设备对应的服务软件,如nginx反向代理服务器、nginx服务器1和2都需安装nginx软件,Tomcat服务器1和2需安装tomcat软件

    1. #nginx反向代理服务器、nginx服务器1和2
    2. [root@localhost ~]#yum install epel-release.noarch -y
    3. [root@localhost ~]#yum install -y nginx
    4. [root@localhost ~]#systemctl start nginx
    1. #Tomcat服务器1和2需安装tomcat软件
    2. 参考https://blog.csdn.net/m0_71815887/article/details/136382688?spm=1001.2014.3001.5502

    注:

    • 当客户端访问的是静态资源,nginx反向代理服务器会根据负载均衡的轮询调度算法,分别调度到nginx服务器1或nginx服务器2处理静态资源(比例1:1)。如果客户端访问的是动态资源,nginx服务器1和nginx服务器2也会根据负载均衡的轮询调度算法,分别调度到tomcat服务器1或tomcat服务器2处理动态资源(比例1:1)
    • 在现实环境中,nginx反向代理服务器反向代理的nginx服务器1和nginx服务器2的网页内容是一样的,但这里,为了方便展示效果,就使用不同的网页,方便区分。tomcat服务器1和tomcat服务器2同理

    客户端访问:http://172.16.12.10/index.html     ---------> nginx服务器1     或   nginx服务器2

                          http://172.16.12.10/index.jsp       ---------> tomcat服务器1   或  tomcat服务器2

    nginx反向代理服务器配置:

    1. [root@localhost ~]#vim /etc/nginx/nginx.conf
    2. upstream web {
    3. server 172.16.12.11;
    4. server 172.16.12.12;
    5. }
    6. server {
    7. listen 80;
    8. listen [::]:80;
    9. server_name _;
    10. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    11. root /usr/share/nginx/html;
    12. location / {
    13. proxy_pass http://web/;
    14. }
    15. [root@localhost ~]#nginx -t
    16. [root@localhost ~]#nginx -s reload

    nginx服务器1配置:

    1. [root@localhost ~]#vim /etc/nginx/nginx.conf
    2. upstream web {
    3. server 172.16.12.11;
    4. server 172.16.12.12;
    5. }
    6. server {
    7. listen 80;
    8. listen [::]:80;
    9. server_name _;
    10. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    11. root /usr/share/nginx/html;
    12. location / {
    13. proxy_pass http://web/;
    14. }
    15. [root@localhost ~]#nginx -t
    16. [root@localhost ~]#nginx -s reload
    17. [root@localhost ~]#scp /etc/nginx/nginx.conf 172.16.12.12:/opt #将配置文件拷贝到nginx服务器2的opt目录下
    18. [root@localhost ~]#echo "welcome to static_server nginx 1 " > /usr/share/nginx/html/index.html

    nginx服务器2配置: 

    1. [root@localhost ~]#cd /opt
    2. [root@localhost opt]#cp nginx.conf /etc/nginx/nginx.conf
    3. [root@localhost opt]#nginx -t
    4. [root@localhost opt]#nginx -s reload
    5. [root@localhost opt]#echo "welcome to static_server nginx 2 " > /usr/share/nginx/html/index.html

     tomcat服务器1配置:

    1. [root@localhost ~]#mkdir /usr/local/tomcat/webapps/dynamic
    2. [root@localhost ~]#echo "welcome to dynamic_server tomcat 1 " > /usr/local/tomcat/webapps/dynamic/index.jsp
    3. [root@localhost ~]#vim /usr/local/tomcat/conf/server.xml
    4. "/usr/local/tomcat/webapps/dynamic"
    5. path="" reloadable="true" />
    6. [root@localhost ~]#systemctl restart tomcat

     

    tomcat服务器2配置:

    1. [root@localhost ~]#mkdir /usr/local/tomcat/webapps/dynamic
    2. [root@localhost ~]#echo "welcome to dynamic_server tomcat 2 " > /usr/local/tomcat/webapps/dynamic/index.jsp
    3. [root@localhost ~]#vim /usr/local/tomcat/conf/server.xml
    4. "/usr/local/tomcat/webapps/dynamic"
    5. path="" reloadable="true" />
    6. [root@localhost ~]#systemctl restart tomcat

    客户端测试:

    1. #访问静态资源
    2. [root@localhost ~]#curl 172.16.12.10/index.html

    1. #访问动态资源
    2. [root@localhost ~]#curl 172.16.12.10/index.jsp

  • 相关阅读:
    手机在我状态查询易语言代码
    IDEA复制代码到MD笔记格式还手动调,赶紧试试这个功能,一步到位
    工作5年,没用过分布式锁,正常吗?
    【速度收藏】17条好用的Python技巧分享(含源代码)
    vim以16进制打开和编辑文件
    R-YOLOv7-tiny检测浸水玉米胚乳裂纹
    go基础语法10问
    后台管理---删除功能
    前端js传入Long类型精度丢失解决办法
    120年奥运历史数据分析
  • 原文地址:https://blog.csdn.net/m0_71815887/article/details/136465664