NGINX 反向代理

引自:反向代理
在电脑网络中,反向代理是代理服务器的一种。服务器根据客户端的请求,从其关系的一组或多组后端服务器(如Web服务器)上获取资源,然后再将这些资源返回给客户端,客户端只会得知反向代理的IP地址,而不知道在代理服务器后面的服务器簇的存在。

根据域名转发请求

这个功能适用于希望一台服务器部署多个应用,并通过不同的域名进行访问的需求。

NGINX 的http配置文件一般是/etc/nginx/conf.d/下新建各自项目以.conf后缀的配置文件;

假设有两个应用,分别是

域 名 端口
app1.example.com 8001
app2.example.com 8002

那么,对应的 NGINX http配置如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# /etc/nginx/conf.d/app1.example.com.conf
server {
listen 80;
server_name app1.example.com;
location / {
proxy_pass http://localhost:8001;
}
}

# /etc/nginx/conf.d/app2.example.com.conf
server {
listen 80;
server_name app2.example.com;
location / {
proxy_pass http://localhost:8002;
}
}

以上配置就会根据域名选择不同的端口进行请求,当访问app1.example.com就会转发到localhost:8001,访问app2.example.com就会转发到localhost:8002,就实现了反向代理。
这样的方式还可以很好的隐藏服务器开放的端口,只需要把80端口开放,对于其他端口都通过转发来访问。

注意
不要忘记在域名提供商处,对域名添加解析

根据路径转发请求

这个已有前辈整理的很好了,我就不再赘言了,以下内容转载自NGINX实现请求转发

反向代理适用于很多场合,负载均衡是最普遍的用法。

NGINX 作为目前最流行的web服务器之一,可以很方便地实现反向代理。

NGINX 反向代理官方文档: NGINX REVERSE PROXY

当在一台主机上部署了多个不同的web服务器,并且需要能在80端口同时访问这些web服务器时,可以使用 NGINX 的反向代理功能: 用 NGINX 在80端口监听所有请求,并依据转发规则(比较常见的是以 URI 来转发)转发到对应的web服务器上。

例如有webmail , webcom 以及 webdefault 三个服务器分别运行在 portmail , portcom, portdefault 端口,要实现从同一个域名同在80端口同时访问这三个web服务器,则可以在80端口运行 NGINX, 然后将 /mail 下的请求转发到 webmail 服务器, 将 /com下的请求转发到 webcom 服务器, 将其他所有请求转发到 webdefault 服务器。

假设服务器域名为example.com,则对应的 NGINX http配置如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
http {
server {
server_name example.com;

# 代理后删除/mail/前缀
location /mail/ {
rewrite /mail/(.*) /$1 break;
proxy_pass http://example.com:protmail/;
}

# 上面的例子,自造百度233
location /baidu {
rewrite /baidu(.*) /$1 break;
proxy_pass https://www.baidu.com/;
}

# 代理后保留/com/前缀
location /com/ {
proxy_pass http://example.com:portcom/main/;
}

location / {
proxy_pass http://example.com:portdefault;
}
}
}

以上的配置会按以下规则转发请求( GET 和 POST 请求都会转发):

http://example.com/mail/下的请求删除/mail后,转发到 http://example.com:portmail/
例:http://example.com/mail/hello->http://example.com:portmail/hello

http://example.com/com/下的请求转发到 http://example.com:portcom/main/
例:http://example.com/com/hello->http://example.com:portcom/main/com/hello

将其它所有请求转发到 http://example.com:portdefault/
例:http://example.com/cn->http://example.com:portdefault/cn