前言:NGINX的反向代理和负载均衡是网站架构中经常用到的一种高并发,高可用的方案,下面我们直接实战操作,当然理论也是要的。
一、反向代理
过程:反向代理:客户端 一>代理 <一> 服务端举个例子: A(客户端)想租一个房子,B(代理)就把这个房子租给了他。 这时候实际上C(服务端)才是房东。 B(代理)是中介把这个房子租给了A(客户端)。这个过程中A(客户端)并不知道这个房子到底谁才是房东 他都有可能认为这个房子就是B(代理)的总结:反向代理中客户端是并不知道自己要访问哪个服务器,反向代理模式屏蔽或者隐藏了真实服务器信息。 一>
结构图
1、什么是正向代理
过程:客户端 <一> 代理 一>服务端举个例子:A(客户端)想租C(服务端)的房子,但是A(客户端)并不认识C(服务端)租不到。 B(代理)认识C(服务端)能租这个房子所以你找了B(代理)帮忙租到了这个房子。总结:正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。 一>
2、正向代理和反向代理的区别
3、反向代理各个参数说明
二、负载均衡
说明:客户端发送的、nginx反向代理服务器接收到的请求数量,就是我们说的负载量,请求数量按照一定的规则进行分发到不同的服务器处理的规则,就是一种均衡规则,所以将服务器接收到的请求按照规则分发的过程,称为负载均衡。
示意图
nginx支持的负载均衡调度算法方式:
三、实战操作
1、环境
代理服务器(接收所有请求) 192.168.8.146服务器 1、192.168.8.228:8080 2、192.168.8.228:8081 3、192.168.8.228:8082
1)代理服务器
2)服务器
1号服务器 server { listen 8080; server_name www.common.com; root /www/local; charset utf-8; index index.php index.html index.htm; try_files $uri $uri/ /index.php?$query_string; location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } } 2号服务器 server {
listen 8081; server_name www.common.com; root /www/test-common/common/public; charset utf-8; index index.php index.html index.htm; try_files $uri $uri/ /index.php?$query_string; location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
3号服务器 server {
listen 8082; server_name www.common.com; root /www/test; charset utf-8; index index.php index.html index.htm; try_files $uri $uri/ /index.php?$query_string; location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
2、效果
四、总结
这篇文章只是简单的试了下效果,而且均衡的方式只试了权重,包括代理方面,有些参数没有配置,欢迎大家补充尝试