forked from mattias-ohlsson/gitlab-installer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgitlab-install-el5.sh
executable file
·341 lines (243 loc) · 8.07 KB
/
gitlab-install-el5.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
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
#!/bin/bash
# Installer for GitLab on RHEL 5 (Red Hat Enterprise Linux and CentOS)
#
# Only run this on a clean machine. I take no responsibility for anything.
#
# Submit issues here: github.com/mattias-ohlsson/gitlab-installer
# Exit on error
set -e
# Define the database type (sqlite or mysql (default))
export GL_DATABASE_TYPE=mysql
# Define the public hostname
export GL_HOSTNAME=$HOSTNAME
# Define gitlab installation root
export GL_INSTALL_ROOT=/var/www/gitlabhq
baseurl=http://dl.atrpms.net/el$releasever-$basearch/atrpms/testing
# Install from this GitLab branch
export GL_INSTALL_BRANCH=stable
# Define the version of ruby the environment that we are installing for
export RUBY_VERSION=ruby-1.9.2-p290
# Define the rails environment that we are installing for
export RAILS_ENV=production
# Define MySQL root password (we need it if we want mysql)
MYSQL_ROOT_PW=$(cat /dev/urandom | tr -cd [:alnum:] | head -c ${1:-16})
die()
{
# $1 - the exit code
# $2 $... - the message string
retcode=$1
shift
printf >&2 "%s\n" "$@"
exit $retcode
}
echo "### Check OS (we check if the kernel release contains el5)"
uname -r | grep "el5" || die 1 "Not RHEL or CentOS"
echo "### Check if we are root"
[[ $EUID -eq 0 ]] || die 1 "This script must be run as root"
echo "### Configure SELinux"
# Disable SELinux
sed -i 's/SELINUX=enforcing/SELINUX=permissive/g' /etc/selinux/config
# Turn off SELinux in this session
setenforce 0
echo "### Installing packages"
# Install epel-release
rpm -Uvh http://mirrors.kernel.org/fedora-epel/5/i386/epel-release-5-4.noarch.rpm
# Modified list from gitlabhq
yum install -y \
make \
libtool \
openssh-clients \
gcc \
libxml2 \
libxml2-devel \
libxslt \
libxslt-devel \
python-devel \
wget \
readline-devel \
ncurses-devel \
gdbm-devel \
glibc-devel \
tcl-devel \
openssl-devel \
db4-devel \
byacc \
httpd \
gcc-c++ \
curl-devel \
openssl-devel \
zlib-devel \
httpd-devel \
apr-devel \
apr-util-devel \
libicu-devel \
gitolite \
git \
redis \
sudo \
mysql-devel \
postgresql-devel
# Install sqlite-devel from atrpms (sqlite > 3.3 is not provided by epel or centos)
rpm -Uvh http://dl.atrpms.net/el5-$(uname -i)/atrpms/testing/sqlite-3.6.20-1.el5.$(uname -i).rpm
rpm -Uvh http://dl.atrpms.net/el5-$(uname -i)/atrpms/testing/sqlite-devel-3.6.20-1.el5.$(uname -i).rpm
echo "### Install and start postfix"
# Install postfix
yum install -y postfix
# Start postfix
service postfix start
echo "### Create the git user and keys"
# Create the git user
/usr/sbin/adduser -r -m --shell /bin/bash --comment 'git version control' git
# Create keys as the git user
su - git -c 'ssh-keygen -q -N "" -t rsa -f ~/.ssh/id_rsa'
echo "### Set up Gitolite"
# Run the installer as the git user
su - git -c "gl-setup -q /home/git/.ssh/id_rsa.pub"
# Change the umask (see whe gitlab wiki)
sed -i 's/0077/0007/g' /home/git/.gitolite.rc
# Change permissions on repositories and home (group access)
chmod 750 /home/git
chmod 770 /home/git/repositories
echo "### Set up Gitolite access for Apache"
# Shoplifted from github.com/gitlabhq/gitlabhq_install
# Create the ssh folder
mkdir /var/www/.ssh
# Use ssh-keyscan to skip host verification problem
# add types (-t) to fix this error: localhost doesn't support ssh1
ssh-keyscan -t rsa1,rsa,dsa localhost > /var/www/.ssh/known_hosts
# Copy keys from the git user
cp /home/git/.ssh/id_rsa* /var/www/.ssh/
# Apache will take ownership
chown apache:apache -R /var/www/.ssh
# Add the git group to apache
usermod -G git apache
echo "### Installing RVM and Ruby"
# rvm requirements tell us to do this
yum install -y gcc-c++ patch readline readline-devel zlib zlib-devel libyaml-devel libffi-devel openssl-devel make bzip2
# Requirements for gem install capybara-webkit
# install devel packages for qt and qtwebkit from ATrpms
cat > /etc/yum.repos.d/atrpms-testing.repo << EOF
[atrpms-testing]
name=EL \$releasever - \$basearch - ATrpms
baseurl=http://dl.atrpms.net/el\$releasever-\$basearch/atrpms/testing
gpgkey=http://ATrpms.net/RPM-GPG-KEY.atrpms
gpgcheck=1
enabled=0
EOF
rpm --import http://packages.atrpms.net/RPM-GPG-KEY.atrpms
yum remove libX11 -y
yum --enablerepo=atrpms-testing install qt47-webkit-devel -y
yum --enablerepo=atrpms-testing update sqlite -y
export QMAKE=/usr/bin/qmake-qt47
# Instructions from https://rvm.io
curl -L get.rvm.io | bash -s stable
# Load RVM
source /etc/profile.d/rvm.sh
# Install Ruby (use command to force non-interactive mode)
command rvm install $RUBY_VERSION
rvm use $RUBY_VERSION
# Install core gems
gem install rails passenger rake bundler grit --no-rdoc --no-ri
echo "### Install pip and pygments"
yum install -y python-pip
pip-python install pygments
echo "### Install GitLab"
# Download code
cd /var/www && git clone -b $GL_INSTALL_BRANCH https://github.com/gitlabhq/gitlabhq.git
# Install GitLab
cd $GL_INSTALL_ROOT && bundle install
echo "### Install Passenger Apache module"
# Run the installer
rvm all do passenger-install-apache2-module -a
echo "### Start and configure redis"
# Start redis
/etc/init.d/redis start
# Automatically start redis
chkconfig redis on
echo "### Configure GitLab"
# Go to install root
cd $GL_INSTALL_ROOT
# Rename config files
cp config/gitlab.yml.example config/gitlab.yml
# Change gitlabhq hostname to GL_HOSTNAME
sed -i "s/ host: localhost/ host: $GL_HOSTNAME/g" config/gitlab.yml
# Change the from email address
sed -i "s/from: notify@localhost/from: notify@$GL_HOSTNAME/g" config/gitlab.yml
# Check database type
if [ "$GL_DATABASE_TYPE" = "sqlite" ]; then
# Use SQLite
echo "... using sqlite"
cp config/database.yml.sqlite config/database.yml
else
# Use MySQL
echo "... using mysql"
# Install mysql-server
yum install -y mysql-server
# Turn on autostart
chkconfig mysqld on
# Start mysqld
service mysqld start
# Copy congiguration
cp config/database.yml.example config/database.yml
# Set MySQL root password in configuration file
sed -i "s/secure password/$MYSQL_ROOT_PW/g" config/database.yml
# Set MySQL root password in MySQL
echo "UPDATE mysql.user SET Password=PASSWORD('$MYSQL_ROOT_PW') WHERE User='root'; FLUSH PRIVILEGES;" | mysql -u root
fi
# Setup DB
rvm all do rake db:setup RAILS_ENV=production
rvm all do rake db:seed_fu RAILS_ENV=production
# Setup gitlab hooks
cp ./lib/hooks/post-receive /home/git/.gitolite/hooks/common/
chown git:git /home/git/.gitolite/hooks/common/post-receive
echo "### Configure Apache"
# Get the passenger version
export PASSENGER_VERSION=`find /usr/local/rvm/gems/$RUBY_VERSION/gems -type d -name "passenger*" | cut -d '-' -f 4`
# Create a config file for gitlab
cat > /etc/httpd/conf.d/gitlabhq.conf << EOF
<VirtualHost *:80>
ServerName $GL_HOSTNAME
DocumentRoot $GL_INSTALL_ROOT/public
LoadModule passenger_module /usr/local/rvm/gems/$RUBY_VERSION/gems/passenger-$PASSENGER_VERSION/ext/apache2/mod_passenger.so
PassengerRoot /usr/local/rvm/gems/$RUBY_VERSION/gems/passenger-$PASSENGER_VERSION
PassengerRuby /usr/local/rvm/wrappers/$RUBY_VERSION/ruby
<Directory $GL_INSTALL_ROOT/public>
AllowOverride all
Options -MultiViews
</Directory>
</VirtualHost>
EOF
# Enable virtual hosts in httpd
cat > /etc/httpd/conf.d/enable-virtual-hosts.conf << EOF
NameVirtualHost *:80
EOF
# Ensure that apache owns all of gitlabhq
chown -R apache:apache $GL_INSTALL_ROOT
# Apache needs access to gems (?)
chown apache:root -R /usr/local/rvm/gems/
echo "### Configure iptables"
# Open port 80
iptables -I INPUT -p tcp -m tcp --dport 80 -j ACCEPT
# Save iptables
service iptables save
echo "### Start Apache"
# Start on boot
chkconfig httpd on
# Start Apache
service httpd start
echo "### Done ###"
echo "#"
if [ "$GL_DATABASE_TYPE" != "sqlite" ]; then
# Print MySQL root password instructions
echo "# You have your MySQL root password in this file:"
echo "# $GL_INSTALL_ROOT/config/database.yml"
echo "#"
fi
echo "# Point your browser to:"
echo "# http://$GL_HOSTNAME (or: http://<host-ip>)"
echo "# Default admin username: [email protected]"
echo "# Default admin password: 5iveL!fe"
echo "#"
echo "# Flattr me if you like this! https://flattr.com/profile/mattiasohlsson"
echo "###"