containerd_buildkitd构建镜像,告别docker构建

一:containerd制作和构建镜像

1.1:下载 containerd 二进制包和 systemd service 文件

复制代码
wget https://github.com/containerd/containerd/releases/download/v1.7.13/containerd-1.7.13-linux-amd64.tar.gz
tar -xvf containerd-1.7.13-linux-amd64.tar.gz
cp bin/* /usr/bin/


创建service
[Unit]
Description=containerd container runtime
Documentation=https://containerd.io
After=network.target local-fs.target
[Service]
ExecStartPre=/usr/sbin/modprobe overlay
ExecStart=/usr/bin/containerd
Type=notify
Delegate=yes
KillMode=process
Restart=always
RestartSec=5
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNPROC=infinity
LimitCORE=infinity
LimitNOFILE=infinity
# Comment TasksMax if your systemd version does not supports it.
# Only systemd 226 and above support this version.
TasksMax=infinity
OOMScoreAdjust=-999
[Install]
WantedBy=multi-user.target

二:buildkit介绍

buildkit是从Docker从公司开源出来的下一代镜像构建工具,支持OCI标准的镜像构建,项目地址是:https://github.com/moby/buildkit

2.1:buildkit由两部分组成

复制代码
buildkitd(服务端):负责镜像构建,目前支持runc和containerd作为镜像构建环境,默认是runc
buildkitctl(客户端):负责解析Dockerfile文件,并向服务端buildkitd发出构建情趣

2.2:相对于docker daemon build,buildkit具有以下优势

复制代码
更高效: 支持并行的多阶段构建、更好的缓存管理
更安全: 支持secret mount,无需root权限
更易于扩展: 使用自定义中间语言LLB,完全兼容Dockerfile,也可以支持第三方语言。后台支持runc和containerd

2.3:buildkit安装

复制代码
wget https://github.com/moby/buildkit/releases/download/v0.10.3/buildkit-v0.10.4.linux-amd64.tar.gz
tar xf buildkit-v0.10.4.linux-amd64.tar.gz -C /usr/local/bin
mv /usr/local/bin/bin/buildctl /usr/local/bin/bin/buildkitd /usr/local/bin

2.3.1:vim /usr/lib/systemd/system/buildkit.socket

复制代码
[Unit]
Description=BuildKit
Documentation=https://github.com/moby/buildkit

[Socket]
ListenStream=%t/buildkit/buildkitd.sock

[Install]
WantedBy=sockets.target

2.3.2:vim /usr/lib/systemd/system/buildkitd.service

复制代码
[Unit]
Description=BuildKit
Requires=buildkit.socket
After=buildkit.socket
Documentation=https://github.com/moby/buildkit

[Service]
ExecStart=/usr/local/bin/buildkitd --oci-worker=false --containerd-worker=true

[Install]
WantedBy=multi-user.target

2.3.3:启动buildkitd

复制代码
systemctl daemon-reload
systemctl start builkitd
systemctl enable builkitd

三:nerdctl安装使用

3.1:nerdctl安装

复制代码
#因为nerdctl运行容器需要使用cni配置容器网络,所以先安装cni
wget https://github.com/containernetworking/plugins/releases/download/v1.1.1/cni-plugins-linux-amd64-v1.1.1.tgz
mkdir -p /opt/cni/bin
tar xvf cni-plugins-linux-amd64-v1.1.1.tgz -C /opt/cni/bin/

wget https://github.com/containerd/nerdctl/releases/download/v0.22.0/nerdctl-0.22.0-linux-amd64.tar.gz
tar xvf nerdctl-0.22.0-linux-amd64.tar.gz
cp nerdctl /usr/bin/
nerdctl version

3.2:nerdctl使用harbor仓库

复制代码
在containerd主机执行
mkdir -p /etc/containerd/certs.d/harbor.magedu.net/
在harbor仓库主机执行
openssl x509 -inform PEM -in harbor-ca.crt -out harbor-ca.cert
scp harbor-ca.cert harbor-ca.key 172.16.10.104:/etc/containerd/certs.d/harbor.magedu.net

containerd主机执行

复制代码
vim /etc/containerd/config.toml
[plugins."io.containerd.grpc.v1.cri".registry] 
  config_path = "/etc/containerd/certs.d"
  
vim /etc/containerd/certs.d/harbor.magedu.net/hosts.toml  
server = "https://harbor.magedu.net"
[host."https://harbor.magedu.net"]
  capabilities = ["pull", "resolve","push"]
  skip_verify = true

3.2.1:nerdctl拉取镜像

复制代码
[root@etcd1 harbor.magedu.net]#  nerdctl pull   harbor.magedu.net/k8s/alpine:latest
harbor.magedu.net/k8s/alpine:latest:                                              resolved       |++++++++++++++++++++++++++++++++++++++| 
manifest-sha256:acd3ca9941a85e8ed16515bfc5328e4e2f8c128caa72959a58a127b7801ee01f: done           |++++++++++++++++++++++++++++++++++++++| 
config-sha256:961769676411f082461f9ef46626dd7a2d1e2b2a38e6a44364bcbecf51e66dd4:   done           |++++++++++++++++++++++++++++++++++++++| 
elapsed: 0.1 s                                                                    total:   0.0 B (0.0 B/s)           
相关推荐
Harvy_没救了1 小时前
【网络部署】 Win11 + VMware CentOS8 + Nginx 文件共享服务 Wiki
运维·网络·nginx
春风有信1 小时前
【2026.05.01】Windows10安装Docker Desktop 4.71.0.0步骤及问题解决
运维·docker·容器
2401_873479402 小时前
断网时如何实时判断IP归属?嵌入本地离线库,保障风控不中断
运维·服务器·网络
守城小轩2 小时前
基于Chrome140的Yahoo自动化(关键词浏览)——需求分析&环境搭建(一)
运维·自动化·chrome devtools·浏览器自动化·指纹浏览器·浏览器开发
handler012 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
日取其半万世不竭4 小时前
LVM 逻辑卷管理:不停机扩容磁盘的正确方式
运维·服务器
优化Henry4 小时前
TDD-LTE站点Rilink=3链路故障处理案例---BBU侧C口“有发光、无收光”的排查与恢复
运维·网络·信息与通信·tdd
浪客灿心4 小时前
Linux网络传输层协议
linux·运维·网络
V搜xhliang02465 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
遇见火星5 小时前
Nginx限流配置:防止接口被刷,服务器稳如泰山
运维·服务器·nginx