文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

只需三步,使用Docker创建Nginx反向代理

2024-11-30 01:38

关注

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

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

图片

反向代理的用途包括:

  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文件如下:

编写一个简单的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 html file for app2

修改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。

图片

来源:Java学研大本营内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯