microk8s使用本地私服registry的镜像http协议

开发环境为了能部署服务到microk8s,我们开启了一个本地私库,地址为:http://localhost:5000,那么如何在microk8s中能拉取本地私库中的镜像呢?

直接部署的话,microk8s会用https协议去拉取镜像,所以必须要配置一下才行。

microk8s是每个registry一个配置文件的,你需要先创建一个配置文件,执行如下命令:

复制代码
sudo mkdir -p /var/snap/microk8s/current/args/certs.d/ibm-johnny-z13:5000

这里的ibm-johnny-z13是你主机名,你还得到/etc/hosts中修改一下,不能让主机名的IP为127.0.0.1,否则microk8s的节点解析到的就是127.0.0.1,那么,那么它就会访问节点机器,所有就访问不到,同理localhost也不行。例如我的:

复制代码
cat /etc/hosts

# generateHosts = false
127.0.0.1       localhost
172.22.164.46 ibm-johnny-z13
# 127.0.1.1     IBM-JOHNNY-Z13. IBM-JOHNNY-Z13
185.199.110.133 raw.githubusercontent.com

由于我是WSL的ubuntu所以IP是172开头的。

复制一个配置文件:

复制代码
 cp /var/snap/microk8s/current/args/certs.d/localhost\:32000/hosts.toml /var/snap/microk8s/current/args/certs.d/ibm-johnny-z13\:5000/

然后修改配置文件内容:

复制代码
sudo  vi /var/snap/microk8s/current/args/certs.d/ibm-johnny-z13\:5000/hosts.toml

内容如下:

复制代码
server = "http://ibm-johnny-z13:5000"

[host."http://ibm-johnny-z13:5000"]
  capabilities = ["pull", "resolve"]

然后再重启microk8s:

复制代码
	microk8s stop && microk8s start

这样就可以使用内部私有库了。

相关推荐
DeepFlow 零侵扰全栈可观测7 小时前
DeepFlow 全栈可观测性 护航某银行核心系统全生命周期
数据库·人工智能·分布式·云原生·金融
BD_Marathon8 小时前
【Zookeeper】CAP理论——BASE定理及ZK追求的一致性
分布式·zookeeper·云原生
h***34638 小时前
docker desktop安装redis
redis·docker·容器
i***48618 小时前
对Docker部署的MySQL中的数据进行备份恢复
mysql·docker·容器
Mr.Ja9 小时前
【Docker 从入门到实战】——解决跨环境部署痛点的完整指南
运维·docker·容器·dockerfile·dockerimage
shida_csdn9 小时前
k0smotron 一键创建 K8s Control Plane(K8s in K8s 模式)
云原生·容器·k0s·kosmotron
张人大 Renda Zhang9 小时前
Maven = Java 构建世界的“事实标准”:从 pom.xml 到云原生 CI/CD
xml·java·spring boot·后端·ci/cd·云原生·maven
小毅&Nora9 小时前
【云计算】【Kubernetes】 ② K8S的架构、应用及源码解析 - Pod 生命周期管理与 CRI 集成详解
架构·kubernetes·云计算
人工智能训练9 小时前
跨架构突围!X86 Ubuntu Dify 无缝迁移 Arm64 openEuler Docker 实战指南
人工智能·ubuntu·docker·容器·架构·arm64·dify
瑞思蕊萌9 小时前
Docker讲解(未完结)
运维·docker·容器