【Docker】安装registry本地镜像库,开启Https功能

下载镜像

docker pull registry:2

需要启动https功能,就要生成服务端的自签名的证书和私钥,以及在docker客户端安装这个经过签名的证书。 第一步:生成公私钥信息,第二步,制作证书签名申请文件, 第三步:用私钥签名申请文件(里面保护公钥申请人的公钥信息) 第四步: 把签名后的证书配置到docker端,同时在registry端配置私钥

制作公私钥

首先熟悉下相关概念:

  • x509:证书标准
  • pem和der:两种(包括公私钥、证书签名请求、证书等内容的)的格式,前者是文本形式,linux常用,后者是二进制形式,windows常用,仅仅是格式,不表明内容,如果作为后缀就像html起的效果一样。有时候用pem做公钥的后缀
  • crt和cer:常见的两种证书后缀名,前者大多数情况为pem格式,后者大多数情况为der格式
  • csr:证书签名请求文件(后缀一般都是.csr),包含了公钥、用户名等信息
  • key:常见的私钥的后缀名

1、先创建一个公私钥对

openssl genpkey -algorithm RSA -out registry_private.key -pkeyopt rsa_keygen_bits:2048

** -algorithm RSA是说明 生产公私钥的算法,rsa_keygen_bits:2048 指定rsa算法密钥的长度,长度越长越安全,但是长度长解密时需要更长时间。 也可以用 -aes256 选项表示加密保护私钥。

2、查看使用openssl pkey -in registry_private.key -text -noout 查看生成后的私钥信息

里面可以看到公钥和私钥部分信息

3、openssl rsa -in registry_private.key -pubout -out registry_public.key 生产一个公钥信息文件

生成证书签名请求 (CSR)

创建一个配置文件,内容如下:

[root@master01 pki]# cat crs.conf

[req]

distinguished_name = req_distinguished_name

req_extensions = v3_req

prompt = no

[req_distinguished_name]

C = CN

ST = CKG

L = CKG

O = ITTest

OU = IT
CN = 192.168.2.222

[v3_req]

keyUsage = critical, digitalSignature, keyEncipherment

extendedKeyUsage = serverAuth

subjectAltName = @alt_names

[alt_names]

DNS.1=master00.com

DNS.2=bqs.master00.com
IP.1 = 192.168.2.222 #这个ip就是你的镜像服务的ip,如果有域名的域名也添加上面 DNS.1= xxx.com

执行命令生成申请文件

openssl req -new -key registry_private.key -out registry.csr -config crs.conf

生成自签名证书

openssl x509 -req -in registry.csr -signkey registry_private.key -out registry.crt -days 3650 -extfile crs.conf -extensions v3_req

-days 3650 指定证书的有效天数

查看证书

openssl x509 -in registry.crt -text -noout

启动私有仓库容器

docker run -d \

--restart=always \

--name registry \

--memory 512m \

-p 443:443 \

-v /root/regimages:/var/lib/registry \

--memory-swap -1 \

-v /root/docker/pki:/etc/certs.d \ # 把刚才生成证书的目录挂载到 容器中

-e REGISTRY_HTTP_ADDR=0.0.0.0:443 \

-e REGISTRY_HTTP_SECRET=secret \

-e REGISTRY_HTTP_TLS_CERTIFICATE=/etc/certs.d/registry.crt \ #指定了https的证书

-e REGISTRY_HTTP_TLS_KEY=/etc/certs.d/registry_private.key \ #指定了https的私钥

registry:2

把证书安装到Docker客户端

1、创建目录 /etc/docker/certs.d/192.168.2.222/ [在其他主机上也是这个ip作为文件夹]

如果https的默认端口不是443,比如是:444 ,那么文件夹的名称端口也要加上: 192.168.2.222:444

*** /etc/docker/certs.d/是固定的,后面IP目录就是根据自己实际IP 或者域名创建文件夹名称就行

2、把刚才生成的证书registry.crt 复制到上面的目录,而且名称要改成 ca.crt 。

3、重新启动Docker,就可以了

测试

***还有一种方式就是把用于签名的证书,因为这里是自签名,所以也就是这个自签名正式直接加入到操作系统层面的 信任正式库里面也可以。

#追加

cat cat.crt >> /etc/pki/ca-trust/extracted/openssl/ca-bundle.trust.crt

#系统层面更新

update-ca-trust

然后k8s中下载库中的镜像

在node上docker login 登录镜像库 生成 $HOME/.docker/config.json

kubectl create secret generic harborregcred -n jtkjdev --from-file=.dockerconfigjson=$HOME/.docker/config.json --type=kubernetes.io/dockerconfigjson

spec:

imagePullSecrets:

  • name: harborregcred

containers:

查看有多少镜像

[root]# curl https://10.99.204.135:444/v2/_catalog -k

{"repositories":["arm/istio/examples-bookinfo-productpage-v1"]}

相关推荐
high20113 分钟前
【Java】-- 利用 jar 命令将配置文件添加到 jar 中
java·pycharm·jar
ihengshuai12 分钟前
使用Docker搭建npm私有仓库
前端·docker·容器·npm·devops
Xiao5xiao12217 分钟前
java后端对接飞书登陆
java·开发语言·飞书
Xiao Tong33327 分钟前
八大排序算法(Java,便于理解)
java·算法·排序算法
新知图书38 分钟前
Spring MVC简单数据绑定
java·spring·mvc
CURRY30_HJH41 分钟前
JAVA 使用apache poi实现EXCEL文件的输出;apache poi实现标题行的第一个字符为红色;EXCEL设置某几个字符为别的颜色
java·apache·excel
梵谷的忧伤1 小时前
两个栈实现队列(D)
java·开发语言·前端·算法
Reese_Cool1 小时前
【Python】Python与C的区别
java·c语言·python
DanceDonkey1 小时前
CAS机制实现多线程并发访问
java·服务器·前端
程序猿零零漆1 小时前
SpringCloud系列教程:微服务的未来(十一)服务注册、服务发现、OpenFeign快速入门
java·spring cloud·微服务·openfeign