美文网首页Docker容器技术我是程序员Docker容器
利用Packer自定义镜像创建容器集群

利用Packer自定义镜像创建容器集群

作者: 阿里云云栖号 | 来源:发表于2019-05-16 11:26 被阅读74次

阿里云容器服务Kubernetes集群支持CentOS操作系统,在绝大多数情况下可以满足客户的要求。但是有些客户由于业务系统对操作系统依赖比较高,希望定制化一些操作系统参数,则可以用自定义镜像来创建Kubernetes集群。

创建自定义操作系统镜像有两种方式,一是在控制台上通过为一台ECS创建快照的方式创建镜像,注意一定要基于阿里云CentOS作为基础镜像,把对操作系统的定制化更新完打成镜像即可。但这种方式的不便之处在于,如果每次对操作系统镜像有更新,则都要手动操作一遍,很难自动化。而且如果是从已有的Kubernetes节点制作镜像,还需要把Docker,Kubelet等清理干净才能制作镜像,步骤繁琐且容易遗漏。

另外一种方式就是本文介绍的用Packer构建镜像。相关的参考文档:使用Packer创建自定义镜像。采用Packer构建镜像的好处是可以把构建方式自动化,构建所需的参数文件中包含了对干净的基础镜像所做的修改,一目了然,并且可以把配置进行版本化管理。后期需要构建新的镜像,只需改变配置重新执行一下Packer构建即可,非常方便,是在生产环境中使用自定义镜像的推荐方式。

那么有没有一个针对容器服务集群的Packer配置模版呢?容器服务团队开源的ack-image-builder就是一个这样的示例项目。下面我们就来一起动手实践一下。

安装Packer

可以根据官方文档安装Packer https://www.packer.io/intro/getting-started/install.html

创建自定义镜像

克隆ack-image-builder项目到本地,可以看到config和scripts目录下是一些示例定制化脚本,读者可以根据自己的需求更新改。

$ git clone https://github.com/AliyunContainerService/ack-image-builder.git
$ cd ack-image-builder
ack-image-builder $ tree
.
├── LICENSE.txt
├── README.md
├── ack-centos.json
├── config
│   └── default.sh
└── scripts
    ├── cleanUpKerneles.sh
    ├── reboot.sh
    ├── updateKernel.sh
    └── verify.sh

2 directories, 8 files

ack-centos.json 可以配置在把生成好的自定义镜像存在哪个区(示例中为cn-hangzhou)。

{
  "variables": {
    "region": "cn-hangzhou",
    "image_name": "ack_test_image{{timestamp}}",
    "source_image": "centos_7_06_64_20G_alibase_20190218.vhd",
    ...
  },

配置好阿里云账号的AK,然后执行构建命令。

export ALICLOUD_ACCESS_KEY=XXX
export ALICLOUD_SECRET_KEY=XXX
packer build ack-centos.json

大约7-8分钟一个新的自定义镜像就构建成功了。可以进入ECS控制台查看新生成的镜像。

利用自定义镜像创建容器集群

开通自定义镜像白名单

读者如果需要尝试自定义镜像能力,需要先开工单,申请在容器服务控制台上开通自定义镜像的白名单。

创建容器集群

白名单开通后进入容器服务控制台 https://cs.console.aliyun.com/#/k8s/cluster/list,创建Kubernetes集群。选择自定义镜像所在的区,在示例中是cn-hangzhou。

在创建集群的页面中点击"显示高级选项",会出现"自定义镜像"的选择界面:

如果在选择中找不到刚创建的镜像,请检查一下集群和自定义镜像是否在同一个Region。

选择了自定义镜像后点击创建集群即可完成一个自定义镜像集群的创建。

集群扩容与自动伸缩

使用自定义镜像创建集群后,集群的扩容与自动伸缩中所用的都是自定义镜像。

Terraform 中自定义镜像支持

利用Terraform创建容器集群也可以使用自定义镜像,具体参数是:

image_id - The ID of node image.

相关链接如下:

专有集群:https://www.terraform.io/docs/providers/alicloud/r/cs_kubernetes.html

托管集群:https://www.terraform.io/docs/providers/alicloud/r/cs_managed_kubernetes.html

讨论

自定义镜像创建集群为很多有对操作系统有定制化要求的客户带来了很大的便利性,在使用自定义镜像的过程中几个比较好的做法是:根据阿里云的提供的最新的CentOS镜像来定制化,利用自定义创建集群后要充分测试,防止对操作系统的更改引发冲突。在实践中也建议基于Packer示例项目来构建镜像。



本文作者:libinjingshan

阅读原文

本文为云栖社区原创内容,未经允许不得转载。

相关文章

  • 利用Packer自定义镜像创建容器集群

    阿里云容器服务Kubernetes集群支持CentOS操作系统,在绝大多数情况下可以满足客户的要求。但是有些客户由...

  • Docker 部署Hadoop集群

    一、网络设置以及集群部署规划 二、Docker容器 拉取镜像 创建容器按照集群的架构,创建容器时需要设置固定IP,...

  • Docker 常用操作指令

    镜像操作 列出docker下的所有镜像 搜索镜像 拉取镜像 删除镜像 容器操作 查看容器 创建与启动容器 创建容器...

  • docker搭建Redis集群(主从集群)

    最终会创建以下6个容器构成集群 啥也不多说,这篇直接上步骤... 1、拉取镜像 2、创建6个容器 部分参数解释:-...

  • docker初识

    镜像命令:拉取镜像查看镜像容器命令:创建容器启动容器/停止容器容器删除拷贝容器目录挂载查看IP 》拉取镜像,创建容...

  • docker入门(3)--创建和管理镜像

    有三种创建自定义镜像的方式 一、交互式创建 选取基础镜像,运行容器,并进入交互窗口docker container...

  • docker学习笔记

    docker镜像:只读的模板,创建docker容器的基础 docker容器:一个轻量级沙箱,docker利用容器来...

  • docker 安装 nacos 安装mysql

    创建自定义网络(用于容器通讯) 查看网络 安装mysql创建挂载文件夹 拉取镜像并启动 拉镜像,版本查看:http...

  • Packer-通过ISO自动创建qemu镜像

    介绍: Packer是一个创建自定义镜像的开源工具,可以免去通过ISO安装系统时的手动操作,完成自动化安装系统的过...

  • Docker镜像和容器

    搜索镜像 获取镜像 查看镜像 删除镜像 启动容器 查看容器 启动交互式容器--name mydocker1 自定义...

网友评论

    本文标题:利用Packer自定义镜像创建容器集群

    本文链接:https://www.haomeiwen.com/subject/htwbaqtx.html