1.进行加密数据运算对配置文件底下的内容进行删除
[root@localhost ~]# vim /etc/docker/daemon.json
data:image/s3,"s3://crabby-images/a82c8/a82c8ab33558f882fac3f71bd160642f4122a785" alt=""
重新启动docker程序
[root@localhost ~]# systemctl restart docker
2.建立加密目录,生成认证key和证书
[root@localhost ~]# mkdir certs
[root@localhost ~]# openssl req -newkey rsa:4096 -nodes -sha256 \
> -keyout certs/timinglee.org.key \
> -addext "subjectAltName = DNS:reg.timinglee.org" \ #指定备用名称
> -x509 -days 365 -out certs/timinglee.org.crt
data:image/s3,"s3://crabby-images/136ac/136ac2704ace22701e19fae2f13b9e520a667c91" alt=""
data:image/s3,"s3://crabby-images/9d9c7/9d9c7fb4fbd5bf09de69fa0d213254939ecbdd3a" alt=""
目录底下成功生成证书和Key
data:image/s3,"s3://crabby-images/1966f/1966f605210fbada8a6c2f53554f00bc5e99bbd6" alt=""
注意:域名解析创建存在对应的地址reg.timinglee.org
[root@localhost ~]# vim /etc/hosts
172.25.254.200 docker-node1.timinglee.org reg.timinglee.org
data:image/s3,"s3://crabby-images/aa052/aa052dcf5dcd45d11fbf8eab0787717ae5683173" alt=""
3.启动registry仓库
[root@localhost ~]# docker run -d -p 443:443 --restart=always \ #使用加密端口443
> -v /root/certs:/certs \ # -v将本机的目录(/root/certs)挂载到镜像目录(/certs)中
> -e REGISTRY_HTTP_ADDR=0.0.0.0:443 \ #指定http监控的端口
> -e REGISTRY_HTTP_TLS_CERTIFICATE=/certs/timinglee.org.crt \ #指定容器底下证书
> -e REGISTRY_HTTP_TLS_KEY=/certs/timinglee.org.key registry:latest #指定运行的镜像
data:image/s3,"s3://crabby-images/9edaf/9edaf5443e23365241c4a1eff76871ad942930e4" alt=""
检测仓库是否启动成功
data:image/s3,"s3://crabby-images/7d7ec/7d7ecef003f1324a3ee76c3779a1ade4aa065398" alt=""
4.尝试进行镜像推送 会失败
[root@localhost ~]# docker tag nginx:v3 reg.timinglee.org/nginx:v3
[root@localhost ~]# docker push reg.timinglee.org/nginx:v3
The push refers to repository [reg.timinglee.org/nignx]
Get "https://reg.timinglee.org/v2/": dial tcp: lookup reg.timinglee.org on 114.114.114.114:53: no such host
原因是docker客户端没有key和证书
5.为客户端建立证书
[root@localhost ~]# mkdir -p /etc/docker/certs.d/reg.timinglee.org -p
[root@localhost ~]# cp /root/certs/timinglee.org.crt /etc/docker/certs.d/reg.timinglee.org/ca.crt
data:image/s3,"s3://crabby-images/5b935/5b935bfb902bea120fc2c3950665b0fc729a50d2" alt=""
查看底下是否存在证书
data:image/s3,"s3://crabby-images/892cc/892cc119270b3de389bec9ca85381c44e7968a86" alt=""
[root@localhost ~]# systemctl restart docker
6.测试,再次推送nginx:v3
[root@localhost ~]# docker push reg.timinglee.org/nginx:v3
data:image/s3,"s3://crabby-images/79492/794922cd0fa5673571d600aad03d95ffb9147f7e" alt=""