发布 Docker 守护进程通常涉及到创建所需的证书,重新配置 Docker 守护进程并重新启动它。但是,您通常没有更改守护进程配置或重启守护进程所需要的权限。接下来,我将演示如何使用容器化反向代理来实现它。
免责声明
在将 Docker 守护进程公开给 TCP 端口上的网络时,都需要我们配置证书身份验证。 如果不这样做,那就等于为所有人提供了 root 权限。
先决条件
请按照官方文档创建保护 Docker 守护进程所需的证书。与官方文档相反,不要将 Docker 守护进程配置为使用新创建的证书。我将在下一节“用法”中介绍为什么要这么做。
用 法
反向代理是基于“nginx:stable-alpine”,并且使用 TLS 来监听“2376/tcp”。所有请求都转发到本地 Docker 守护进程的“/var/run/docker.sock”中,它必须映射到容器中,如下所示:
docker run -d --env CA_CRT=$(cat ca.pem) --env SERVER_KEY=$(cat server_key.pem) --env SERVER_CRT=$(cat server_cert.pem) --volume /var/run/docker.sock:/var/run/docker.sock --net=host nicholasdille/docker-auth-proxy
您也可以在默认网络中启动容器并公开端口:
docker run -d --env CA_CRT=$(cat ca.pem) --env SERVER_KEY=$(cat server_key.pem) --env SERVER_CRT=$(cat server_cert.pem) --volume /var/run/docker.sock:/var/run/docker.sock -p 2376:2376 nicholasdille/docker-auth-proxy
可以根据需要启动和停止 Docker 守护进程的发布,这并不会影响到正在运行的容器。
下 载
浏览 https://hub.docker.com/r/nicholasdille/docker-auth-proxy/ 即可下载该反向代理镜像。
原文链接:https://blog.csdn.net/weixin_39706441/article/details/110425573
© 版权声明
声明📢本站内容均来自互联网,归原创作者所有,如有侵权必删除。
本站文章皆由CC-4.0协议发布,如无来源则为原创,转载请注明出处。
THE END