Nginx 篇章-反向代理
admin
2023-02-26 12:02:08
0

讲述反向七层代理的配置文件以及解释

Nginx官网:https://www.nginx.com/

Centos yum安装nginx

yum install nginx -y

so,我们先提个问题,What?为何要用Nginx实现七层代理,什么是七层代理?

1、有无nginx proxy的区别

传统无nginx web架构:

看下面一张图:

Nginx 篇章-反向代理

首先,我们有一个域名 www.test_app.com,后端有三台服务器,都运行PHP+Nginx服务,如果要实现三台服务器都提供网站服务,我们需要具备下面几个条件(缺点)。

1、每台web服务器都需要有固定的公网IP地址(成本高)
2、一个域名需要对应多个公网IP(扩展性差)
3、每添加一台web服务器都需要动用dns配置以及购买固定公网IP(灵活性差)

so,缺点很明显了

nginx proxy架构:

Nginx 篇章-反向代理

这时,我们在前端部署一台nginx proxy(反向代理),就可以解决刚才上面所说的问题,可以在nginx proxy配置proxy pool,称为代理池,里面填写后端web节点的IP:PORT,每次扩展一台Web节点的时候,只需要在该proxy pool中添加IP:PORT,然后在reload一下nginx即可,并且该nginx proxy只需要有一个固定的公网IP即可,DNS只需要绑定该公网IP

2、Nginx Proxy简介
Nginx的负载均衡功能依赖于ngx_http_upsteam_module模块,所支持的代理方式包括proxy_pass,fastcgi_pass,memcached_pass等,新版Nginx软件支持的方式有所增加。本文主要讲解proxy_pass代理方式。
ngx_http_upstream_module模块允许Nginx定义一组或多组节点服务器组,使用时可以通过proxy_pass代理方式把网站的请求发送到事先定义好的对应Upstream组的名字上,具体写法为“proxy_pass http:// www_server_pools”,其中www_server_pools就是一个Upstream节点服务器组名字。

upstream模块内部server标签部分参数说明:

模块参数 说明
server 负载均衡后面的RS地址,可域名或IP
weight 服务器权重,权重数字越大表示请求越多,默认为1
max_fils 尝试连接后端节点失败的次数,默认为1
backup 表示节点作为备份服务器
fail_timeout 在max_fails定义次数失败后,距离下次检查间隔时间

3、Nginx Proxy调度算法
静态调度算法:

算法 说明
rr 轮询,默认调度算法,将请求按顺序分配到不同的后端节点
wrr 权重轮询,权重值越大,后端节点接受的请求也就越多
ip_hash 会话保持,每个请求按照客户端的IP的Hash结果来分配后端节点

动态调度算法:

算法 说明
fair 响应时间,根据后端节点的响应时间来分配请求
least_conn 最小连接数,根据后端节点的连接数来分配请求
url_hash web缓存节点,根据访问的URL的hash结果来分配请求

注意调度算法只能使用一种

nginx proxy常见配置文件(多域名):

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    # 这是代理池,池子名:blog_server_pools,将web节点的IP:PORT/域名 添加到此即可
    upstream blog_server_pools {    
                    server 172.16.1.7:80 weight=3 max_fils=3 fail_timeout=5;
                    server 172.16.1.8:80 weight=2 max_fils=3 fail_timeout=5;
                    server 172.16.1.9:80 weight=1 backup max_fils=3 fail_timeout=5; 
           }

      upstream www_server_pools {    
                     # 使用调度算法:ip_hash 
                     ip_hash
                     server 172.16.1.10:80  max_fils=3 fail_timeout=5;
                     server 172.16.1.11:80 max_fils=3 fail_timeout=5;
                     server 172.16.1.12:80 weight=1 backup max_fils=3 fail_timeout=5;   
           }

    server {          
        listen       80;
        server_name  blog.youngboy.org;
        location / {
        # 通过proxy_pass 调用对应的代理池
        proxy_pass http://blog_server_pools; 
        # proxy优化参数(下面有解释)
        proxy_redirect default;
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-forwarded-for $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_send_timeout 60;
        proxy_read_timeout 60;
        proxy_buffer_size 32k;
        proxy_buffers 4 128k;
        proxy_busy_buffers_size 256k;
        proxy_temp_file_write_size 256k;

                   }
       }
    server {          
        listen       80;
        server_name  www.youngboy.org;
        location / {
        proxy_pass http://www_server_pools; 
        proxy_redirect default;
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-forwarded-for $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_send_timeout 60;
        proxy_read_timeout 60;
        proxy_buffer_size 32k;
        proxy_buffers 4 128k;
        proxy_busy_buffers_size 256k;
        proxy_temp_file_write_size 256k;

                   }
       }     
}

我们会发现。每添加一个server标签(一个站点),都需要将nginx proxy参数粘贴一遍,这样会导致配置冗余
我们可以将proxy优化参数配置写到一个文件中

# vim /etc/nginx/conf.d/http.proxy
proxy_redirect default;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-forwarded-for $proxy_add_x_forwarded_for;
proxy_connect_timeout 60;
proxy_send_timeout 60;
proxy_read_timeout 60;
proxy_buffer_size 32k;
proxy_buffers 4 128k;
proxy_busy_buffers_size 256k;
proxy_temp_file_write_size 256k;

在nginx http标签下,使用include来引入刚刚创建的proxy文件

....
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
        include /etc/nginx/conf.d/http.proxy;
....
}

平滑重启nginx

nginx -s reload

4、Nginx Proxy优化参数

# 设置http请求header项传给后端服务器节点
proxy_set_header

# 用于指定客户端请求主体缓冲区大小
client_body_buffer_size 

# 表示反向代理与后端节点服务器连接的超时时间,即发起握手等待响应的超时时间
proxy_connect_timeout   

# 表示代理后端服务器的数据回传时间,即在规定时间内服务器必须传完所有的数据,否则,Nginx将断开这个连接
proxy_sed_simeout   

# 设置Nginx从从代理的后端服务器获取信息的时间,表示连接建立成功后,Nginx等待后端服务器的响应时间,其实是Nginx已经进入后端的派对之中等候处理的时间
proxy_read_timeout  

# 设置缓冲区大小,默认该缓冲区大小等于指令proxy_buffers设置的大小
proxy_buffer_size   

# 设置缓冲区的数量和大小。Nginx从代理后端的服务器获取的响应信息,会防止缓冲区
proxy_buffers   

# 用于设置系统很忙时可以使用的proxy_buffers大小,官方推荐的大小为proxy_buffers*2
proxy_busy_buffers_size 

# 指定proxy缓存临时文件的大小
proxy_temp_file_write_size  

相关内容

热门资讯

终于了解“快乐打筒子.怎么装挂... 有 亲,根据资深记者爆料快乐打筒子是可以开挂的,确实有挂(咨询软件无需打...
玩家最新攻略“琼戏互娱.究竟有... 您好:琼戏互娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
终于了解“新九方炸金花.开挂器... 有 亲,根据资深记者爆料新九方炸金花是可以开挂的,确实有挂(咨询软件无需...
最新引进“新蓝鲸.到底有挂吗?... 有 亲,根据资深记者爆料新蓝鲸是可以开挂的,确实有挂(咨询软件无需打开直...
玩家攻略科普“中至上饶麻将.真... 您好:中至上饶麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款...
【今日要闻】“花城牌舍.可以开... 有 亲,根据资深记者爆料花城牌舍是可以开挂的,确实有挂(咨询软件无需打开...
乌代表团与美欧举行系列会议,美... 当地时间12月21日,美国总统特使威特科夫表示,过去三天,乌克兰代表团在美国佛罗里达州与美国和欧洲伙...
终于懂了“新青鸟牛牛.怎么装挂... 您好:新青鸟牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
今日重磅消息“圣盛宜昌花牌.真... 今日重磅消息“圣盛宜昌花牌.真的有挂吗?”其实是有挂您好,圣盛宜昌花牌这个游戏其实有挂的,确实是有挂...
开发者破1000万,华为鸿蒙迈... 据心声社区公众号 12 月 19 日分享,鸿蒙迈过了生死线 —— 搭载 HarmonyOS 5、Ha...