forked from stoqs/stoqs
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprovision.sh
executable file
·246 lines (218 loc) · 8.83 KB
/
provision.sh
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
#!/bin/bash
# Idempotent shell script to install system level prerequisites for STOQS.
# Designed to be run from Vagrantfile, where default USER is vagrant.
# Usage: provision.sh centos7 vagrant (default)
# Where to do a git checkout from
export GIT_REPO_URL=$GIT_REPO_URL
export GIT_REPO_URL=https://github.com/mcgredonps/stoqs.git
if [ "$EUID" -ne 0 ]
then echo "Please run as root"
exit 1
fi
if [ $1 ]
then
OS=$1
else
OS='centos7'
fi
if [ $2 ]
then
USER=$2
else
USER='vagrant'
fi
if id -u "$USER" >/dev/null 2>&1;
then
echo "user $USER exists"
else
echo "user $USER does not exist"
exit 1
fi
cd /home/$USER
mkdir Downloads && cd Downloads
# OS specific provisioning
# TODO: Add stanza for other OSes, e.g. 'ubuntu'
if [ $OS = 'centos7' ]
then
echo Disable SELinux
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
mkdir /selinux
echo 0 > /selinux/enforce
echo Add epel, remi, and postgres repositories
# The epel release occasionally gets out of date, and must be updated,
# typically from something like "epel-release-7-7.noarch.rpm"
# to "epel-release-7-8.noarch.rpm".
yum makecache fast
yum -y install wget git
wget -q -N http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-8.noarch.rpm
if [ $? -ne 0 ] ; then
echo "File not found. Check http://dl.fedoraproject.org/pub/epel/7/x86_64/e/ for current version."
exit 1
fi
wget -q -N http://rpms.famillecollet.com/enterprise/remi-release-7.rpm
rpm -Uvh remi-release-7*.rpm epel-release-7*.rpm
curl -L -sS -O http://yum.postgresql.org/9.4/redhat/rhel-7-x86_64/pgdg-centos94-9.4-1.noarch.rpm > /dev/null
rpm -ivh pgdg*
yum -y install postgresql94-server
yum -y groupinstall "PostgreSQL Database Server 9.4 PGDG"
echo Install Python 2.7 and its support tools pip and virtalenv
yum groupinstall -y development
yum install -y zlib-devel openssl-devel sqlite-devel bzip2-devel xz-libs firefox
echo install uwsgi proxy for apache httpd
yum install -y uwsgi mod_proxy_uwsgi
wget -q -N http://www.python.org/ftp/python/2.7.9/Python-2.7.9.tar.xz
xz -d -c Python-2.7.9.tar.xz | tar -xvf -
cd Python-2.7.9
./configure
make && make altinstall
cd ..
wget -q --no-check-certificate -N https://pypi.python.org/packages/source/s/setuptools/setuptools-1.4.2.tar.gz
tar -xvf setuptools-1.4.2.tar.gz
cd setuptools-1.4.2
/usr/local/bin/python2.7 setup.py install
cd ..
curl -L -sS https://bootstrap.pypa.io/get-pip.py | sudo /usr/local/bin/python2.7 - > /dev/null
/usr/local/bin/pip install virtualenv
yum -y install rabbitmq-server scipy mod_wsgi memcached python-memcached
yum -y install graphviz-devel graphviz-python ImageMagick postgis2_94
yum -y install freetype-devel libpng-devel giflib-devel libjpeg-devel gd-devel proj-devel
yum -y install proj-nad proj-epsg curl-devel libxml2-devel libxslt-devel pam-devel readline-devel
yum -y install python-psycopg2 libpqxx-devel geos geos-devel hdf hdf-devel freetds-devel postgresql-devel
yum -y install gdal gdal-python gdal-devel mapserver mapserver-python libxml2 libxml2-python python-lxml python-pip python-devel gcc mlocate
yum -y install scipy blas blas-devel lapack lapack-devel GMT lvm2
yum -y groups install "GNOME Desktop"
fi
# Commands that work on any *nix
echo Download and install CMake
wget -q -N http://www.cmake.org/files/v2.8/cmake-2.8.3.tar.gz
tar xzf cmake-2.8.3.tar.gz
cd cmake-2.8.3
./configure --prefix=/opt/cmake
gmake && gmake install
cd ..
echo Build and install gdal
wget -q -N http://download.osgeo.org/gdal/2.1.0/gdal-2.1.0.tar.gz
tar xzf gdal-2.1.0.tar.gz
cd gdal-2.1.0
export PATH=$(pwd):$PATH
./configure --with-python
gmake && gmake install
cd ..
echo Build and install Mapserver
wget -q -N http://download.osgeo.org/mapserver/mapserver-6.4.1.tar.gz
tar xzf mapserver-6.4.1.tar.gz
cd mapserver-6.4.1
mkdir build
cd build
/opt/cmake/bin/cmake .. -DWITH_FRIBIDI=0 -DWITH_CAIRO=0 -DWITH_FCGI=0 -DCMAKE_PREFIX_PATH="/usr/local;/usr/pgsql-9.4"
make && make install
cp /usr/local/bin/mapserv /var/www/cgi-bin
echo "/etc/ld.so.conf.d/mapserver.conf" > /etc/ld.so.conf.d/mapserver.conf
ldconfig
cp /etc/sysconfig/httpd /etc/sysconfig/httpd.bak
cat <<EOT >> /etc/sysconfig/httpd
# Needed for mapserv in /var/www/cgi-bin
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib64
export LD_LIBRARY_PATH
EOT
cd ../..
# Required to install the netCDF4 python module
echo "Need to sudo to install hdf5 packages..."
sudo yum -y install hdf5 hdf5-devel
if [ $? -ne 0 ] ; then
echo "Exiting $0"
exit 1
fi
# Required to install the netCDF4 python module
wget ftp://ftp.unidata.ucar.edu/pub/netcdf/netcdf-4.3.3.tar.gz
tar -xzf netcdf-4.3.3.tar.gz
cd netcdf-4.3.3
./configure --enable-hl --enable-shared
make; sudo make install
cd ..
# Required for plotting basemap in LRAUV plots
wget 'http://sourceforge.net/projects/matplotlib/files/matplotlib-toolkits/basemap-1.0.7/basemap-1.0.7.tar.gz'
tar -xzf basemap-1.0.7.tar.gz
cd basemap-1.0.7/geos-3.3.3
export GEOS_DIR=/usr/local
./configure --prefix=/usr/local
make; sudo make install
cd ..
python setup.py install
cd ..
echo Build database for locate command
updatedb
echo Configure and start services
/usr/pgsql-9.4/bin/postgresql94-setup initdb
/usr/bin/systemctl enable postgresql-9.4
/usr/bin/systemctl start postgresql-9.4
/sbin/chkconfig rabbitmq-server on
/sbin/service rabbitmq-server start
rabbitmqctl add_user stoqs stoqs
rabbitmqctl add_vhost stoqs
rabbitmqctl set_permissions -p stoqs stoqs ".*" ".*" ".*"
/usr/bin/systemctl enable httpd.service
/usr/bin/systemctl start httpd.service
/usr/bin/systemctl enable memcached.service
/usr/bin/systemctl start memcached.service
echo Modify pg_hba.conf
mv -f /var/lib/pgsql/9.4/data/pg_hba.conf /var/lib/pgsql/9.4/data/pg_hba.conf.bak
cat <<EOT > /var/lib/pgsql/9.4/data/pg_hba.conf
# Allow user/password login
host all stoqsadm 127.0.0.1/32 md5
host all stoqsadm 10.0.2.0/24 md5
host all vagrant 127.0.0.1/32 trust
local all all trust
# Allow root to login as postgres (as travis-ci allows) - See also pg_ident.conf
local all all peer map=root_as_others
host all all 127.0.0.1/32 ident map=root_as_others
EOT
cat /var/lib/pgsql/9.4/data/pg_hba.conf.bak >> /var/lib/pgsql/9.4/data/pg_hba.conf
cp /var/lib/pgsql/9.4/data/pg_ident.conf /var/lib/pgsql/9.4/data/pg_ident.conf.bak
echo "root_as_others root postgres" >> /var/lib/pgsql/9.4/data/pg_ident.conf
su - postgres -c 'createuser -s $USER'
su - postgres -c "/usr/pgsql-9.4/bin/pg_ctl -D /var/lib/pgsql/9.4/data -l logfile start"
echo Create postgis database and restart postgresql-9.4
su - postgres -c "createdb postgis"
su - postgres -c "createlang plpgsql postgis"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/postgis.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/spatial_ref_sys.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/postgis_comments.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/rtpostgis.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/raster_comments.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/topology.sql"
su - postgres -c "psql -d postgis -f /usr/pgsql-9.4/share/contrib/postgis-2.1/topology_comments.sql"
su - postgres -c "psql -c \"CREATE DATABASE template_postgis WITH TEMPLATE postgis;\""
su - postgres -c "psql -c \"CREATE USER vagrant LOGIN PASSWORD 'vagrant';\""
su - postgres -c "psql -c \"ALTER ROLE vagrant SUPERUSER;\""
/usr/bin/systemctl restart postgresql-9.4
cd ..
echo Modifying local firewall to allow incoming connections on ports 80 and 8000
firewall-cmd --zone=public --add-port=8000/tcp --permanent
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload
echo Configuring vim edit environment
cd /home/$USER
cat <<EOT > .vimrc
:set tabstop=4
:set expandtab
:set shiftwidth=4
EOT
echo Cloning STOQS repo from $GIT_REPO_URL
echo "(See CONTRIBUTING.md for how to clone from your fork so that you can share your contributions.)"
mkdir dev && cd dev
git clone $GIT_REPO_URL stoqsgit
cd stoqsgit
export PATH="/usr/local/bin:$PATH"
virtualenv venv-stoqs
echo Installing Pyhton modules for a development system
source venv-stoqs/bin/activate
./setup.sh
echo Giving user $USER ownership of everything in /home/$USER
chown -R $USER /home/$USER
echo Provisioning and setup have finished. You should now test this installation with:
echo ---------------------------------------------------------------------------------
echo vagrant ssh -- -X
echo "cd ~/dev/stoqsgit && source venv-stoqs/bin/activate"
echo export DATABASE_URL=postgis://stoqsadm:CHANGEME@127.0.0.1:5432/stoqs
echo ./test.sh CHANGEME