通过k8s部署应用,需要从远程镜像仓库拉取镜像,默认的远程镜像为dock hub,访问这个仓库难免出现各种超时和龟速问题。那么有什么解决方案吗?
我们可以将直接用k8s运行本地镜像将容器跑起来。但是前置条件得保证所有的node节点都有这个镜像,然后指定镜像拉取策略为imagePullPolicy: Never
即可。
1)将镜像同步到所有node节点:
假设当前镜像为spring-app:20200906-130657
,将镜像tar包,然后scp到各个node节点:
docker save spring-app:20200906-130657 -o spring-app-20200906-130657.tar
scp spring-app-20200906-130657.tar 192.168.6.131:/root/Desktop/docker-image/
scp spring-app-20200906-130657.tar 192.168.6.132:/root/Desktop/docker-image/
node1执行:
docker load < spring-app-20200906-130657.tar
node2执行:
docker load < spring-app-20200906-130657.tar
2)修改你的Deployment资源得yaml文件
containers:
- name: spring-app
image: spring-app:20200906-130657
imagePullPolicy: Never
最后执行apply命令即可,当然这个方案只是下下策,每次同步它不浪费时间吗。
以本地仓库代替默认的中央仓库,每次部署时,镜像发送到本地仓库,k8s调度到具体得节点时,再本地仓库拉取镜像,就能快得多。
1)选择master节点搭建本地仓库:
docker run -d -p 5000:5000 --restart=always --name registry registry:2
2)每次打镜像时,指定为registry为 localhost:5000
,然后可以push镜像。
docker push localhost:5000/spring-app:20200906-130657
3)所有的node节点要更新daemon.json,指定insecure-registries
为本地仓库地址。注意这里的地址要填master的ip。
echo '{ "insecure-registries": ["192.168.6.128:5000"] }' > /etc/docker/daemon.json
4)部署阶段,Deployment的yaml文件要指定为:
containers:
- name: spring-app
image: 192.168.6.128:5000/spring-app:20200906-130657
每次打镜像时,镜像完整名称为localhost:5000/spring-app:20200906-130657
,但是实际部署是yaml要指定为192.168.6.128:5000/spring-app:20200906-130657
。因为k8s默认将应用部署到node节点,node节点是没有安装本地仓库的,所以要指定实际master的ip
至此本地仓库创建完毕。