博客
关于我
【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/

你可能感兴趣的文章
Objective-C实现2 个数字之间的算术几何平均值算法(附完整源码)
查看>>
Objective-C实现2d 表面渲染 3d 点算法(附完整源码)
查看>>
Objective-C实现2D变换算法(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现9x9乘法表算法(附完整源码)
查看>>
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>
Objective-C实现AES算法(附完整源码)
查看>>
Objective-C实现AffineCipher仿射密码算法(附完整源码)
查看>>
Objective-C实现aliquot sum等分求和算法(附完整源码)
查看>>
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>