diff options
author | Dylan William Hardison <dylan@hardison.net> | 2017-04-14 19:05:03 +0200 |
---|---|---|
committer | Dylan William Hardison <dylan@hardison.net> | 2017-04-14 19:10:20 +0200 |
commit | 4a130afba58836ebb2f70a31c88588ea46017009 (patch) | |
tree | 200816c2c7525e76228559e6b0ee81dc46980c14 /Vagrantfile | |
parent | 480bbf368b485a6a0317b9356ce90b75201b3efa (diff) | |
download | bugzilla-4a130afba58836ebb2f70a31c88588ea46017009.tar.gz bugzilla-4a130afba58836ebb2f70a31c88588ea46017009.tar.xz |
Bug 1328874 - Add Vagrantfile for production-like development VMs
Diffstat (limited to 'Vagrantfile')
-rw-r--r-- | Vagrantfile | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/Vagrantfile b/Vagrantfile new file mode 100644 index 000000000..88c68d052 --- /dev/null +++ b/Vagrantfile @@ -0,0 +1,98 @@ +# vim: set ft=ruby sw=2 ts=2: +# -*- mode: ruby -*- + +DB_IP = ENV.fetch "BMO_DB_IP", '192.168.3.42' +WEB_IP = ENV.fetch "BMO_WEB_IP", '192.168.3.43' +DB_HOSTNAME = ENV.fetch "BMO_DB_HOST", 'bmo-db.vm' +WEB_HOSTNAME = ENV.fetch "BMO_WEB_HOST", 'bmo-web.vm' +DB_PORT = ENV.fetch "BMO_DB_PORT", 2221 +WEB_PORT = ENV.fetch "BMO_WEB_PORT", 2222 +WEB_MEM = ENV.fetch "BMO_WEB_MEM", 2048 +WEB_CPU = ENV.fetch "BMO_WEB_CPU", 2 + +# this is for centos 6 / el 6 +VENDOR_BUNDLE_URL = ENV.fetch "BMO_BUNDLE_URL", + 'https://moz-devservices-bmocartons.s3.amazonaws.com/bmo/vendor.tar.gz' + +# All Vagrant configuration is done below. The '2' in Vagrant.configure +# configures the configuration version (we support older styles for +# backwards compatibility). Please don't change it unless you know what +# you're doing. +Vagrant.configure('2') do |config| + # The most common configuration options are documented and commented below. + # For a complete reference, please see the online documentation at + # https://docs.vagrantup.com. + + config.vm.provision 'ansible_local', run: 'always' do |ansible| + ansible.playbook = 'vagrant_support/playbook.yml' + ansible.extra_vars = { + WEB_IP: WEB_IP, + DB_IP: DB_IP, + WEB_HOSTNAME: WEB_HOSTNAME, + DB_HOSTNAME: DB_HOSTNAME, + VENDOR_BUNDLE_URL: VENDOR_BUNDLE_URL, + } + end + + config.vm.define 'db' do |db| + db.vm.box = 'centos/6' + + db.vm.hostname = DB_HOSTNAME + db.vm.network 'private_network', ip: DB_IP + db.vm.network 'forwarded_port', + id: 'ssh', + host: DB_PORT, + guest: 22, + auto_correct: true + + db.vm.synced_folder '.', '/vagrant', type: 'rsync', + rsync__args: ['--verbose', '--archive', '--delete', '-z', '--copy-links', + '--exclude=local/', + '--exclude=data/', + '--exclude=template_cache/', + '--exclude=localconfig'] + db.vm.provider 'parallels' do |prl, override| + override.vm.box = 'parallels/centos-6.8' + end + end + + config.vm.define 'web', primary: true do |web| + # Every Vagrant development environment requires a box. You can search for + # boxes at https://atlas.hashicorp.com/search. + web.vm.box = 'centos/6' + web.vm.hostname = WEB_HOSTNAME + + # Create a private network, which allows host-only access to the machine + # using a specific IP. + web.vm.network 'private_network', ip: WEB_IP + web.vm.network 'forwarded_port', + id: 'ssh', + host: WEB_PORT, + guest: 22, + auto_correct: true + + + web.vm.synced_folder '.', '/vagrant', type: 'rsync', + rsync__args: ['--verbose', '--archive', '--delete', '-z', '--copy-links', + '--exclude=local/', + '--exclude=data/', + '--exclude=template_cache/', + '--exclude=localconfig'] + + web.vm.provider 'virtualbox' do |v| + v.memory = WEB_MEM + v.cpus = WEB_CPU + end + + web.vm.provider 'parallels' do |prl, override| + override.vm.box = 'parallels/centos-6.8' + prl.memory = WEB_MEM + prl.cpus = WEB_CPU + end + + web.vm.provider 'vmware_fusion' do |v| + v.vmx['memsize'] = WEB_MEM + v.vmx['numvcpus'] = WEB_CPU + end + end +end |