文章目录
- @[toc]
- 编写 Dockerfile
- 编写 k8s yaml 文件
- kubelet 配置静态 pod 路径
- 启动静态 pod
- docker 配置增加 registry 地址
- 验证 docker registry 仓库
文章目录
- @[toc]
- 编写 Dockerfile
- 编写 k8s yaml 文件
- kubelet 配置静态 pod 路径
- 启动静态 pod
- docker 配置增加 registry 地址
- 验证 docker registry 仓库
- docker registry 相对于 harbor 来说,安全性会更低有点,不过对于一些内网场景(不需要和公网有互通)来说,其实 docker registry 更轻量化一些
- 本文仅作学习参考,至于实际的选择,还是以各自实际需求和场景为准
编写 Dockerfile
- 为了让 docker registry 支持认证登录,需要安装 htpasswd 命令
- 为了方便后期维护 docker registry,增加镜像删除的功能
config.yml
version: 0.1
log:fields:service: registry
storage:cache:blobdescriptor: inmemoryfilesystem:rootdirectory: /var/lib/registry# 增加这里的 delete 和 enabled ## 启用 registry 镜像删除的功能delete:enabled: true
http:addr: :5000headers:X-Content-Type-Options: [nosniff]
health:storagedriver:enabled: trueinterval: 10sthreshold: 3
Dockerfile
FROM registry:2
RUN rm -f /etc/docker/registry/config.yml && \apk add apache2-utils && \apk cache clean
ADD ./config.yml /etc/docker/registry/
- 构建镜像(需要构建成什么样的镜像名字,可以自己定义)
docker build -t registry:2_auth .
编写 k8s yaml 文件
- 以静态 pod 的方式来部署,这里就直接使用
kind: Pod
,而不是其他的控制集 - 不同 k8s 版本,
apiVersion
版本可能会不一样,可以使用kubectl explain pod.apiVersion
命令查看pod
这个kind
的apiVersion
---
apiVersion: v1
kind: Pod
metadata:# pod 名称前缀name: docker-registry# 指定 namespacenamespace: kube-system
spec:# 使用主机网络模式hostNetwork: truetolerations:- key: node-role.kubernetes.io/mastereffect: NoSchedule- key: "CriticalAddonsOnly"operator: "Exists"- key: "node.alpha.kubernetes.io/notReady"operator: "Exists"initContainers:# 这里注意修改成自己 build 的镜像名称- image: registry:2_auth# docker 容器的名字name: docker-registry-initimagePullPolicy: IfNotPresent# 配置用户名和密码command:- sh- "-c"- "htpasswd -Bbn admin adminpasswd > /auth/htpasswd"volumeMounts:- mountPath: /authname: docker-registry-authcontainers:# 这里注意修改成自己 build 的镜像名称- image: registry:2_auth# docker 容器的名字name: registryimagePullPolicy: IfNotPresent# 资源限制以自己的实际需求为准resources:limits:cpu: 3000mmemory: 3000Mienv:# registry 访问的端口,静态 pod 会暴露出来对应的端口- name: REGISTRY_HTTP_ADDRvalue: ":35000"# registry 存储路径- name: REGISTRY_STORAGE_FILESYSTEM_ROOTDIRECTORYvalue: /var/lib/registry# 以 htpasswd 的方式认证- name: REGISTRY_AUTHvalue: htpasswd# 注册认证- name: REGISTRY_AUTH_HTPASSWD_REALMvalue: Registry# 认证文件路径- name: REGISTRY_AUTH_HTPASSWD_PATHvalue: /auth/htpasswdvolumeMounts:- mountPath: /var/lib/registryname: docker-registry-storage- mountPath: /authname: docker-registry-authvolumes:# 将 registry 存储路径持久化到本地,path 指定的路径可以自己修改- name: docker-registry-storagehostPath:path: /data/k8s-data/registry-datatype: Directory# 认证文件的持久化访问为 emptyDir,每次重启都会重新生成- name: docker-registry-authemptyDir: {}
kubelet 配置静态 pod 路径
- kubeadm 部署的,默认就配置了静态 pod 的存放路径,可以不进行下面的操作
- 二进制部署的,一般没有配置静态 pod 的存放路径,需要 kubelet 增加
--pod-manifest-path
指定路径(提前创建好路径),然后重启 kubelet
--pod-manifest-path=/etc/kubernetes/manifests
启动静态 pod
创建持久化路径,这里的路径要和
yaml
文件里面的volumes
下面的docker-registry-storage
指定的path
一致
mkdir -p /data/k8s-data/registry-data
将 yaml 文件放到上面 kubelet 配置的静态 pod 路径下,然后等 pod 启动(如果想快点,可以直接重启 kubelet 组件)
查看 pod 是否创建成功
kubectl get pod -n kube-system | grep registry
静态 pod 会以 yaml 文件里面的 name 加上当前节点 ip 作为 pod 的名称
docker-registry-172.72.0.95 1/1 Running 0 33s
docker 配置增加 registry 地址
vim /etc/docker/daemon.json
注意 json 语法格式
如果重启 docker 失败,日志有如下输出,表示 daemon.json 文件的格式有错误,注意最后是否需要加上逗号
unable to configure the Docker daemon with file /etc/docker/daemon.json: invalid character '"' after object key:value pair
# 增加下面的信息
"insecure-registries": ["ip:端口"]
拿我的举个例子
{"registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"],"insecure-registries": ["172.72.0.95:35000"],"exec-opts": ["native.cgroupdriver=systemd"],"data-root": "/approot/data/crt-data","log-driver": "json-file","log-opts": {"max-size": "200m","max-file": "5"},"storage-driver": "overlay2","storage-opts": ["overlay2.override_kernel_check=true"]
}
重启 docker 服务
systemctl restart docker
验证 docker registry 仓库
登录 docker registry 仓库,这里的用户名,密码以及登录的 ip 和端口都需要以自己的为准
docker login -u admin -p adminpasswd 172.72.0.95:35000
登录成功后,就会返回对应的 success 了
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-storeLogin Succeeded
修改镜像 tag,然后尝试上传镜像
docker tag registry:2_auth 172.72.0.95:35000/registry:2_auth
推送镜像到 docker registry
docker push 172.72.0.95:35000/registry:2_auth
返回类似如下的信息,说明推送成功了,可以去其他节点使用
docker login
登录(也需要 docker 配置文件加上 docker registry 的地址),然后直接docker pull <仓库地址>:<仓库端口>/registry:2_auth
The push refers to repository [172.72.0.95:35000/registry]
f586723f1e87: Pushed
b14c705d6378: Pushed
6e5160500bc7: Pushed
744dbed40ffa: Pushed
f8dc4f9c98a6: Pushed
4984fbd72df1: Pushed
bb01bd7e32b5: Pushed
2_auth: digest: sha256:3b215dad8c5b7704b0b84a3ee46971314b8db9e65fb82a62204cf8497587377a size: 1781