Nginx负载均衡+静态代理+动静分离===>配置文件基本配置

发布于:2023-01-10 ⋅ 阅读:(460) ⋅ 点赞:(0)

Nginx负载均衡的架构图:

 

Nginx负载均衡的配置文件修改:

第一步:在http模块加上upstream配置

upstream www.myweb.com { 
     	server  127.0.0.1:9100 weight=3; 
      	server  127.0.0.1:9200 weight=1;  
}

其中weight=1表示权重,用于后端服务器性能不均的情况,访问比率约等于权重之比,权重越大访问机会越多;server后的“ip:端口号”为开启的***tomcat的端口号***;;

upstream是配置nginx与后端服务器负载均衡非常重要的一个模块,并且它还能对后端的服务器的健康状态进行检查,若后端服务器中的一台发生故障,则前端的请求不会转发到该故障的机器
第二步:在server模块里添加location,并配置proxy_pass

location /myweb {
	proxy_pass http://www.myweb.com;
}

其中 www.myweb.com 字符串要和 upstream 后面的字符串相等

我是分割线*************************************************************

Nginx常用负载均衡策略

1、轮询(默认)

这里的轮询并不是每个请求轮流分配到不同的后端服务器,与ip_hash类似,但是按照访问url的hash结果来分配请求,使得每个url定向到同一个后端服务器,主要应用于后端服务器为缓存时的场景下。如果后端服务器down掉,将自动剔除

	upstream backserver { 
    	server 127.0.0.1:8080; 
    	server 127.0.0.1:9090; 
    } 

2、权重

每个请求按一定比例分发到不同的后端服务器,weight值越大访问的比例越大,用于后端服务器性能不均的情况
	upstream backserver { 
    	server 192.168.0.14 weight=2; 
    	server 192.168.0.15 weight=1;
    }

3、ip_hash===>相同ip访问的理论上一直是同一个端口

ip_hash也叫IP绑定,每个请求按访问ip的hash值分配,这样每个访问客户端会固定访问一个后端服务器,可以解决会话Session丢失的问题
	算法:hash("124.207.55.82") % 2 = 0, 1

	upstream backserver { 
    	ip_hash; 
    	server 127.0.0.1:8080; 
    	server 127.0.0.1:9090; 
    }

4、最少连接

web请求会被转发到连接数最少的服务器上

	upstream backserver { 
    	least_conn;
    	server 127.0.0.1:8080; 
    	server 127.0.0.1:9090; 
    }

5、补充配置

配置1:backup
    upstream backserver { 
    	server 127.0.0.1:9100;
		#其它所有的非backup机器down的时候,才请求backup机器
    	server 127.0.0.1:9200 backup; 
    }

配置2:down
	upstream backserver { 
        server 127.0.0.1:9100;
        #down表示当前的server是down状态,不参与负载均衡
        server 127.0.0.1:9200 down; 
    } 


一般在项目上线的时候,可以分配部署不同的服务器上,然后对Nginx重新reload。
reload不会影响用户的访问,或者可以给一个提示页面,系统正在升级...

***我是分割线***

静态代理的结构图

 

静态代理的配置文件修改

1、在nginx.conf的location中配置静态资源的后缀

例如:当访问静态资源,则从linux服务器/opt/static目录下获取(举例)

location ~ .*\.(js|css|htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid
|doc|ppt|pdf|xls|mp3|wma)$ {
    	root /opt/static;
}

说明:
~ 表示正则匹配,也就是说后面的内容可以是正则表达式匹配
第一个点 . 表示任意字符
*表示一个或多个字符
\. 是转移字符,是后面这个点的转移字符
| 表示或者
$ 表示结尾

整个配置表示以 .后面括号里面的这些后缀结尾的文件都由nginx处理
放置静态资源的目录,要注意一下目录权限问题,如果权限不足,给目录赋予权限; 
否则会出现403错误 chmod 755

/opt/static可理解为自定义的保存静态资源的路径;两种方式:绝对路径和相对路径,但是我一直没搞懂,所以我就步误人子弟了


{可以不看}补充:假如访问图片的路径为http://192.168.235.128/myweb/image/001.jpg;因为我们在nginx中配置了对静态资源访问的拦截,所以请求会交给nginx服务器进行处理。根据ip + port等于root的原则,我们会去/opt/static/myweb/image目录下存在001.jpg资源,所以在/opt/static下创建myweb目录,并放入image目录及图片

2、在nginx.conf的location中配置静态资源所在目录实现

例如:当访问静态资源,则从linux服务器/opt/static目录下获取(举例)

location ~ .*/(css|js|img|images) {
    	root   /opt/static;
}

xxx/css
xxx/js
xxx/img
xxx/images

	我们将静态资源放入 /opt/static 目录下,然后用户访问时由nginx返回这些静态资源



补充注意:拦截的目录一定要与拦截的目录名一致

*********我是分割线*******

动静分离

原理:Nginx的负载均衡和静态代理结合在一起动态资源,如jsp由tomcat或其他web服务器完成。静态资源,如图片、css、js等由nginx服务器完成

结构图:

整个架构中,一个nginx负责负载均衡,两个nginx负责静态代理。Nginx在一台Linux上安装一份,可以启动多个Nginx,每个Nginx的配置文件不一样即可

配置文件修改:

1、新启动的两个子nginx的配置文件需要修改:

因为这两个机器只需要做静态代理,所以删除掉负载均衡的配置

 同时,给两个子nginx的配置文件中添加静态代理的配置:

 2、修改主nginx的配置文件

添加动态资源的负载均衡:分发到两个tomcat

upstream www.myweb.com { 
    server  127.0.0.1:9100 weight=5; 
    server  127.0.0.1:9200 weight=2;  
}

location /myweb {
    	proxy_pass http://www.myweb.com;
}
添加静态资源的负载均衡;访问的静态资源会根据权重来访问不同的nginx来获取静态资源

upstream static.myweb.com { 
    server  127.0.0.1:81 weight=1; 
    server  127.0.0.1:82 weight=1;  
}

location ~ .*/(css|js|img|images) {
    	proxy_pass http://www.static.myweb.com;
}
补充:启动多个nginx的时候,需要启动子nginx后再启动主nginx

******我是分割线*******

补充:

关于tomcat端口号的修改: