Я создаю бродячую коробку с возможностью. Тем не менее, мой бродячий хост не поддерживает правдоподобие, поэтому я должен выполнить доступ к локальному хосту изнутри бродячего бокса. Я использую средство обеспечения оболочки, выполняя скрипт, который установит доступный и запустит правильную исполняемую команду против playbook в синхронизированной папке.Как сохранить организованную конфигурацию бродяг
Это решение работает, но оно бесполезно и сложно поддерживать, поскольку данные конфигурации засоряются между файлами. Как вы можете видеть ниже, существует дублирование пути для воспроизведения, жестко закодированное как для Vagrantfile, так и для сценария подготовки. И, как мы знаем, дублирование является источником зла. Скорее, я хотел бы сохранить все строки конфигурации в Vagrantfile или внешнем файле. Возможно ли это в моем случае? Было бы также полезно переопределить эти значения с помощью параметров командной строки.
Вот бродяга файл
VAGRANT_API_VERSION = 2
BOX_IMAGE = "ubuntu/trusty64"
PROVISIONING_SRC = "./provisioning"
PROVISIONING_DEST = "/etc/provisioning/vagrant"
Vagrant.configure(VAGRANT_API_VERSION) do |config|
config.vm.box = BOX_IMAGE
config.vm.network "private_network", ip: "192.168.22.22"
config.vm.network "forwarded_port", guest: 8080, host: 8080
config.vm.network "forwarded_port", guest: 8081, host: 8081
config.vm.network "forwarded_port", guest: 2222, host: 2223
config.vm.network "forwarded_port", guest: 5000, host: 5000
config.vm.network "forwarded_port", guest: 50000, host: 50000
config.vm.provision :shell, path: "provisioning.sh"
config.vm.synced_folder "./provisioning", "/etc/provisioning/vagrant"
end
Вот скрипт инициализации
apt-get install -y python-pip
apt-get install -y git-core
if [ -z $PLAYBOOK_PATH ]; then
echo "PLAYBOOK_PATH not set, using default"
PLAYBOOK_PATH=/etc/provisioning/vagrant/playbook.yml
fi
if [ -n $PLAYBOOK_PATH ]; then
echo "PLAYBOOK_PATH set at $PLAYBOOK_PATH"
if [ -f $PLAYBOOK_PATH ]; then
echo "PLAYBOOK FOUND, insalling ansible and starting provisioning"
pip install ansible
pip install markupsafe
if (ansible-playbook $PLAYBOOK_PATH); then
echo "provisioning OK"
else
echo "prvosioning failed"
fi
else
echo "PLAYBOOK not found"
fi
else
echo "PLAYBOOK_PATH not set"
fi
И, наконец, вот Playbook внутри инициализации папки
- name: Provision local docker host
hosts: localhost
become : yes
roles:
- docker.ubuntu
tasks:
- name: Add vagrant to docker group
become: yes
user: name=vagrant groups=docker append=yes