Início rápido no Ubuntu 14.04

Início rápido no Ubuntu 14.04

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.

  1. InstalarChefDK
    1. mkdir /tmp/packages && cd /tmp/packages
    2. wget https://opscode-omnibus-packages.s3.amazonaws.com/ubuntu/12.04/x86_64/chefdk_0.8.1-1_amd64.deb
    3. sudo dpkg -i chefdk_0.8.0-1_amd64.deb
    4. cd /opt/chefdk/
    5. chef verify
    6. which ruby
    7. echo 'eval "$(chef shell-init bash)"' >> ~/.bash_profile && source ~/.bash_profile
  2. InstalarCaixa Virtual
    1. echo 'deb http://download.virtualbox.org/virtualbox/debian vivid contrib' > /etc/apt/sources.list.d/virtualbox.list
    2. wget -q https://www.virtualbox.org/download/oracle_vbox.asc -O- | sudo apt-key add -
    3. sudo apt-get update -qqy
    4. sudo apt-get install virtualbox-5.0 dkms
  3. InstalarVagabundo
    1. cd /tmp/packages
    2. wget https://dl.bintray.com/mitchellh/vagrant/vagrant_1.7.4_x86_64.deb
    3. sudo dpkg -i vagrant_1.7.4_x86_64.deb
    4. vagrant plugin install vagrant-berkshelf
    5. vagrant plugin install vagrant-omnibus
    6. vagrant plugin list
  4. InstalarEmpacotador
    1. mkdir /opt/packer && cd /opt/packer
    2. wget https://dl.bintray.com/mitchellh/packer/packer_0.8.6_linux_amd64.zip
    3. unzip packer_0.8.6_linux_amd64.zip
    4. echo 'PATH=$PATH:/opt/packer' >> ~/.bash_profile && source ~/.bash_profile
  5. Construa Mike Greilingopsworks-vmimagem do virtualbox usando Packer
    1. mkdir ~/packer && cd ~/packer
    2. git clone https://github.com/pixelcog/opsworks-vm.git
    3. cd opsworks-vm
    4. rake build install
    5. 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.jsoncaminho 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 uppara 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 destroye vagrant upcomeçar do zero.

informação relacionada