首页 > 代码库 > 【Web】Nginx 反向代理与负载均衡
【Web】Nginx 反向代理与负载均衡
反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
nginx反向代理工作流程如下:
Nginx设置反向代理如下,在Nginx配置文件中配置
1 server { 2 #侦听的80端口 3 listen 80; 4 server_name localhost; 5 6 location / { 7 8 proxy_pass http://127.0.0.1:81; #在这里设置一个代理 9 #以下是一些反向代理的配置可删除 10 proxy_redirect off; 11 #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP 12 proxy_set_header Host $host; 13 proxy_set_header X-Real-IP $remote_addr; 14 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 15 client_max_body_size 10m; #允许客户端请求的最大单文件字节数 16 client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数 17 proxy_connect_timeout 300; #nginx跟后端服务器连接超时时间(代理连接超时) 18 proxy_send_timeout 300; #后端服务器数据回传时间(代理发送超时) 19 proxy_read_timeout 300; #连接成功后,后端服务器响应时间(代理接收超时) 20 proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小 21 proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置 22 proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2) 23 proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传 24 } 25 }
负载均衡
负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。
Nginx负载均衡需要用到upstream模块。工作示意图如下:
nginx配置如下:
1 upstream my_server_pool{ 2 server 192.168.7.7:80 weight=1 max_fails=2 fail_timeout=30s; 3 server 192.168.7.8:80 weight=1 max_fails=2 fail_timeout=30s; 4 server 192.168.7.9:80 weight=1 max_fails=2 fail_timeout=30s; 5 } 6 7 server { 8 listen 80; 9 server_name localhost; 10 location / { 11 proxy_pass http://my_server_pool; 12 13 proxy_set_header Host $host; 14 proxy_set_header X-Real-IP $remote_addr; 15 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 16 } 17 }
【Web】Nginx 反向代理与负载均衡
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。