Назад | Перейти на главную страницу

Как лучше всего создать и протестировать кулинарные книги для шеф-поваров aws opsworks на местном уровне?

В течение нескольких месяцев я пытался найти лучший рабочий процесс для создания и тестирования моих кулинарных книг aws opsworks локально, прежде чем перейти к opsworks.

После множества неудачных попыток я нашел сообщение в блоге Майка Грейлинга и с тех пор остановился на среде, которая мне подходит. Я хотел бы поделиться настройкой / конфигурацией, потому что есть много движущихся частей.

Я призываю всех, у кого есть собственная среда сборки / тестирования для шеф-повара, которые специально предназначены для кулинарных книг opsworks, чтобы также публиковать ответы здесь - спасибо !!.

Я НАСТОЯТЕЛЬНО рекомендую всем посмотреть сообщение в блоге Майка Грейлинга. Упростите разработку OpsWorks с помощью Packer и его репозиторий на github opsworks-vm которые помогут вам смоделировать весь стек opsworks, включая установку агента opsworks так что вы также можете тестировать рецепты развертывания приложений, несколько уровней, несколько экземпляров одновременно и т. д. Это очень впечатляет.

Я включил все настройки, необходимые для подготовки вашей среды перед использованием сборки Packer Virtualbox Майка Грейлинга.

Быстрый старт в Ubuntu 14.04

ПРИМЕЧАНИЕ. Это НЕЛЬЗЯ сделать с виртуальной машины ubuntu, потому что virtualbox не поддерживает вложенную виртуализацию 64-битных машин.

  1. Установить ChefDK
    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. Установить VirtualBox
    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. Установить Бродяга
    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. Установить Упаковщик
    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. Сборка Майка Грейлинга opsworks-vm образ виртуального бокса с использованием 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. Это установит новый виртуальный ящик vm в ~ / .vagrant.d / boxs / ubuntu1404-opsworks /

Чтобы смоделировать один экземпляр opsworks, создайте новый Vagrantfile следующим образом:

Vagrant.configure("2") do |config|
  config.vm.box = "ubuntu1404-opsworks"
  config.vm.provision :opsworks, type: 'shell', args: 'path/to/dna.json'
end

В dna.json путь к файлу задается относительно Vagrantfile и должен содержать любые данные JSON, которые вы хотите отправить в OpsWorks Chef.

Например:

{
  "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]"
    ]
  }
}

Чтобы смоделировать несколько экземпляров opsworks и включить слои, см. Его Пример начала работы с AWS OpsWorks который включает stack.json ниже.

Vagrantfile (для нескольких экземпляров)

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

stack.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"
    }
  }
}

Для тех, кто не знаком с бродягой, просто сделайте vagrant up для запуска экземпляра (ов). Затем вы можете изменить свою кулинарную книгу локально, и любые изменения могут быть применены путем повторного запуска chef для существующих экземпляров с помощью vagrant provision. Вы можете сделать vagrant destroy и vagrant up начать с нуля.