静态页面负载均衡

如有两个节点xxx.xx.xxx.123、xxx.xx.xxx.456,

一、tomcat组件负载均衡

部署后端服务,启动tomcat即可启动服务。如123和456的8080端口上均部署了myTest服务,使用upstream直接代理即可。

复制代码
upstream myTest_upstream {
	server xxx.xx.xxx.123:8080 weight=10 max_fails=10 fail_timeout=2s;
	server xxx.xx.xxx.456:8080 weight=10 max_fails=10 fail_timeout=2s;
}
	
	
server {
	listen       80;
	server_name  xxx.xxx.cn;
	set $bg_groupName MYTEST;
	set $bg_env online;
	location ~ /myTest/(.*) {
		set $bg_context_path  myTest;
		set $backend myTest_upstream;
		rewrite_by_lua_file '/usr/local/nginx/nginx/bluegreen-lua/src/upstream_chooser.lua';
			proxy_set_header Host $http_host;
        proxy_set_header X-Real-Ip $remote_addr;
        proxy_set_header X-Forwarded-For $remote_addr;
		proxy_pass http://$backend;
		access_log logs/access_myTest.log main;
	}
}

二、静态页面负载均衡

有几下几种方法:

1、tomcat部署

静态页面放到后端的静态目录下/src/main/resources,使用tomcat启动后端即可访问静态页面,当代理了该ip端口负载均衡后,静态页面也实现了负载均衡。具体方法同上。

2、静态目录

将静态页面(如html、vue打包后的dist文件等)放到某一目录下如/data/***,使用本机nginx反向代理该目录,那么通过nginx也可以访问静态页面。此时实现负载均衡需要一个总nginx代理两个子nginx,所以需要三个nginx:

(1)123机器:

安装nginx,上传目标文件到固定目录下,使用nginx代理该目录,如:

复制代码
    server {
        listen       70;
        server_name  localhost;
        #charset koi8-r;

        #access_log  logs/host.access.log  main;
        error_page 405 =200 $request_uri;

         location ^~ /report-h5/ {
           root /data/public/nginx/;
         }

        location ^~ /message-h5/ {
      
            root /data/public/nginx/;
         }
   }

(2)456机器:

同123机器

(3)主Ng:

主ng可以安装在123机器上,可以安装在456机器上,也可以安装在其他机器上。负责负载均衡123和456两个机器,

复制代码
  location ^~ /report-h5 {
		set $bg_context_path  htm-report-app;
		set $backend report_upstream;
		rewrite_by_lua_file '/usr/local/nginx/nginx/bluegreen-lua/src/upstream_chooser.lua';
			proxy_set_header Host $http_host;       
       proxy_set_header X-Real-Ip $remote_addr;
        proxy_set_header X-Forwarded-For $remote_addr;
		proxy_pass http://$backend;
		access_log logs/access_htm-report-app.log main;
	}
	
	
	location ^~ /message-h5 {
		set $bg_context_path  htm-message-app;
		set $backend message_upstream;
		rewrite_by_lua_file '/usr/local/nginx/nginx/bluegreen-lua/src/upstream_chooser.lua';
			proxy_set_header Host $http_host;       
        proxy_set_header X-Real-Ip $remote_addr;
        proxy_set_header X-Forwarded-For $remote_addr;
		proxy_pass http://$backend;
		access_log logs/access_htm-message-app.log main;
	}
	
	
	
	upstream report_upstream {
	 server xxx.xx.xxx.123:70 max_fails=1 fail_timeout=10s;
	 server xxx.xx.xxx.456:70 max_fails=1 fail_timeout=10s;
   }
   
    upstream message_upstream {
	 server xxx.xx.xxx.123:70 max_fails=1 fail_timeout=10s;
	 server xxx.xx.xxx.456:70 max_fails=1 fail_timeout=10s;
   }

三、tomcat和静态页面同时存在

1、后端组件

直接使用主ng负载均衡即可;

2、静态页面

(1)分别上传到123、456两个子Ng上,并配置反向代理;

(2)使用主ng代理两个子Ng。

相关推荐
Lsir10110_11 分钟前
【Linux】进程信号(下半)
linux·运维·服务器
skywalk816327 分钟前
unbound dns解析出现问题,寻求解决之道
运维·服务器·dns·unbound
酉鬼女又兒29 分钟前
零基础入门Linux指南:每天一个Linux命令_pwd
linux·运维·服务器
云飞云共享云桌面31 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
skywalk816333 分钟前
走近科学:unbound dns域名服务器自己本地解析出现问题,寻求解决之道
运维·服务器·dns·unbound
袁煦丞 cpolar内网穿透实验室37 分钟前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
AZ996ZA1 小时前
自学linux的第二十一天【DHCP 服务从入门到实战】
linux·运维·服务器·php
神梦流2 小时前
GE 引擎的非标准数据流处理:稀疏张量与自定义算子在图优化中的语义保持
linux·运维·服务器
兜兜转转了多少年2 小时前
从脚本到系统:2026 年 AI 代理驱动的 Shell 自动化
运维·人工智能·自动化
Lsir10110_3 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件