docker nginx 配置反向代理和负载均衡

1. 获取及配置nginx  

  如果需要全站通过docker部署,那么nginx或许是不可或缺的。通过配置nginx,可以迅速实现负载均衡和反向代理服务。值得一提的是,docker官网恰好也有nginx镜像。通过以下命令获取:

$ docker pull nginx:latest

  nginx镜像的配置和正常使用时是一样的,一般都是在/etc/nginx/conf.d目录下建立自己的filename.cnf文件即可。不同的,docker nginx通过挂载的方式将配置文件应用到nginx。
  例如,我在本地$HOME/nginx/conf.d文件夹下建立default.cnf文件,文件内容:

upstream backends {
    server app1:8080;
    server app2:80801;
}

server {
    listen        80;
    listen       443 ssl;
    server_name example.com;
    # SSL
    # ssl on; # 只允许ssl方式访问
    ssl_certificate /etc/ssl/certs/example.pem;
    ssl_certificate_key /etc/ssl/certs/example.key;
    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;

    #proxy to webs
    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://backends;      # 这里设置你要代理的ip+端口
    }
}

其中,
upstream backends {}:实现了名称为backends的负载均衡。可存在多个,如有需要,还可以自行创建其他。
listen 80:监听80端口。
listen 443 ssl;监听443端口,并且开启ssl。
ssl_certificate, ssl_certificate_key:加载ssl证书。他们指定的是镜像中ssl证书文件的位置,推荐将证书放到如上位置。他们后面的几个配置,都是ssl的默认配置,不需要修改。
location ~.*/{}:nginx文件路径的正则匹配,将外部对服务器的访问,自动分配到docker应用程序容器,交给这些应用程序处理请求。

  这个文件实现了简单地http访问、https访问,以及简单地负载均衡(将外部对服务器的请求,随机地分配到app1和app2这两个容器处理)。

2. 启动nginx

  通过upstream的配置,我们看到,nginx还关联着其他两个容器:app1、app2,并且需要能够和这两个容器相互通信。所以,启动nginx之前,需要先启动其他两个容器,这样通过命令行纪委不方便,我们通过docker-compose的编写配置文件的方式来启动nginx。
  文件内容如下:
docker-compose.yml 

version: "3"
services:
  nginx:
    image: nginx
    container_name: nginx
    depends_on:
      - todolist
    ports:
      - "443:443" # https访问端口
      - "80:80" # http访问端口
    volumes:
      - $HOME/etc/nginx/conf.d:/etc/nginx/conf.d # 挂载配置文件
      - $HOME/etc/ssl/certs:/etc/ssl/certs # 挂载证书文件
    links:
      - app1 # 相当于 docker run 中的 --link
      - app2

  app1: # 镜像服务的名称(不指定container_name,docker-compose在此基础上构建名称)
    image: web # 既然是负载均衡,那么启动的镜像必然是相同的
    container_name: app1 # 这样写是必要的,否则docker-compose将采用默认命名方式
    ports:
      - "8080:8080" # 端口映射不是必要的。详情请连接docker的通信
  app2:
    image: web
    container_name: app2
    ports:
      - "8081:8081" # 端口映射不是必要的。详情请连接docker的通信

  在以上文件所在的目录运行以下命令,即可启动nginx,体验配置结果了:

$ docker-compose up -d


需要注意地地方:


1. nginx镜像暴露了两个端口,80443。如果需要通过http的方式访问,一定要映射80端口;如果需要通过https的方式访问,一定要映射443端口。默认同时映射就好了,更新配置方便。
2. docker-compose中指定镜像的名字,使用container_name属性。

我看了网上的很多教程,都没有提到nginx的启动问题,尤其是端口映射。如果你启动时,没有映射443端口,单独配置http访问或者https访问,不会发生任何问题,一旦要配置二者可以同时访问,或者http重定向到https,必要会出现问题。常见的为,本地curl出现如下结果:

curl: (35) gnutls_handshake() failed: An unexpected TLS packet was received.
### 回答1: 要在Docker中使用Nginx反向代理,可以按照以下步骤进行配置: 1.首先,创建一个名为 `proxy` 的网络: ``` docker network create proxy ``` 2.创建一个Nginx容器,并将其连接到 `proxy` 网络: ``` docker run --name nginx-proxy --network proxy -p 80:80 -d nginx ``` 3.创建一个要反向代理的应用程序容器,并将其连接到 `proxy` 网络。确保应用程序容器具有一个标识符,以便Nginx可以识别它: ``` docker run --name app --network proxy -d your_app_image ``` 4.在Nginx容器中,创建一个名为 `proxy.conf` 的文件,其中包括反向代理配置。以下是一个示例配置文件: ``` server { listen 80; server_name your_domain.com; location / { proxy_pass http://app:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 该配置文件将请求 `your_domain.com` 的所有请求转发到连接到 `proxy` 网络的名为 `app` 的应用程序容器的端口3000。 5.将 `proxy.conf` 文件复制到Nginx容器中: ``` docker cp proxy.conf nginx-proxy:/etc/nginx/conf.d/ ``` 6.重新加载Nginx配置: ``` docker exec nginx-proxy nginx -s reload ``` 现在,当您访问 `your_domain.com` 时,Nginx将自动将请求转发到连接到 `proxy` 网络的名为 `app` 的应用程序容器的端口3000。 ### 回答2: 使用Docker配置Nginx反向代理非常简单。反向代理是指将客户端的请求转发到后端服务器上,实现负载均衡和高可用性。 首先,确保已经安装了DockerDocker Compose。在项目目录下创建一个名为`docker-compose.yml`的文件,内容如下: ``` version: '3' services: nginx: image: nginx ports: - "80:80" volumes: - ./nginx.conf:/etc/nginx/conf.d/default.conf restart: always ``` 在同一目录下创建一个名为`nginx.conf`的文件,这是Nginx配置文件,示例内容如下: ``` server { listen 80; server_name example.com; location / { proxy_pass http://backend-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 在上面的示例中,`example.com`是你的域名,你可以根据自己的需求进行修改。`http://backend-server`是你要代理的后端服务器的地址,可以是IP地址或者域名。 保存并关闭文件后,在项目目录下打开终端,运行以下命令启动Nginx容器: ``` docker-compose up -d ``` 这将拉取Nginx镜像并在后台运行容器。你可以通过访问`http://localhost`来验证反向代理是否正常工作。 在实际应用中,你可能需要配置更复杂的Nginx反向代理规则,例如添加SSL证书、使用多个后端服务器等。你可以根据实际需求修改`nginx.conf`文件并重新启动Nginx容器来实现这些功能。 总的来说,使用Docker配置Nginx反向代理非常方便。只需编写一个简单的Docker Compose文件和Nginx配置文件,就可以快速搭建一个强大的反向代理服务器。 ### 回答3: Docker是一款开源的容器化平台,Nginx是一款高性能的HTTP服务器和反向代理服务器。在使用Docker部署应用时,可以使用Nginx作为反向代理来实现负载均衡、缓存和SSL终止等功能。 配置Docker中的Nginx反向代理有以下几个步骤: 1. 创建Nginx配置文件:在Docker中创建一个用于存放Nginx配置文件的目录,如`/etc/nginx`。 2. 编写Nginx配置文件:在上述目录中创建一个名为`nginx.conf`的文件,并编辑该文件,设置反向代理的规则。例如,可使用`proxy_pass`指令指定服务器的地址和端口号。 3. 创建Docker镜像:使用Dockerfile来创建一个Nginx镜像。其中,可以通过`COPY`指令将上述Nginx配置文件拷贝到镜像内的`/etc/nginx`目录中。 4. 构建和运行容器:使用Docker命令构建Nginx镜像,并运行容器。运行容器时,可以使用`-p`选项来映射容器内Nginx实例的端口到宿主机上。 通过上述步骤,即可完成DockerNginx配置反向代理。此时,当有请求到达Nginx时,Nginx会根据配置反向代理规则将请求转发到指定的服务器。这样可以实现负载均衡和高可用,提高应用的性能和可靠性。 总之,使用DockerNginx进行配置反向代理可以快速、灵活地部署应用,并有效地提升应用的性能和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kiloveyousmile

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值