2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-10 09:02:10 +00:00
bench/vm
2018-04-11 12:47:23 +05:30
..
http Fixes for VM build issue 2018-03-08 13:41:09 +05:30
scripts Changes for auto VM builds 2018-03-31 23:37:40 +05:30
build.py minor fixes 2018-04-01 02:51:43 +05:30
Readme.md updated readme 2018-04-11 12:47:23 +05:30
Vagrantfile Vagrant box addition 2018-03-09 14:55:23 +05:30
vm-develop.json minor fixes 2018-04-01 02:51:43 +05:30
vm-production.json minor fixes 2018-04-01 02:51:43 +05:30

ERPNext VM Builder

Steps to build a VM Image

  • python build.py builds a new Production VM, a Dev VM and a Dev Vagrant Box

Requirements

  • Bench should be installed
  • Ansible should be installed

How it works

Apart from the above the rest is handled by bench:

  • Install prerequisites if not already installed
    • virtualbox
    • packer
  • Cleanup
    • Clean the required directories
  • Build the VM using packer
    • Packer downloads the mentioned Ubuntu iso, boots a virtual machine and preceeds the preseed.cfg file into it in order to setup a clean Ubuntu OS
    • Then packer uses ssh to enter the virtual machine to execute the required commands
    • scripts/debian_family/install_ansible.sh sets up ansible on the vm.
    • Depending on the VM being built, the vm-develop.json or the vm-production.json is used
    • scripts/set_message.sh sets welcome message (with update instructions) in the vm.
    • scripts/cleanup.sh writes zeros to all the free space in the disk, it shrinks the disk image
  • Set the correct permissions for the built Vagrant and Virtual Appliance Images
  • Cleanup
    • Delete the generated files from the required directories
  • Restart nginx

Running the build.py script builds the VMs and puts them in ~/Public. It also creates the md5 hashes for the same, and puts them in the same folder.