Há meses tenho lutado para encontrar o melhor fluxo de trabalho para criar e testar meus livros de receitas do aws opsworks localmente antes de enviar para o opsworks.
Depois de muitas tentativas paralisadas, encontrei uma postagem no blog de Mike Greiling e, desde então, decidi por um ambiente que funciona bem para mim. Eu gostaria de compartilhar a configuração porque há muitas peças móveis.
Encorajo qualquer pessoa que tenha seus próprios ambientes de construção/teste para chef,que são especificamente voltados para livros de receitas do opsworks, para também postar respostas aqui - obrigado!!.
Responder1
Eu recomendo a todos que dêem uma olhada na postagem do blog de Mike GreilingSimplifique o desenvolvimento do OpsWorks com o Packere seu repositório no githubopsworks-vm que ajudam você a simular toda a pilha do opsworks, incluindo a instalação do agente opsworksentão você também pode testar receitas de implantação de aplicativos, múltiplas camadas, múltiplas instâncias ao mesmo tempo, etc.
Incluí toda a configuração necessária para preparar seu ambiente antes de usar a versão Packer Virtualbox de Mike Greiling.
Início rápido no Ubuntu 14.04
NOTA: Isso NÃO pode ser feito em uma máquina virtual Ubuntu porque o VirtualBox não suporta virtualização aninhada de máquinas de 64 bits.
- InstalarChefDK
mkdir /tmp/packages && cd /tmp/packages
wget https://opscode-omnibus-packages.s3.amazonaws.com/ubuntu/12.04/x86_64/chefdk_0.8.1-1_amd64.deb
sudo dpkg -i chefdk_0.8.0-1_amd64.deb
cd /opt/chefdk/
chef verify
which ruby
echo 'eval "$(chef shell-init bash)"' >> ~/.bash_profile && source ~/.bash_profile
- InstalarCaixa Virtual
echo 'deb http://download.virtualbox.org/virtualbox/debian vivid contrib' > /etc/apt/sources.list.d/virtualbox.list
wget -q https://www.virtualbox.org/download/oracle_vbox.asc -O- | sudo apt-key add -
sudo apt-get update -qqy
sudo apt-get install virtualbox-5.0 dkms
- InstalarVagabundo
cd /tmp/packages
wget https://dl.bintray.com/mitchellh/vagrant/vagrant_1.7.4_x86_64.deb
sudo dpkg -i vagrant_1.7.4_x86_64.deb
vagrant plugin install vagrant-berkshelf
vagrant plugin install vagrant-omnibus
vagrant plugin list
- InstalarEmpacotador
mkdir /opt/packer && cd /opt/packer
wget https://dl.bintray.com/mitchellh/packer/packer_0.8.6_linux_amd64.zip
unzip packer_0.8.6_linux_amd64.zip
echo 'PATH=$PATH:/opt/packer' >> ~/.bash_profile && source ~/.bash_profile
- Construa Mike Greilingopsworks-vmimagem do virtualbox usando Packer
mkdir ~/packer && cd ~/packer
git clone https://github.com/pixelcog/opsworks-vm.git
cd opsworks-vm
rake build install
- Isso instalará um novo virtualbox vm em ~/.vagrant.d/boxes/ubuntu1404-opsworks/
Para simular uma única instância do opsworks, crie um novo Vagrantfile assim:
Vagrant.configure("2") do |config|
config.vm.box = "ubuntu1404-opsworks"
config.vm.provision :opsworks, type: 'shell', args: 'path/to/dna.json'
end
O dna.json
caminho do arquivo é definido em relação ao Vagrantfile e deve conter quaisquer dados JSON que você deseja enviar ao OpsWorks Chef.
Por exemplo:
{
"deploy": {
"my-app": {
"application_type": "php",
"scm": {
"scm_type": "git",
"repository": "path/to/my-app"
}
}
},
"opsworks_custom_cookbooks": {
"enabled": true,
"scm": {
"repository": "path/to/my-cookbooks"
},
"recipes": [
"recipe[opsworks_initial_setup]",
"recipe[dependencies]",
"recipe[mod_php5_apache2]",
"recipe[deploy::default]",
"recipe[deploy::php]",
"recipe[my_custom_cookbook::configure]"
]
}
}
Para simular várias instâncias do opsworks e incluir camadas, consulte seuExemplo de "Introdução" do AWS OpsWorksque inclui opilha.jsonabaixo.
Vagrantfile (para múltiplas instâncias)
Vagrant.configure("2") do |config|
config.vm.box = "ubuntu1404-opsworks"
# Create the php-app layer
config.vm.define "app" do |layer|
layer.vm.provision "opsworks", type:"shell", args:[
'ops/dna/stack.json',
'ops/dna/php-app.json'
]
# Forward port 80 so we can see our work
layer.vm.network "forwarded_port", guest: 80, host: 8080
layer.vm.network "private_network", ip: "10.10.10.10"
end
# Create the db-master layer
config.vm.define "db" do |layer|
layer.vm.provision "opsworks", type:"shell", args:[
'ops/dna/stack.json',
'ops/dna/db-master.json'
]
layer.vm.network "private_network", ip: "10.10.10.20"
end
end
pilha.json
{
"opsworks": {
"layers": {
"php-app": {
"instances": {
"php-app1": {"private-ip": "10.10.10.10"}
}
},
"db-master": {
"instances": {
"db-master1": {"private-ip": "10.10.10.20"}
}
}
}
},
"deploy": {
"simple-php": {
"application_type": "php",
"document_root": "web",
"scm": {
"scm_type": "git",
"repository": "dev/simple-php"
},
"memcached": {},
"database": {
"host": "10.10.10.20",
"database": "simple-php",
"username": "root",
"password": "correcthorsebatterystaple",
"reconnect": true
}
}
},
"mysql": {
"server_root_password": "correcthorsebatterystaple",
"tunable": {"innodb_buffer_pool_size": "256M"}
},
"opsworks_custom_cookbooks": {
"enabled": true,
"scm": {
"repository": "ops/cookbooks"
}
}
}
Para quem não está familiarizado com o vagrant basta fazer um vagrant up
para iniciar a(s) instância(s). Em seguida, você pode modificar seu livro de receitas localmente e quaisquer alterações podem ser aplicadas executando novamente o chef nas instâncias existentes com vagrant provision.
Você pode fazer um vagrant destroy
e vagrant up
começar do zero.