来源:小生方勤
ID:XSFQ_HSD
作者:小生方勤
前言
现在看到的这篇文章是修改后的第三个版本。
由于我家老板看过之后,对这篇文章的评价是:写的不错,语句是通顺的,排版是可以的,但反向代理是什么还是不清楚?所以我就想尝试着向非 IT 工作者解释“正向代理”和“反向代理”。
接下来我会先尝试面向大众,来解释“代理”的概念。在从专业的角度解释“正向代理”和“反向代理”。
概念实例化
在讲代理的概念之前我先讲个类比。也是我向我家老板解释的过程。
还好我反应机敏,要不然这个月的零花钱就要替我挡一刀了。可是我该怎么解释呢?还要让没有编程语言基础的人也听懂,伤脑筋啊!
在没有思绪的时候,她突然问我晚上吃了没有?这不就是很好的例子吗?
解释了这么久,不知道是真的懂了,还是因为太困了。不过我有钱吃肉了。
接下来我们就认真的看看“正向代理”和“反向代理”
概念
首先看看说明图,先有一个整体的理解。
正向代理( Forward Proxy ):
是指是一个位于客户端和原始服务器之间的服务器,为了从原始服务器取得内容, 客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。
反向代理( Reverse Proxy ):
是指以代理服务器来接受 Internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 Internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
接下来我提炼一下各自的特点。
特点
正向代理
反向代理
共同点
区别
说了这么多,现在说说代理在工作中的实机应用场景吧。
实际应用
上网软件 —— 正向代理
我们知道在国内用访问 www.google.com 是无法访问的,因为正常情况下是会被 GFW 限制访问的。
可是你还是想使用 google 来访问外国网站的话,这个时候我们就需要一些代理来帮我们去请求 www.google.com,代理再把响应结果返回给你。
GFW 的作用主要是用于分析和过滤中国境内外网络间的互相访问。也就是说,他不仅能限制国内网民访问境外的某些站点,也能限制国外用户访问国内的站点。我们通常说的“被墙”,就是指访问被 GFW 所限制。,顾名思义,则是突破限制。
Nginx 服务器 —— 反向代理
Nginx 服务器的功能有很多,诸如反向代理、负载均衡、静态资源服务器等。
客户端本来可以直接通过 HTTP 协议访问服务器,不过我们可以在中间加上一个 Nginx 服务器,客户端请求 Nginx 服务器,Nginx 服务器请求应用服务器,然后将结果返回给客户端,此时 Nginx 服务器就是反向代理服务器。
在虚拟主机的配置中配置反向代理
# 虚拟主机的配置
server
{
listen
8080
;
# 监听的端口
server_name
192.168
.
1.1
;
# 配置访问域名
root
/
data
/
toor
;
# 站点根目录
error_page
502
404
/
page
/
404.html
;
# 错误页面
location
^~
/
api
/
{
# 使用 /api/ 代理 proxy_pass 的值
proxy_pass http
:
//192.168.20.1:8080; # 被代理的应用服务器 HTTP 地址
}
}
以上简单的配置就可以实现反向代理的功能。
当然反向代理也可以处理跨域问题。
对于使用 vue-cli 搭建的工程而言,我们知道 vue-cli 采用 http-proxy-middleware 插件来进行代理服务器等各项配置。
所以我们可以利用 proxyTable,设置地址映射表。即使用 proxyTable 这个属性进行相关的配置来解决跨域问题带来的烦恼。配置如下:
...
proxyTable
:
{
'/weixin'
:
{
target
:
'http://192.168.20.1:8080/'
,
// 接口的域名
secure
:
false
,
// 如果是 https 接口,需要配置这个参数
changeOrigin
:
true
,
// 如果接口跨域,需要进行这个参数配置
pathRewrite
:
{
'^/weixin'
:
''
}
},
},
...
负载均衡的配置
# upstream 表示负载服务器池,定义名字为 my
upstream
my
{
server
192.168
.
2.1
:
8080
weight
=
1
max_fails
=
2
fail_timeout
=
30s
;
server
192.168
.
2.2
:
8080
weight
=
1
max_fails
=
2
fail_timeout
=
30s
;
server
192.168
.
2.3
:
8080
weight
=
1
max_fails
=
2
fail_timeout
=
30s
;
server
192.168
.
2.4
:
8080
weight
=
1
max_fails
=
2
fail_timeout
=
30s
;
# 即在 30s 内尝试 2 次失败即认为主机不可用
}
负载均衡即将 请求/数据 轮询分摊到多个服务器上执行,负载均衡的关键在于 均匀。
也可以通过 ip-hash 的方式,根据客户端 ip 地址的 hash 值将请求分配给固定的某一个服务器处理。
另外,服务器的硬件配置可能不同,配置好的服务器可以处理更多的请求,这时可以通过 weight 参数来控制。
我们整理了一个学习知识库,可以了解看一下:
【超全整理】《Linux云计算从入门到精通》系列实战笔记全放送 | Linux运维部落
http://www.magedu.com/74163.html
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。