云生态下的镜像管理利器Packer

简介: ## About Packer Packer (https://www.packer.io/)是Hashicorp 组织旗下的一款DevOps运维工具,可以看下整个软件交付周期所处的位置: ![image.

About Packer

Packer (https://www.packer.io/)是Hashicorp 组织旗下的一款DevOps运维工具,可以看下整个软件交付周期所处的位置:
image.png

Packer是一款面向云生态非常便利的镜像管理利器,通过一个模板配置可以快速的创建镜像。
当前支持阿里云、AWS、Azure、Vmware、Google Cloud Platform、DigitalOcean 等多个云厂商平台。通过Packer,可以在创建镜像过程中,执行相应的脚本文件,或者安装目标软件,执行配置系统等操作,可提升系统应用交付效能。

Install Packer

Packer可以安装在多个系统平台上
image.png
通过https://www.packer.io/downloads.html 可以下载相应的可执行二进制包,配置好相应的PATH则可使用Packer Command,如下:
image.png

Build an Image on alicould

只需要通过创建一个Packer的模板配置文件(json格式),指定好镜像所在的region,类型,实例规格,IO类型,则可完成一个系统镜像的创建,下面看一下基于Alicloud的一个模板配置:

{
  "variables": {
    "access_key": "${your_access_key}",
    "secret_key": "${your_secret_key}"
  },
  "builders": [{
    "type":"alicloud-ecs",
    "access_key":"${your_access_key}",
    "secret_key":"${your_secret_key}",
    "region":"cn-beijing",
    "image_name":"packer_test_image",
    "source_image":"centos_7_03_64_20G_alibase_20170818.vhd",
    "ssh_username":"root",
    "instance_type":"ecs.n4.small",
    "internet_charge_type":"PayByTraffic",
    "io_optimized":"true"
  }]
}

其中镜像类型对应的多平台说明文档可参考:
https://www.packer.io/docs/builders/index.html

Provision

Packer 可以支持Provision实现在创建镜像过程中,执行相应的脚本文件,或者安装目标软件,执行配置系统等,比如下可以预先安装redis:
image.png

注意事项:上面配置的sleep 30非常关键,因为在创建镜像的过程中,是构建了完整的VM实例,这中间需要通过SSH上去执行指令的过程中,可能系统尚未完成整改初始化过程,所以需要做一个30秒的时间等待。

Parallel Builds

Packer 同时支持多平台创建一个镜像,如下在AWS、DigitalOcean 创建镜像,只不过这里需要制定好各自平台的AK、API-Token:
image.png

Execute build image

当我们创建好一个镜像的时候,比如这里通过创建一个基于阿里云的镜像模板:

{
  "variables": {
    "access_key": "{your_access_key}",
    "secret_key": "${your_secret_key}"
  },
  "builders": [{
    "type":"alicloud-ecs",
    "access_key":"{your_access_key}",
    "secret_key":"${your_secret_key}",
    "region":"cn-beijing",
    "image_name":"packer_test_image",
    "source_image":"centos_7_03_64_20G_alibase_20170818.vhd",
    "ssh_username":"root",
    "instance_type":"ecs.n4.small",
    "internet_charge_type":"PayByTraffic",
    "io_optimized":"true"
  }],
  "provisioners": [{
    "type": "shell",
    "inline": [
      "sleep 30",
      "echo 'hello world' > /tmp/a.txt"
    ]
  }]
}

我们需要验证写的模板语法上是否有错误,则通过validate进行判断:

$ packer validate alicloud.json 

当如上vadidate验证json语法等问题okay后,则通过packer build 直接构建镜像:

$ packer build alicloud.json

如果为build的过程的STDOUT:
image.png

如上可以看到该过程完成了资源的创建和释放的过程,执行后到阿里云管控控制台查看ECS自定义镜像:
image.png

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
存储 缓存 弹性计算
阿里巴巴开源 容器镜像加速技术DADI 上手指南
阿里资深技术专家在阿里云开发者社区特别栏目《周二开源日》直播中,介绍刚于3月份开源的容器镜像加速器项目 DADI ,并带大家快速上手使用。本文为直播内容文字整理,看直播回放,请点击文首链接~
阿里巴巴开源 容器镜像加速技术DADI 上手指南
|
4月前
|
运维 Kubernetes 监控
PaaS平台
【7月更文挑战第2天】PaaS平台
241 58
|
6月前
|
机器学习/深度学习 人工智能 数据可视化
PAI平台
近年来,随着人工智能技术的飞速发展,越来越多的企业开始关注如何将AI技术应用到业务场景中,以提高效率、降低成本。然而,对于大多数企业来说,AI技术的应用仍然面临着许多挑战,例如高昂的计算资源需求、复杂的模型训练和部署流程等。
161 2
|
存储 消息中间件 资源调度
什么是PaaS平台
PaaS平台通常是基于IaaS平台构建的,PaaS平台和IaaS平台最大的差别是需求即服务。所有的管理都是以服务为粒度的,在IaaS以资源管理为中心的平台上提供了更高层次的抽象。
2289 1
|
Kubernetes 监控 Java
K8s企业级管理神器:Rancher 你值得拥有!
K8s企业级管理神器:Rancher 你值得拥有!
|
XML JavaScript Cloud Native
云原生之使用Docker部署kkFileView在线文档管理平台
云原生之使用Docker部署kkFileView在线文档管理平台
2122 0
云原生之使用Docker部署kkFileView在线文档管理平台
|
Kubernetes 网络安全 Docker
Rancher | 开源的企业级PaaS平台
Rancher | 开源的企业级PaaS平台
358 0
|
弹性计算 负载均衡 网络协议
开源PaaS工具CloudFoundry落地阿里云
云计算技术的不断成熟和完善,尤其是IaaS平台的不断发展,使得越来越多的企业和用户青睐于将自己的业务和应用不断的从传统IT设施迁移到云上,在灵活、高效管理应用,快速扩展业务的同时不断地降低基础设施的运维和管理成本。
14142 0
开源PaaS工具CloudFoundry落地阿里云
|
存储 Devops Linux
群晖+DOCKER,一个更好的DEVOPS+WEBOS云平台及综合云OS选型
本文关键字:dualrunning os bootloader设想,dockerized os subsystem appmodel,云devops学编程
823 0
群晖+DOCKER,一个更好的DEVOPS+WEBOS云平台及综合云OS选型
|
容器 Cloud Native Kubernetes
正式开放 | 阿里云 10 亿级镜像服务正式支持 Helm Charts,云原生交付再加速!
阿里云容器镜像服务(ACR)是国内最大的公有云镜像服务平台之一,支撑数万名开发者,十亿级别的镜像拉取,为开发者的每个应用镜像保驾护航。未来我们将持续改进、优化 Helm Chart 托管能力,提供自定义接入域名,服务端 BYOK 存储加密等企业级功能。
正式开放 | 阿里云 10 亿级镜像服务正式支持 Helm Charts,云原生交付再加速!
下一篇
无影云桌面