Skip to content

Instantly share code, notes, and snippets.

@mapaiva
Last active August 8, 2017 16:30
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save mapaiva/39e52f0373d0cd6eac6db35a46093ceb to your computer and use it in GitHub Desktop.
Save mapaiva/39e52f0373d0cd6eac6db35a46093ceb to your computer and use it in GitHub Desktop.
Vagrant file for Golang and PostgreSQL
#-*- 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.
# Every Vagrant development environment requires a box. You can search for
# boxes at https://atlas.hashicorp.com/search.
config.vm.box = "fedora/25-cloud-base"
# 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
# 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.
# config.vm.network "forwarded_port", guest: 80, host: 8080
# 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"
# 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"
# 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
# information on available options.
# Define a Vagrant Push strategy for pushing to Atlas. Other push strategies
# such as FTP and Heroku are also available. See the documentation at
# https://docs.vagrantup.com/v2/push/atlas.html for more information.
# config.push.define "atlas" do |push|
# push.app = "YOUR_ATLAS_USERNAME/YOUR_APPLICATION_NAME"
# 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
# PostgreSQL
config.vm.network "forwarded_port", guest: 5432, host: 25432
# Install git
config.vm.provision "shell", inline: <<-SHELL
dnf -y install git
SHELL
# Install golang and setup its environment
config.vm.provision "shell", privileged: false, inline: <<-SHELL
curl -O https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz
mkdir -p go/src go/bin go/pkg
echo "
export GOPATH=$HOME/go
export GOROOT=/usr/local/go
export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin
" >> .bashrc
SHELL
config.vm.provision "shell", inline: <<-SHELL
tar -C /usr/local -xzf go1.8.3.linux-amd64.tar.gz
SHELL
# Copy SSH key used to download git repositories
config.vm.provision "file",
source: "/home/mapaiva/.ssh/id_rsa",
destination: "~/.ssh/id_rsa"
config.vm.provision "file",
source: "/home/mapaiva/.ssh/id_rsa.pub",
destination: "~/.ssh/id_rsa.pub"
# Install PostreSQL
config.vm.provision "shell", inline: <<-SHELL
dnf -y install postgresql-server postgresql-contrib
#echo 'Configuring postgresql...'
#postgresql-setup --initdb --unit postgresql
#systemctl restart postgresql
SHELL
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment