目录
作为代理服务器是当客户端访问代理服务器时,代理服务器代理客户端去访问真实web服务器。proxy_pass; 用来设置将客户端请求转发给的后端服务器的主机。
需要模块ngx_http_upstream_module支持。
单台反向代理
在第三台主机上下载安装httpd,在主页面/var/www/html/下写一个页面index.html
并启动systemctl start httpd别忘了关防火墙
data:image/s3,"s3://crabby-images/5032a/5032ac99675c337baa641ef49a510ba9b7f4bf78" alt=""
在7-1上做代理服务器,写入location配置文件:
data:image/s3,"s3://crabby-images/1c453/1c453c6ef6850e9cd3c024da1db5bb9e1834fd81" alt=""
当有客户端访问我的IP时,我把请求转给指定的IP处理。保存退出,重新加载配置文件nginx -s reload
使用7-2访问7-1那么应该显示Node3的网页内容,也就是显示7-3 7-3
data:image/s3,"s3://crabby-images/9772c/9772c8ca5bf4eefd59ada31c85450ff40a09b9e7" alt=""
proxy_pass后面加不加/的问题:
location /test {
proxy_pass http://192.168.114.30; #不加/
}
这里直接是将/test附加到192.168.114.30后面,也就是192.168.114.30/test/index.html,也就是主站点要有test这个文件夹。
在web网站建立主页面index.html内容为/var/www/html在主页面中建立test文件夹,里面创建一个内容为/var/www/html/test的文件index.html
data:image/s3,"s3://crabby-images/170d1/170d1597a14d4458f744cb3ccd2b4fadee036e4c" alt=""
使用Node2访问192.168.114.10/test
可以发现获取到的是/var/www/html/test也就是192.168.114.10/test/index.html类似于root
data:image/s3,"s3://crabby-images/cfd71/cfd71482c65cf740b559201ef8473b25a35e3a1f" alt=""
如果加/:
location /test {
proxy_pass http://192.168.114.30/;
}
发现实际返回的是proxy_pass后面的url的内容,也就是192.168.114.10/index.html类似于alias
data:image/s3,"s3://crabby-images/fa9a1/fa9a12cc99c2e0b03391f8fa0084b5c53a141b1d" alt=""
反向代理动静分离
动静分离是实现客户端访问动态和静态资源时,代理服务器通过匹配url访问不同的服务器。
用浏览器作为客户端,7-1反向代理,7-2作为静态服务器,7-3作为动态服务器。
7-2和7-3使用httpd即可,
data:image/s3,"s3://crabby-images/ea37b/ea37bcc5c34766938b1f7c939942f4331cb0cdfb" alt=""
7-1上的配置:
data:image/s3,"s3://crabby-images/147ec/147ec95699d93389a091b1da7c5e076d2df015a6" alt=""
重启配置文件:nginx -s reload
开启正则表达式~*,不能加/
当在浏览器访问192.168.114.10/a.jpg时,代理服务器会匹配以.jpg结尾的url,转给Node3主机处理,访问a.jpg图片:
data:image/s3,"s3://crabby-images/f7576/f75769d9c5692ddcbfa62fcde452f4eccb8eadda" alt=""
当在浏览器访问192.168.114.10/api时,匹配访问192.168.114.20静态服务器。
data:image/s3,"s3://crabby-images/b4326/b4326adede95001312d8f8c28825b82b306bb920" alt=""
反向代理负载均衡
当客户端访问网页时,代理服务器通过对客户端发出的请求分别交给真实服务端依次提供服务,解决单台服务器负载问题。
当7-4客户机访问代理服务器7-1时,7-1分别交给7-2或7-3依次执行,对多个服务端设置成一个服务器组,upstream,在location模块中写入代理转交给组名称。
7-1代理服务器端的配置:
data:image/s3,"s3://crabby-images/9949c/9949cf47ef33846f62beb864040d8d62115f886a" alt=""
在web服务器组中,还可以加权重,weight=2;
server 192.168.114.20 weight=2;默认都是1,加权重之后就是192.168.114.20大概是两次,192.168.114.10大概是1次,并不是绝对的。
我们在两台真实服务器端使用httpd模拟web服务器。分别在主页写入文件:
data:image/s3,"s3://crabby-images/10ac5/10ac5d157c6c226441a45e435ebdb14886bb9253" alt=""
data:image/s3,"s3://crabby-images/df091/df091e1dba3436855f731e1047a13a8303df8ce1" alt=""
在7-4上测试如下,发现每次访问代理服务器,7-2和7-3都会交替提供服务。实现负载均衡效果。
data:image/s3,"s3://crabby-images/ead40/ead406ad628e5ea67fe538136c78c6de10cf79a6" alt=""
-------end---------