Docker的使用
前言
有些时候我们会遇到这种问题,有A、B两平台,在A平台下有购买的服务器C和域名D,在B平台下有购买的服务器E,问如何使用域名D的二级域名访问B平台下的E服务器?一般我们会想到在A平台下的域名解析中添加指向B平台下的E服务器公网ip的二级域名。但我们知道一般这样是行不通的,B平台会对未在B平台中备案解析的域名请求进行拦截,进而指引你备案或域名转入。这时候你想我不是已经备案了么,怎么还给我搞这些。那么想解决这个问题有没有更好的处理办法呢?答案是有的,那就是使用Nginx反向代理。
提示:以下是本篇文章正文内容,下面案例可供参考
一、Nginx反向代理配置
server {
listen 80 default_server;
listen [::]:80 default_server ipv6only=on;
root /usr/share/nginx/html;
index index.html index.htm;
server_name localhost;
location / {
try_files $uri $uri/ =404;
}
}
# 代理的A平台下的C服务器8080端口。
server
{
listen 80;
server_name 8080.a.com; # 这里填A平台的二级域名
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://C服务器公网ip:8080;
}
}
# 代理的A平台下的C服务器8081端口。
server
{
listen 80;
server_name 8081.a.com; # 这里填A平台的二级域名
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://C服务器公网ip:8081;
}
}
# 代理的B平台下的E服务器8080端口。
server
{
listen 80;
server_name b.a.com; # 这里填A平台的二级域名
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://E服务器公网ip:8080;
}
}