aws eks 使用packer构建自定义ami

2023-11-02 10:31

本文主要是介绍aws eks 使用packer构建自定义ami,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

资料

  • 如何创建用于 Amazon EKS 的自定义 Amazon Linux AMI?

  • 构建预置容器镜像的EKS自定义AMI解决方案

  • https://github.com/awslabs/amazon-eks-ami

  • https://github.com/awslabs/amazon-eks-ami/blob/master/doc/USER_GUIDE.md

  • https://developer.hashicorp.com/packer/tutorials

使用aws eks需要依赖与aws的其他服务对基础设施进行配置和维护,例如节点组需要创建autoscaling group对节点的生命周期进行管理。我们能够通过以下方式对节点进行一定的配置

  • 启动启动模板支持
  • 通过bootstrap启动脚本指定kubelet参数

以上方式虽然能够提供一定的灵活性,但是对于需要在节点预装程序以及预加载image等需求,就需要通过在启动模板中指定自定义ami来实现。本文参考官方blog使用packer进行eks的自定义ami的构建

Packer 在工作时需要利用 AWS CloudFormation 堆栈。该堆栈运行一个 m4.large 或 a1.large Amazon Elastic Compute Cloud (Amazon EC2) 实例(具体取决于目标 AMI 架构)。该实例由 Packer 预置。在使用程序包和二进制文件对实例进行预置后,Packer 会从正在运行的实例中创建 AMI。

img

aws-labs之eks-ami

安装和配置packer

sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/AmazonLinux/hashicorp.repo
sudo yum -y install packer
packer --version

clone官方仓库

git clone https://github.com/awslabs/amazon-eks-ami

在根目录可以看到Makefile文件,该makefile文件提供了对packer命令的封装,查看帮助如下

A Makefile is provided to build the Amazon EKS Worker AMI, but it is just a small wrapper around invoking Packer directly

$ make help
Usage:make <target>all              Build all versions of EKS Optimized AL2 AMIfmt              Format the source fileslint             Check the source files for syntax and format issuestest             run the test-harnessvalidate         Validate packer configk8s              Build default K8s version of EKS Optimized AL2 AMI1.20             Build EKS Optimized AL2 AMI - K8s 1.201.21             Build EKS Optimized AL2 AMI - K8s 1.211.22             Build EKS Optimized AL2 AMI - K8s 1.221.23             Build EKS Optimized AL2 AMI - K8s 1.231.24             Build EKS Optimized AL2 AMI - K8s 1.24help             Display help

每个入口对应一个配置项,可以按需构建所需版本。能够自定义的配置很明确

  1. AMI template variables
  2. Building against other versions of Kubernetes binaries
  3. Providing your own Kubernetes binaries
  4. Container image caching
  5. IAM permissions
  6. Customizing kubelet config
  7. AL2 and Linux kernel information
  8. Updating known instance types

总结如下

  • 有两个配置文件比较重要,eks-worker-al2-variables.json是构建的默认变量,eks-worker-al2.json是packer涉及到的全部变量(可以修改并覆盖)

  • 默认使用AL2作为源ami,在构建中提供自定义ami,需要修改配置文件eks-worker-al2.json

在 Packer 配置文件 eks-worker-al2.json 中设置变量 source_ami_idsource_ami_ownersaws_region

  • 可以在构建过程中提供自定义的二进制文件,可以看到有5个组件是必须的

默认情况下,会从 us-west-2 中的 Amazon EKS 公有 Amazon Simple Storage Service(Amazon S3)存储桶 amazon-eks 下载二进制文件

$ aws s3 ls s3://amazon-eks/1.24.7/2022-10-31/bin/linux/amd64/ | grep -v "\."
2022-11-09 21:21:23   47403008 aws-iam-authenticator
2022-11-09 21:21:57   15351808 ecr-credential-provider
2022-11-09 21:22:05   41828352 kube-proxy
2022-11-09 21:22:20   45735936 kubectl
2022-11-09 21:22:38  119789048 kubelet
  • 在构建过程中可以指定二进制文件的版本,官方的s3桶已经按照版本和构建日期提供了许多文件

  • 由于节点启动过程中需要拉取image完成配置到达ready状态,可以将这些image打包到ami中加速节点启动。以下命令开启image缓存功能

cache_container_images=true make 1.23
  • 使用eks优化的ami支持在bootstrap脚本中加入--kubelet-extra-args参数对kubelet进行修改。和kubelet相关的任何额外参数,在节点启动的过程中都能够在journalctl -u kubelet中找到

    有一个比较快捷的方式(开启apiserver代理访问)能够获取特定节点的kubelet配置文件

    $ kubectl proxy
    $ curl -sSL "http://localhost:8001/api/v1/nodes/ip-192-168-92-220.us-east-2.compute.internal/proxy/configz" | jq
    
  • 默认在构建过程中,使用source_ami_filter对ami进行筛选,选择的是最新的AL2作为底包。构建ami的好处在于能够选择内核版本,例如想要使用cilium全部功能内核可能要很新才行

    When building an AMI, you can set the kernel_version to 4.14 or 5.4 to customize the kernel version. The upgrade_kernel.sh script contains the logic for updating and upgrading the kernel. For Kubernetes versions 1.18 and below, it uses the 4.14 kernel if not set, and it will install the latest patches. For Kubernetes version 1.19 and above, it uses the 5.4 kernel if not set.

  • 此外,一些实例类型在启动时会出现问题,原因是bootstrap.sh通过查找eni-max-pods.txt文件中实例类型对应的最大pod数量,如果没有查到会报错。因此需要将此实例类型的pod数量更新到文件中。这个在节点启动逻辑那篇blog中也有提及。

packer和aws

镜像即代码:使用 Packer 实现自动化构建镜像

packer是Hashicorp 开发的镜像构建工具,能够提供跨平台的系统镜像构建能力。

img

packer为aws的镜像构建提供了完善的支持,并提供了相当多的插件进行定制,官方示例如下:

创建.pkr.hcl文件,使用插件扩展pakcer打包器的功能(amazon插件)

$ mkdir packer_tutorial
$ cat aws-ubuntu.pkr.hcl
packer {required_plugins {amazon = {version = ">= 0.0.2"source  = "github.com/hashicorp/amazon"}}
}source "amazon-ebs" "ubuntu" {ami_name      = "learn-packer-linux-aws"instance_type = "t2.micro"region        = "cn-north-1"source_ami_filter {filters = {name                = "ubuntu/images/*ubuntu-xenial-16.04-amd64-server-*"root-device-type    = "ebs"virtualization-type = "hvm"}most_recent = trueowners      = ["099720109477"]}ssh_username = "ubuntu"
}build {name    = "learn-packer"sources = ["source.amazon-ebs.ubuntu"]
}

使用pakcer构建aws镜像需要首先配置aws凭证,可以使用aksk获取权限

可以将模板中的变量通过variable的方式进行配置

初始化packer,会下载相关插件

packer init .

构建镜像,pakcer会使用cloudformation启动相关资源使用上述配置执行构建操作,

packer build aws-ubuntu.pkr.hcl

构建eks-ami

通过修改构建脚本,可以在ami构建中指定需要运行的shell命令

cd amazon-eks-ami && vim scripts/install-worker.sh

scripts文件夹中的脚本在eks-worker-al2.json配置中的Provisioners部分配置,在packer中provisioners代表实例启动后需要对ami进行的配置,通常包括:安装包,打补丁,用户管理,下载code等,例如以下install-worker.sh脚本

{"type": "shell","remote_folder": "{{ user `remote_folder`}}","script": "{{template_dir}}/scripts/install-worker.sh","environment_vars": ["KUBERNETES_VERSION={{user `kubernetes_version`}}","KUBERNETES_BUILD_DATE={{user `kubernetes_build_date`}}","BINARY_BUCKET_NAME={{user `binary_bucket_name`}}","BINARY_BUCKET_REGION={{user `binary_bucket_region`}}","DOCKER_VERSION={{user `docker_version`}}","CONTAINERD_VERSION={{user `containerd_version`}}","RUNC_VERSION={{user `runc_version`}}","CNI_PLUGIN_VERSION={{user `cni_plugin_version`}}","PULL_CNI_FROM_GITHUB={{user `pull_cni_from_github`}}","AWS_ACCESS_KEY_ID={{user `aws_access_key_id`}}","AWS_SECRET_ACCESS_KEY={{user `aws_secret_access_key`}}","AWS_SESSION_TOKEN={{user `aws_session_token`}}","SONOBUOY_E2E_REGISTRY={{user `sonobuoy_e2e_registry`}}","PAUSE_CONTAINER_VERSION={{user `pause_container_version`}}","CACHE_CONTAINER_IMAGES={{user `cache_container_images`}}"]
}

S3_PATH="s3://$BINARY_BUCKET_NAME/$KUBERNETES_VERSION/$KUBERNETES_BUILD_DATE/bin/linux/$ARCH"之后添加以下命令

export ACCOUNT_ID=$(aws sts get-caller-identity --output text --query Account)
export AWS_REGION=$(curl -s 169.254.169.254/latest/dynamic/instance-identity/document | jq -r '.region')aws --version
aws sts get-caller-identity
aws configure set default.region ${AWS_REGION}
aws configure get default.regionecho "start docker"
sudo systemctl start docker
echo "pull image"
sudo docker pull hello-world
echo "docker stop"
sudo systemctl stop docker

由于需要使用aws命令拉取资源,通过环境变量配置构建ami使用的凭证

export AWS_ACCESS_KEY_ID=xxxxxxxxxx
export AWS_SECRET_ACCESS_KEY=xxxxxxxxxxxxxxxxxxxxexport ACCOUNT_ID=$(aws sts get-caller-identity --output text --query Account)
export AWS_REGION=$(curl -s 169.254.169.254/latest/dynamic/instance-identity/document | jq -r '.region')

启动新实例构建ami,在cn-north-1区域执行构建需要修改packer变量配置

cd amazon-eks-ami
$ make 1.23

默认类型为m4.large,由于众所周知的原因,去us拉取kubelet等二进制程序非常慢,可以提前下载到s3中,并修改packer变量

在这里插入图片描述

构建完成后只需要在创建集群时指定ami即可

apiVersion: eksctl.io/v1alpha5
kind: ClusterConfig
metadata:name: xxxxversion: "1.23"region: cn-north-1managedNodeGroups:- name: testpakcerami: ami-xxxxxxxxxxxxdesiredCapacity: 1minSize: 0maxSize: 3instanceType: t3.mediumprivateNetworking: falsessh:allow: truepublicKeyName: cluster-keyiam:withAddonPolicies:imageBuilder: truealbIngress: trueebs: true

这篇关于aws eks 使用packer构建自定义ami的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329993

相关文章

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经