-
Notifications
You must be signed in to change notification settings - Fork 119
/
Copy pathVagrantfile
75 lines (58 loc) · 2.7 KB
/
Vagrantfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
# frozen_string_literal: true
# -*- mode: ruby -*-
# vi: set ft=ruby :
require 'date'
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
VAGRANTFILE_API_VERSION = '2'
DEFAULT_BOX = 'Sgoettschkes/debian7'
SUBNET = '192.168.33'
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
config.vm.box = DEFAULT_BOX
config.vm.define 'dev', primary: true do |dev|
dev.vm.network :private_network, ip: "#{SUBNET}.10"
dev.vm.network :forwarded_port, guest: 5432, host: 5432 # pq
dev.vm.network :forwarded_port, guest: 6379, host: 6379 # redis
script = <<~SCRIPT
date --set #{DateTime.now.strftime('%Y-%m-%d')}
date --set #{DateTime.now.strftime('%H:%M')}
set -e
DEBIAN_FRONTEND=noninteractive
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 9D6D8F6BC857C906
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 7638D0442B90D010
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 7638D0442B90D010
apt-get -qqy update
PG_PKG=postgresql
PG_INSTALLED=$(dpkg -l | grep -q ${PG_PKG} || echo "NOT")
if [ "x${PG_INSTALLED}" = "xNOT" ] ; then
echo 'deb http://apt.postgresql.org/pub/repos/apt/ wheezy-pgdg main' > /etc/apt/sources.list.d/pgdg.list
wget https://www.postgresql.org/media/keys/ACCC4CF8.asc --no-check-certificate
apt-key add ACCC4CF8.asc
apt-get update
echo 'Name: libraries/restart-without-asking
Template: libraries/restart-without-asking
Value: true
Owners: libssl1.0.0
Flags: seen' >> /var/cache/debconf/config.dat
apt-get -qyf install postgresql-10 postgresql-contrib-10 postgresql postgresql-contrib
sed -i "s|#listen_addresses.*$|listen_addresses = '*' |g" /etc/postgresql/9.3/main/postgresql.conf
echo "host all all all trust" > /etc/postgresql/9.3/main/pg_hba.conf
/etc/init.d/postgresql restart
fi
REDIS_PKG=redis-server
REDIS_INSTALLED=$(dpkg -l | grep -q ${REDIS_PKG} || echo "NOT")
if [ "x${REDIS_INSTALLED}" = "xNOT" ] ; then
apt-get -qy install $REDIS_PKG
sed -i "s|bind 127.0.0.1|#bind = 127.0.0.1|g" /etc/redis/redis.conf
/etc/init.d/redis-server restart
fi
echo DONE
SCRIPT
dev.vm.provision :shell, inline: script
end
config.vm.define 'stage' do |stage|
stage.vm.network :private_network, ip: "#{SUBNET}.11"
end
config.vm.define 'node' do |node|
node.vm.network :private_network, ip: "#{SUBNET}.12"
end
end