From 3329da92fa8fdcb6752d7ebf997e44077d831a62 Mon Sep 17 00:00:00 2001 From: Mauricio Esguerra Date: Wed, 15 Jul 2020 11:12:27 +0200 Subject: [PATCH 1/3] UPDATE: Update Ubuntu to focal-fossa and use a little bit more of server resources Note, this config is asking for 8 cores. You may want to change that. --- Vagrantfile | 99 +++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 78 insertions(+), 21 deletions(-) diff --git a/Vagrantfile b/Vagrantfile index 805353ed..21a53250 100644 --- a/Vagrantfile +++ b/Vagrantfile @@ -1,33 +1,90 @@ +# -*- mode: ruby -*- +# vi: set ft=ruby : + +# 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. - # Vagrant box to build off of. - config.vm.box = "ubuntu/bionic64" - config.disksize.size = '20GB' + # Every Vagrant development environment requires a box. You can search for + # boxes at https://vagrantcloud.com/search. + config.vm.box = "ubuntu/focal64" + config.vm.box_version = "20200629.0.0" - # Forward ports - config.vm.network :forwarded_port, guest: 22, host: 2226, id: "ssh" - config.vm.network :forwarded_port, guest: 8000, host: 8000 - config.vm.network :forwarded_port, guest: 80, host: 8001 + # Disable automatic box update checking. If you disable this, then + # boxes will only be checked for updates when the user runs + # `vagrant box outdated`. This is not recommended. + # config.vm.box_check_update = false - # Allocate resources - config.vm.provider :virtualbox do |vb| - vb.customize ["modifyvm", :id, "--ioapic", "on"] - vb.customize ["modifyvm", :id, "--memory", "4096"] - vb.customize ["modifyvm", :id, "--cpus", "4"] - end + # Create a forwarded port mapping which allows access to a specific port + # within the machine from a port on the host machine. In the example below, + # accessing "localhost:8080" will access port 80 on the guest machine. + # NOTE: This will enable public access to the opened port + # config.vm.network "forwarded_port", guest: 80, host: 8080 + config.vm.network "forwarded_port", guest: 22, host: 2226, id: "ssh" + config.vm.network "forwarded_port", guest: 8000, host: 8000 + config.vm.network "forwarded_port", guest: 80, host: 8001 + + # Create a forwarded port mapping which allows access to a specific port + # within the machine from a port on the host machine and only allow access + # via 127.0.0.1 to disable public access + # config.vm.network "forwarded_port", guest: 80, host: 8080, host_ip: "127.0.0.1" + + # Create a private network, which allows host-only access to the machine + # using a specific IP. + # config.vm.network "private_network", ip: "192.168.33.10" - # Set up a shared directory + # Create a public network, which generally matched to bridged network. + # Bridged networks make the machine appear as another physical device on + # your network. + # config.vm.network "public_network" + + # Share an additional folder to the guest VM. The first argument is + # the path on the host to the actual folder. The second argument is + # the path on the guest to mount the folder. And the optional third + # argument is a set of non-required options. + # config.vm.synced_folder "../data", "/vagrant_data" config.vm.synced_folder "shared", "/protwis/", :owner => "vagrant" - # copy puppet scripts to VM + # Provider-specific configuration so you can fine-tune various + # backing providers for Vagrant. These expose provider-specific options. + # Example for VirtualBox: + # + # config.vm.provider "virtualbox" do |vb| + # # Display the VirtualBox GUI when booting the machine + # vb.gui = true + # + # # Customize the amount of memory on the VM: + # vb.memory = "1024" + # end + # + # View the documentation for the provider you are using for more + config.vm.provider "virtualbox" do |vb| + # vb.customize ["modifyvm", :id, "--ioapic", "on"] + vb.customize ["modifyvm", :id, "--ioapic", "on", "--uartmode1", "file", File::NULL ] + vb.memory = "4096" + vb.cpus = "8" + end + + # Enable provisioning with a shell script. Additional provisioners such as + # Puppet, Chef, Ansible, Salt, and Docker are also available. Please see the + # documentation for more information about their specific syntax and use. + # config.vm.provision "shell", inline: <<-SHELL + # apt-get update + # apt-get install -y apache2 + # SHELL config.vm.provision "file", source: "protwis_puppet_modules", destination: "/protwis/conf/protwis_puppet_modules" config.vm.provision "shell", inline: "sudo apt-get update && sudo apt-get install -y puppet" - # Enable the Puppet provisioner - config.vm.provision :puppet do |puppet| - puppet.manifests_path = "manifests" - puppet.manifest_file = "default.pp" - puppet.module_path = "protwis_puppet_modules" + # Enable the Puppet provisioner + config.vm.provision "puppet" do |puppet| + puppet.manifests_path = "manifests" + puppet.manifest_file = "default.pp" + puppet.module_path = "protwis_puppet_modules" + puppet.options = "--verbose --debug" end - end From be81c57d19cf70254ebad798dc6d9c7ffdca30ab Mon Sep 17 00:00:00 2001 From: Mauricio Esguerra Date: Mon, 27 Jul 2020 10:58:02 +0200 Subject: [PATCH 2/3] changes on dependent folder protwis_puppet_modules. because it's included in .gitmodules, it gets added somehow as a change, though it shouldn't. --- protwis_puppet_modules | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/protwis_puppet_modules b/protwis_puppet_modules index fa88b006..def4228f 160000 --- a/protwis_puppet_modules +++ b/protwis_puppet_modules @@ -1 +1 @@ -Subproject commit fa88b00691ddf8f6d1f4232ecb039a05b6988442 +Subproject commit def4228f1922e663a392b21341282ff29f33846c From 7643d879f3658a7fe0d894c215c6493bb90f5979 Mon Sep 17 00:00:00 2001 From: Mauricio Esguerra Date: Mon, 27 Jul 2020 11:08:20 +0200 Subject: [PATCH 3/3] UPDATE: Needed plugins update to readme. --- README.md | 37 ++++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/README.md b/README.md index 2c0058b4..648b5a25 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ Development environment for [Protwis](https://github.com/protwis/protwis) using ### Instructions -This guide describes how to set up a ready-to-go virtual machine with Virtualbox and Vagrant. +This guide describes how to set up a ready-to-go virtual machine (VM) with Virtualbox and Vagrant. Works on Linux, Mac, and Windows. @@ -13,12 +13,12 @@ Works on Linux, Mac, and Windows. * [Git][git] * [GitHub][github] account -[vagrant]: http://www.vagrantup.com +[vagrant]: https://www.vagrantup.com [virtualbox]: https://www.virtualbox.org -[git]: http://git-scm.com -[github]: http://www.bitbucket.org +[git]: https://git-scm.com +[github]: https://github.com -Install Vagrant, VirtualBox, and Git, and create a GitHub account (if you don't already have one). +Install **Vagrant**, **VirtualBox**, and **Git**, and create a **GitHub** account (if you don't already have one). Make sure you have the latest version of all three. On Ubuntu (and this may also apply to other Linux distros), the package manager installs an old version of Vagrant, so you will have to download and install the latest version from @@ -44,12 +44,16 @@ Clone into the "shared" directory (replace your-username with your GitHub userna cd ~/protwis_vagrant git clone https://github.com/your-username/protwis.git shared/sites/protwis -##### Add vagrant plugin +##### Add vagrant plugins This allows for VM boxes to change disk size vagrant plugin install vagrant-disksize +To mount your folders into the vagrant VM you will also need to install the guest additions plugin + + vagrant plugin install vagrant-vbguest + ##### Start the vagrant box This may take a few minutes @@ -60,12 +64,13 @@ This may take a few minutes vagrant ssh -##### Start the built in Django development webserver +##### Activate the python virtual environment and start the built in Django development webserver cd /protwis/sites/protwis - /env/bin/python3 manage.py runserver 0.0.0.0:8000 + source /env/bin/activate + ./manage.py runserver 0.0.0.0:8000 -You're all set up. The webserver will now be accessible from http://localhost:8000 +You're all set up. The web server will now be accessible in your local web browser at http://localhost:8000 #### Windows @@ -107,21 +112,23 @@ Use an SSH client, e.g. PuTTY, with the following settings cd /protwis/sites/protwis /env/bin/python3 manage.py runserver 0.0.0.0:8000 -You're all set up. The webserver will now be accessible from http://localhost:8000 +You're all set up. The web server will now be accessible in your local web browser at http://localhost:8000 #### Other notes -The protwis directory is now shared between the host machine and the virtual machine, and any changes made on the host -machine will be instantly reflected on the server. +The protwis directory is now shared between the *host* machine and the *virtual* machine, and any changes made on the +host machine will be instantly reflected on the server. -To run django commands from the protwis directory, ssh into the VM, and use the "/env/bin/python3" command e.g +To run django commands from the protwis directory, ssh into the VM, and activate the python virtual environment, +`source /env/bin/activate` then you can start running django e.g cd ~/protwis_vagrant/ vagrant ssh cd /protwis/sites/protwis - /env/bin/python3 manage.py check protein + source /env/bin/activate + ./manage.py check protein -The database administration tool Adminer is installed and accessible at http://localhost:8001/adminer. Use the +The database administration tool **Adminer** is installed and accessible at http://localhost:8001/adminer. Use the following settings System: PostgreSQL