Nginx反向代理Docker私有仓库

环境

  • 系统:CentOS7
  • IP地址:192.168.253.128
  • Nginx版本:1.12.2
  • Docke版本:18.09.0

安装

第一步:关闭防火墙和selinux

systemctl  stop firewalld 
setenforce  0

第二步:安装Docker 18.09.0

这里使用yum方式安装,rpm包下载地址为 https://download.docker.com/linux/centos/7/x86_64/stable/Packages/
我已经提前下载好了,这里就直接用了

yum install containerd.io-1.2.0-3.el7.x86_64.rpm  \
> docker-ce-18.09.0-3.el7.x86_64.rpm \
> docker-ce-cli-18.09.0-3.el7.x86_64.rpm  -y

第三步:安装Docker私有仓库

yum install -y docker-distribution

第四步:启动Docker与Docker私有仓库

systemctl  start docker
systemctl  start docker-distribution

在这里插入图片描述

先拉取几个基础镜像,等一下用来测试

docker image pull centos
docker image pull busybox

第五步:安装Nginx

Nginx在epel源中,所以先下载epel源,然后再安装nginx

yum install  epel-release -y
yum install nginx -y

第六步:修改Nginx配置文件并启动nginx

修改配置文件/etc/nginx/nginx.conf 添加下列内容

       client_max_body_size 0;

        location / {
            proxy_pass  http://192.168.253.128:5000;
            proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
            proxy_redirect off;
            proxy_buffering 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;
        }

启动Nginx

systemctl  start nginx

第七步:镜像推送到私有的仓库

先给基础镜像打标签

docker image tag  docker.io/centos  192.168.253.128:80/centos:v1

推送到代理服务器

[root@localhost ~]# docker image push 192.168.253.128:80/centos:v1
The push refers to repository [192.168.253.128:80/centos]
Get https://192.168.253.128:80/v2/: http: server gave HTTP response to HTTPS client

这时候出现报错,问题在于推送的协议是http,而本来是要求https协议的。解决方法有2个,将nginx设置ssl连接,或者设置Docker的启动参数,使得允许http协议推送
在这里插入图片描述

这里使用第二个方法,设置一下允许http方式推送
(1)修改/etc/docker/daemon.json文件(如果不存在,则创建)

[root@localhost ~]# cat /etc/docker/daemon.json
{
  "insecure-registries" : ["192.168.253.128:80"]
}

(2)重启docker

systemctl  restart docker

然后再次推送

docker image push 192.168.253.128:80/centos:v1

在这里插入图片描述
可以看到成功了

删除本地镜像
在这里插入图片描述
从私有仓库拉取

docker image pull 192.168.253.128:80/centos:v1

在这里插入图片描述

参考的官方文档:
https://docs.docker-cn.com/engine/installation/linux/docker-ce/centos/#先决条件
https://docs.docker.com/registry/insecure/#deploy-a-plain-http-registry
https://docs.docker.com/config/daemon/systemd/#httphttps-proxy (如果代理设置失败可以参考这个文档,自己测试的时候发现需要按照这个文档进行proxy相关参数的设置,但是写博客的时候好像不需要也能成功。)

要在nginx中设置反向代理docker容器,可以按照以下步骤进行操作: 1. 首先,在docker-compose.yml文件中定义nginx服务,并将其配置为反向代理到目标docker容器。例如,可以将以下内容添加到docker-compose.yml文件中: ``` version: '2.0' services: nginx: restart: always image: nginx container_name: nginx ports: - 81:80 volumes: - ./conf/nginx.conf:/etc/nginx/nginx.conf - ./wwwroot:/usr/share/nginx/wwwroot ``` 这将创建一个名为nginx的服务,并将其配置为监听主机的81端口,并将请求转发到目标docker容器。 2. 然后,将nginx的配置文件nginx.conf复制到宿主机上的指定目录。可以使用以下命令将容器中的nginx.conf文件复制到宿主机上的/home/nginx/conf/nginx.conf: ``` docker cp nginx:/etc/nginx/nginx.conf /home/nginx/conf/nginx.conf ``` 3. 接下来,根据需要,将容器中的其他配置文件或文件夹复制到宿主机上的相应目录。例如,可以使用以下命令将容器中的conf.d文件夹复制到宿主机上的/home/nginx/conf/conf.d目录: ``` docker cp nginx:/etc/nginx/conf.d /home/nginx/conf/conf.d ``` 4. 最后,使用docker run命令重新启动nginx容器,并将宿主机上的配置文件和文件夹挂载到容器中。例如,可以使用以下命令重新启动nginx容器,并将宿主机上的/home/nginx/conf/nginx.conf挂载到容器的/etc/nginx/nginx.conf: ``` docker rm -f nginx docker run -p 9002:80 --name nginx -v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /home/nginx/conf/conf.d:/etc/nginx/conf.d -v /home/nginx/log:/var/log/nginx -v /home/nginx/html:/usr/share/nginx/html -d nginx:latest ``` 这样,nginx就会作为反向代理服务器运行,并将请求转发到目标docker容器。请根据实际情况修改配置文件路径和端口号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值