- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 AWS 中创建新的 AMI,我通常手动运行命令以验证它们是否正常工作,然后我对该框进行镜像以创建 AMI。但是还有其他选择,例如 packer.io ,使用此服务制作简单的自定义 AMI 的最小工作示例是什么?
最佳答案
https://github.com/devopracy/devopracy-base/blob/master/packer/base.json有一个加壳文件看起来与我在工作中用于基本镜像的文件非常相似。它没有经过测试,但我们可以深入研究一下。基础镜像是我自己的基础——所有服务都是使用它作为源 ami 构建的。这样我就可以控制我的依赖关系并确保我的服务下有一个一致的操作系统。您可以简单地从 chef supermarket 添加食谱,以查看供应服务如何使用此文件,或将其用作基础。作为基础,您将为服务创建一个类似的、不太详细的构建并将其称为源 ami。
第一部分声明了我用来打包的变量。变量是在构建之前从 bash 文件注入(inject)的,我没有检查到源代码控制。我将 bash 脚本保存在我的主目录中,并在调用 packer build 之前获取它。请注意,厨师供应商有一个食谱路径。我使用 base_dir
作为我的开发箱或构建服务器上的位置。我使用引导 key 来构建;如果您不指定,packer 会为 ssh 创建自己的 key ,但最好在 aws 上创建一个 key ,然后用它启动您的构建。这使得实时调试加壳器更加容易。
"variables": {
"aws_access_key_id": "{{env `AWS_ACCESS_KEY`}}",
"aws_secret_key": "{{env `AWS_SECRET_ACCESS_KEY`}}",
"ssh_private_key_file": "{{env `SSH_PRIVATE_KEY_FILE`}}",
"cookbook_path": "{{env `CLOUD_DIR`}}/ops/devopracy-base/cookbooks",
"base_dir": "{{env `CLOUD_DIR`}}"
},
文件的下一部分包含构建器。我在工作和下类时也使用 amazon-ebs,创建一个文件更简单,而且通常较大的实例类型只能作为 ebs 使用。在这个文件中,我调整了卷的大小,以便我们有更多的空间来安装东西。请注意,此处未指定源 ami,我在这里或那里查找最新版本。如果您正在使用 Ubuntu,它有一个方便的站点,只需谷歌 ec2 ubuntu 定位器。您需要放入源图像进行构建。
"builders": [{
"type": "amazon-ebs",
"access_key": "{{user `aws_access_key_id`}}",
"secret_key": "{{user `aws_secret_key`}}",
"region": "us-west-2",
"source_ami": "",
"instance_type": "t2.small",
"ssh_username": "fedora",
"ami_name": "fedora-base-{{isotime \"2006-01-02\"}}",
"ami_description": "fedora 21 devopracy base",
"security_group_ids": [ "" ],
"force_deregister": "true",
"ssh_keypair_name": "bootstrap",
"ssh_private_key_file": "{{user `ssh_private_key_file`}}",
"subnet_id": "",
"ami_users": [""],
"ami_block_device_mappings": [{
"delete_on_termination": "true",
"device_name": "/dev/sda1",
"volume_size": 30
}],
"launch_block_device_mappings": [{
"delete_on_termination": "true",
"device_name": "/dev/sda1",
"volume_size": 30
}],
"tags": {
"stage": "dev",
"os": "fedora 21",
"release": "latest",
"role": "base",
"version": "0.0.1",
"lock": "none"
}
}],
当您开始在云上执行自动化时,标记图像非常有用。这些标签是您处理部署等的方式。 fedora
是 fedora 的默认用户,ubuntu
是 ubuntu 的默认用户,ec2-user
是 amazon linux 等的默认用户。您可以在文档中查找这些用户你的发行版。
同样,您需要向此文件添加一个安全组,以及一个要在其中启动的子网。如果您没有指定这些,但如果您是在构建服务器或非默认 vpc,您必须指定。强制注销将在成功构建时删除同名的 ami - 我按日期命名,因此我可以每天迭代构建而不是堆积一堆图像。
最后,我使用了 chef provisioner。我在另一个 repo 中有这本食谱,它在构建服务器上的路径是顶部的一个变量。在这里,我们正在寻找用于配置的 chef-zero,这在技术上不受支持,但可以与 chef 客户端配置器和自定义命令一起正常工作。除了主厨运行之外,我还编写了一些自己的脚本,然后通过运行 serverspec 测试来跟进,以确保一切正常。
"provisioners": [
{
"type": "shell",
"inline": [
]
},
{
"type": "shell",
"script": "{{user `base_dir`}}/ops/devopracy-base/files/ext_disk.sh"
},
{
"type": "shell",
"inline": [
"sudo reboot",
"sleep 30",
"sudo resize2fs /dev/xvda1"
]
},
{
"type": "shell",
"inline": [
"sudo mkdir -p /etc/chef && sudo chmod 777 /etc/chef",
"sudo mkdir -p /tmp/packer-chef-client && sudo chmod 777 /tmp/packer-chef-client"
]
},
{
"type": "file",
"source": "{{user `cookbook_path`}}",
"destination": "/etc/chef/cookbooks"
},
{
"type": "chef-client",
"execute_command": "cd /etc/chef && sudo chef-client --local-mode -c /tmp/packer-chef-client/client.rb -j /tmp/packer-chef-client/first-boot.json",
"server_url": "http://localhost:8889",
"skip_clean_node": "true",
"skip_clean_client": "true",
"run_list": ["recipe[devopracy-base::default]"]
},
{
"type": "file",
"source": "{{user `base_dir`}}/ops/devopracy-base/test/spec",
"destination": "/home/fedora/spec/"
},
{
"type": "file",
"source": "{{user `base_dir`}}/ops/devopracy-base/test/Rakefile",
"destination": "/home/fedora/Rakefile"
},
{
"type": "shell",
"inline": ["/opt/chef/embedded/bin/rake spec"]
},
{
"type": "shell",
"inline": ["sudo chmod 600 /etc/chef"]
}
]
}
自然地,这里围绕 chef 目录的 chmoding 有一些愚蠢的事情,而且它显然不安全 - 我在私有(private)子网中运行我的构建。我希望这可以帮助您开始使用 packer,它实际上是一个了不起的软件,而且非常有趣!如有任何问题,请在评论中联系我,或者在 github 上联系我。所有 devopracy 的东西都是 WIP,但是当我有更多时间处理这些文件时,这些文件可能会成熟 :P
祝你好运!
关于amazon-web-services - 如何使用 Packer 创建 EC2 机器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37145189/
我有一个包装器 json,如: "builders": [{...}], "provisioners": [ { "type": "file",
我想将 ISO_URL 作为命令行参数传递。我试着按照 https://www.packer.io/docs/templates/user-variables.html 上的一个例子 我的变量部分看起
我最近一直在研究 packer,发现它是一个很棒的工具。但是我没有在安装脚本中使用已安装的工具。 这是我一直在玩的一个示例打包程序模板(我知道有更好的方法可以将它与脚本和供应商一起使用。但为了简单起见
我对 Packer 和 RancherOS 有疑问。我正在尝试使用 cloud-config 文件构建自定义 rancherOS 镜像。我正在 MacOSX 上工作。 我有这个build.json文件
这是我的第一个问题。我尝试遵循所有准则。 我正在尝试使用 Packer 创建 Debian 8 的 Vagrant 镜像。如果我运行仅使用“builders”模板的 packer 构建,它将成功执行并
Packer 在构建时自动缓存操作系统 ISO。有没有什么方法可以利用这种机制(或类似机制)在 VM 内配置文件,这样它就不会每次都重新下载它们? 最佳答案 使用 url 的 sha256 下载 is
我刚开始使用Packer,并且在某些情况下我的构建失败,因此我希望登录到该机中调查原因。但是,似乎没有packer login或类似命令可以给我一个 shell 。取而代之的是,在我有机会进行调查之前
我想在打包程序配置期间生成一个公共(public)/私有(private) ssh key 对并将文件复制到主机。有没有办法使用打包程序将文件从 VM 复制到主机? 最佳答案 我想到了。文件配置器有一
我有一个似乎是不受支持的有效用例 - afaik - 场景,使用 packer.io我担心我可能会遗漏一些东西...... 因此,在加壳器中,我可以添加: 很多builders , 有一个不同的nam
我一直在尝试找出在打包程序中使用选项变量的可能性,我的脚本如下: "provisioners": [{ "type": "shell", "scripts": [ "scripts/c
在我对 Packer 的探索中,我想知道以下几点: docs状态(作为向 AWS 预配 Ubuntu 镜像的入门步骤的一部分): Note: The sleep 30 in the example a
我开始使用 Packer,我有一个问题。是否有添加 bash 脚本的解决方案,该脚本将在从镜像部署 VM 后自动启动且仅启动一次? 最佳答案 在linux虚拟机镜像的/etc/rc.local中添加如
假设我有一个名为 windows_10.json 的 Packer 文件.我跑了 packer build windows_10.json构建 Windows 10 的 VirtualBox 镜像需要
我正在使用 PAR::Packer,这个问题突然出现在我的脑海中。 PAR::Packer 在 Perl 中是如何工作的?它实际上是否将 Perl 脚本编译为 .exe,就像 g++ 将 C++ 源代
当我使用 vagrant 时,我可以在 Vagrantfile 中指定 list 文件。 例子: config.vm.provision "ansible" do |ansible| ansi
任何人都已经遇到过 packer build 的这个问题? Waiting for SSH to become available... [INFO] Attempting SSH connectio
如果我想使用 Packer 创建虚拟机镜像,一种选择是下载操作系统的 ISO 镜像并将其用作自定义设置的基础。执行此操作时,需要提供 boot_command ,这是一个字符串数组,告诉 Packer
我从 ubuntu shell 运行以下命令,与 aws 平台对话,自定义 amazon ami(ami-9abea4fb): $ packer build -debug template.packe
我对整个 Packer/Vagrant, Puppet 世界很陌生。我正在尝试使用 Packer 和 Puppet 构建我的第一个 VM。 我可以成功构建一个 virtualbox,并且我已经包含了一
我试图了解所有这些工具是如何工作的,因为据我所知,它们会更改变量的名称以实现更好的压缩。 它们是否也更改对象属性的名称?我猜他们不会,因为否则任何使用 object[property] 符号的东西,其
我是一名优秀的程序员,十分优秀!