为kubernetes创建本地镜像仓库

通过k8s部署应用,需要从远程镜像仓库拉取镜像,默认的远程镜像为dock hub,访问这个仓库难免出现各种超时和龟速问题。那么有什么解决方案吗?

k8s直接运行本地镜像

我们可以将直接用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

至此本地仓库创建完毕。

你可能感兴趣的:(Kubernetes,kubernetes,k8s,docker,运维)