博客
关于我
【docker】开启remote api访问,并使用TLS加密
阅读量:536 次
发布时间:2019-03-08

本文共 1726 字,大约阅读时间需要 5 分钟。

CentOS7下配置Docker TLS(SSL)访问

在Docker集群环境中,使用本地socket进行管理确实非常不便,尤其是在需要对外开放Docker服务时。默认情况下,Docker支持通过TCP协议提供服务,但这会直接向外公开Docker集群,存在较大安全风险。为了解决这一问题,我们可以通过TLS(传输层安全)协议对Docker服务进行加密通信。以下是实现这一目标的详细步骤说明。

1. TLS配置:生成CA证书和服务器证书

首先,我们需要生成CA(证书颁发机构)证书和服务器相关的私钥和证书文件。

# 生成CA私钥和证书openssl genrsa -aes256 -out ca-key.pem 4096openssl req -new -x509 -days 3650 -key ca-key.pem -sha256 -out ca.pem# 生成服务器私钥和证书openssl genrsa -out server-key.pem 4096openssl req -sha256 -new -key server-key.pem -out server.csropenssl x509 -req -days 3650 -sha256 -in server.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out server-cert.pem# 生成客户端私钥和证书openssl genrsa -out key.pem 4096openssl req -new -key key.pem -out client.csropenssl x509 -req -days 3650 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out cert.pem

2. 复制证书文件

将生成的CA证书和服务器证书文件复制到目标服务器的/root/.docker目录下。这些文件可以放在任意位置,但通常我们会将它们放在/root/.docker中,以便于后续配置使用。

# 生成证书文件并设置权限rm -v client.csr server.csrchmod -v 0400 ca-key.pem key.pem server-key.pemchmod -v 0444 ca.pem server-cert.pem cert.pem

3. 修改Docker服务配置

在CentOS7系统中,我们需要修改Docker服务的配置文件,以启用TLS验证。

# 打开Docker服务配置文件进行编辑vim /lib/systemd/system/docker.service

ExecStart部分,添加TLS验证相关参数:

# 修改后的配置内容ExecStart=/usr/bin/dockerd -H unix:///var/run/docker.sock -D -H tcp://0.0.0.0:2375 --tlsverify --tlscacert=/root/.docker/ca.pem --tlscert=/root/.docker/server-cert.pem --tlskey=/root/.docker/server-key.pem

4. 重新加载Docker配置并重启服务

完成配置后,我们需要重新加载systemd服务配置,并重启Docker进程。

# 重新加载配置文件systemctl daemon-reload# 重启Docker服务service docker restart

5. 测试Docker TLS配置

最后,我们需要验证TLS配置是否正确。

在测试机上,将cert.pemkey.pem文件复制到该机上,并执行以下命令:

# 使用`-k`选项可以跳过SSL证书验证curl -k https://
:2375/info --cert ./cert.pem --key ./key.pem

如果返回Docker信息,说明TLS配置已成功完成。

转载地址:http://zufiz.baihongyu.com/

你可能感兴趣的文章
NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
查看>>
NVelocity标签使用详解
查看>>
NVelocity标签设置缓存的解决方案
查看>>
Nvidia Cudatoolkit 与 Conda Cudatoolkit
查看>>
NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
查看>>
NVIDIA-cuda-cudnn下载地址
查看>>
nvidia-htop 使用教程
查看>>
nvidia-smi 参数详解
查看>>
Nvidia驱动失效,采用官方的方法重装更快
查看>>
nvmw安装node-v4.0.0之后版本的临时解决办法
查看>>
nvm切换node版本
查看>>
nvm安装 出现 Error retrieving “http://xxxx/SHASUMS256.txt“: HTTP Status 404 解决方法
查看>>
nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
查看>>
ny540 奇怪的排序 简单题
查看>>
NYOJ 1066 CO-PRIME(数论)
查看>>
NYOJ 737:石子合并(一)(区间dp)
查看>>
nyoj 91 阶乘之和(贪心)
查看>>
nyoj------203三国志
查看>>
NYOJ-525 一道水题
查看>>
nyoj58 最少步数
查看>>