一、前言 提到代理,我们可能想到最多的就是代理卖货,代理购物等。 而在互联网中,如果我们向访问国外的网站,我们必须得以国外的网络IP身份,才可以进行访问外网。基于这种情况下,VPN就诞生了,我们如果想访问外网,可能得需要购买国外的vpn来作为跳板机器,进行外网的访问。那么这个vpn服务器就相当于代理服务器。
二、正向代理 正向代理服务器时位于客户端和服务器之间,客户端为了从服务器获取数据,必须向代理服务器发送一个请求。并指定目标服务器,代理服务器将目标服务器返回的数据转交给客户端。
正向代理,是在用户端的。 举例:翻墙 正向代理中被代理的是客户端的请求
如果要访问某些国外网站,我们使用vpn进行了连接,并且vpn是在我们的用户浏览器端设置的(并不是在远端的服务器设置)。 浏览器先访问vpn地址,vpn地址转发请求,并最后将请求结果原路返回来。
三、反向代理 反向代理,客户端对代理是无感知的,客户端不需要任何配置就可以访问
反向代理是作用在服务器端的
访问流程:客户端将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端。 特点:反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
nginx反向代理的使用 在nginx的配置文件nginx.conf中新建一个虚拟主机的配置,
注:listen表示nginx要监听的端口; server_name 表示访问nginx时在浏览器中输入的域名,可以直接填ip地址,要绑定多个可以用空格隔开; location 表示nginx监听该端口时要匹配的url, 如果访问nginx的url中包含有/test/时,就执行代理; proxy_pass 表示nginx要把客户端的请求代理到的目标。 这里需要注意的是: proxy_pass的路径写法,如果像上边这样,路径的结尾不带/,表示的是相对路径,那么nginx在转发请求时不会截取掉原始url中的/test/ ,如浏览器访问http://localhost:8080/test/abc,那么nginx实际发出的请求地址是http://localhost/test/abc。
如果proxy_pass的目标路径配置时 末尾带上了/ ,表示的是绝对路径,那么nginx在转发请求时就会截取掉原始url中的/test/ ,如浏览器访问http://localhost:8080/test/abc,那么nginx实际发出的请求地址是http://localhost/test。