大佬整理的Shell个人感觉用着有问题,改进了一下。
客户端用的key保存到~/.docker/tls-client-certs.tar.gz
希望大家用的开心
#!/bin/bash # # Created by L.STONE# Mod By Ryan.L # ------------------------------------------------------------- # 自动创建 Docker TLS 证书 # ------------------------------------------------------------- # 以下是配置信息 # Config start IP="8.8.8.8" PASSWORD="123456" COUNTRY="CN" STATE="Beijing" CITY="" ORGANIZATION="iPlayLoli" ORGANIZATIONAL_UNIT="Dev" COMMON_NAME="$IP" EMAIL="github-benzBrake@woai.ru" # Config end # 工作目录 mkdir -p /etc/docker ~/.docker cd ~/.docker # 停止 docker service docker stop # 生成 CA 密钥 if [[ ! -f ca-key.pem ]]; then echo " - 生成 CA 密钥" openssl genrsa -aes256 -passout "pass:$PASSWORD" -out "ca-key.pem" 4096 fi # 生成 CA if [[ ! -f ca.pem ]]; then echo " - 生成 CA" openssl req -new -x509 -days 365 -key "ca-key.pem" -sha256 -out "ca.pem" -passin "pass:$PASSWORD" -subj "/C=$COUNTRY/ST=$STATE/L=$CITY/O=$ORGANIZATION/OU=$ORGANIZATIONAL_UNIT/CN=$COMMON_NAME/emailAddress=$EMAIL" fi # 生成服务器密钥 & 服务器证书 if [[ ! -f server-key.pem ]]; then echo " - 生成服务器密钥" openssl genrsa -out "server-key.pem" 4096 fi if [[ ! -f server.csr ]]; then openssl req -subj "/CN=$COMMON_NAME" -sha256 -new -key "server-key.pem" -out server.csr fi if [[ ! -f server-cert.pem ]]; then echo " - 生成服务器证书" echo "subjectAltName = IP:$IP,IP:127.0.0.1" >> extfile.cnf echo "extendedKeyUsage = serverAuth" >> extfile.cnf openssl x509 -req -days 365 -sha256 -in server.csr -passin "pass:$PASSWORD" -CA "ca.pem" -CAkey "ca-key.pem" -CAcreateserial -out "server-cert.pem" -extfile extfile.cnf fi rm -f extfile.cnf # 生成客户端证书 if [[ ! -f key.pem ]]; then openssl genrsa -out "key.pem" 4096 fi if [[ ! -f cert.pem ]]; then openssl req -subj "/CN=client" -new -key "key.pem" -out client.csr echo extendedKeyUsage = clientAuth >> extfile.cnf openssl x509 -req -days 365 -sha256 -in client.csr -passin "pass:$PASSWORD" -CA "ca.pem" -CAkey "ca-key.pem" -CAcreateserial -out "cert.pem" -extfile extfile.cnf fi chmod -v 0400 "ca-key.pem" "key.pem" "server-key.pem" chmod -v 0444 "ca.pem" "server-cert.pem" "cert.pem" # 打包客户端证书 echo " - 打包客户端证书为 tls-client-certs.tar.gz" mkdir -p "tls-client-certs" cp -f "ca.pem" "cert.pem" "key.pem" "tls-client-certs/" cd "tls-client-certs" tar zcf "tls-client-certs.tar.gz" * mv "tls-client-certs.tar.gz" ../ cd .. rm -rf "tls-client-certs" # 拷贝服务端证书 mkdir -p /etc/docker/certs.d cp -f "ca.pem" "server-cert.pem" "server-key.pem" /etc/docker/certs.d/ echo " - 修改 /etc/docker/daemon.json 文件" if [[ -f /etc/docker/daemon.json ]]; then grep "/etc/docker/certs.d/server-key.pem" /etc/docker/daemon.json > /dev/null if [[ ! $? -eq 0 ]]; then cat >/etc/docker/daemon.json< /etc/docker/daemon.json< /etc/systemd/system/docker.service.d/override.conf<
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/27735.html
摘要:上一篇文章搭建了一个具有基础功能的私有仓库,这次来搭建一个拥有权限认证的私有仓库。移动证书到目录。身份验证为用户创建一个带有一个条目的密码文件,密码为创建仓库启动注册表,指示它使用证书。注册表在端口默认的端口上运行。 上一篇文章搭建了一个具有基础功能的私有仓库,这次来搭建一个拥有权限认证、TLS 的私有仓库。 环境准备 系统:Ubuntu 17.04 x64 IP:198.13.48...
摘要:如果存在文件请优先修改此文件,具体原因请百度配置重启到此为止,我们就已经成功的完成了的配置。 本文首发地址:https://liluyang.me 本文将以本站 http://liluyang.me 升级到 https://liluyang.me 的过程来分享一下 https 的原理,http 和 https 的区别,以及如何将网站从 http 升级到 https。 引言 为什么要用...
阅读 1356·2021-09-22 15:09
阅读 2677·2021-08-20 09:38
阅读 2418·2021-08-03 14:03
阅读 877·2019-08-30 15:55
阅读 3383·2019-08-30 12:59
阅读 3560·2019-08-26 13:48
阅读 1899·2019-08-26 11:40
阅读 680·2019-08-26 10:30