只需三步,使用Docker创建Nginx反向代理
创始人
2025-07-12 14:31:13
0

在Web架构中,敏捷性和可伸缩性是必不可少的,在管理服务的同时也需要保证最佳性能。

为了达到这一目标,可以使用反向代理。反向代理非常灵活,可简化客户端和服务器之间的交互和通信。

如图所示,反向代理就像大楼里的接待员,该大楼有各个部门和区域。接待员成功地将客户或访客重定向到适当的部门。他们负责指引访客,处理查询,并确保各个部门之间的分发。

图片图片

反向代理的用途包括:

  1. 用于可伸缩性的负载均衡。
  2. 终止SSL和TLS。
  3. 将子域映射到特定路径。

本文将使用Nginx和Docker容器来设置反向代理。

第1步,创建应用程序

下载完整代码(https://github.com/DiptoChakrabarty/nginx-reverse-proxy)。

我们从构建作为代理的应用程序开始。

编写Docker文件,在访问此应用程序的/端点时显示一个简单的HTML页面。

FROM nginx:stable-alpine
COPY index.html /usr/share/nginx/html/index.html

index.html文件如下:

This is the main app

编写一个简单的Docker Compose文件,来运行这个应用程序。

version : '3.7'
services :
  web:
    build: .
    ports:
    - "8080:80"

通过运行以下命令启动Docker Compose:

docker-compose up

访问localhost:8080,应该能够看到以下内容。

图片图片

以类似的方式创建两个不同的应用程序,使用两个HTML文件和相同的Dockerfile。

This is html file for app1

This is APP 1

This is html file for app2

This is APP 2

修改Docker Compose文件以启动这两个容器:

version : '3.7'
services :
  web:
    build: .
    ports:
    - "8080:80"
    restart: always
  app1:
    build: ./app1/
    ports:
    - "8085:80"
    restart: always
  app2:
    build: ./app2
    ports:
    - "8010:80"
    restart: always

访问端口8085和8010时,可以看到如下内容:

图片图片

第2步,编写Nginx配置

编写Nginx配置文件,以在访问/app时,在app1和app2之间进行代理,而在/端点上只显示主页面。

Nginx配置如下所示:

worker_processes  1;  ## Default: 1
worker_rlimit_nofile 8192;

http {
  
  upstream cloud_server_com {
    server app1:80;
    server app2:80;
  }
  server {
    listen   80;
    location /app/ {
      proxy_pass      http://cloud_server_com/;
    }
    location / {
      root   /usr/share/nginx/html;
      index  index.html;
    }
    
  }
}

配置文件定义了组合在一起的服务器组。在这里,我们指定了在Docker Compose文件中定义的容器名称及其端口号。

location帮助Nginx定义如何处理特定端点的请求。/app/将请求发送到cloud_server_com上游,而cloud_server_com就是两个应用程序的容器。

proxy_pass确定了请求将被重定向到哪里。

现在,Docker Compose文件需要能够读取此配置,因此需要修改Compose文件,如下所示:

version : '3.7'
services :
  web:
    build: .
    ports:
    - "8080:80"
    volumes:
      - ./config/nginx.conf:/etc/nginx/nginx.conf
    restart: always
  app1:
    build: ./app1/
    ports:
    - "8085:80"
    restart: always
  app2:
    build: ./app2
    ports:
    - "8010:80"
    restart: always

第3步,运行容器

运行docker-compose up命令,然后在浏览器中查看反向代理的工作原理。

这是在/端点上运行的主应用程序:

图片图片

但是,在访问/app/端点时,它返回两个不同的服务器,代理逐个发送请求到app1和app2。

图片 图片 图片

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...