2013-08-27 07:30:06 -04:00
|
|
|
#! /bin/sh
|
2013-04-22 06:44:09 -04:00
|
|
|
|
|
|
|
# GITLAB
|
|
|
|
# Maintainer: @randx
|
2013-08-27 07:30:06 -04:00
|
|
|
# Authors: rovanion.luckey@gmail.com, @randx
|
2013-04-22 06:44:09 -04:00
|
|
|
|
|
|
|
### BEGIN INIT INFO
|
|
|
|
# Provides: gitlab
|
|
|
|
# Required-Start: $local_fs $remote_fs $network $syslog redis-server
|
|
|
|
# Required-Stop: $local_fs $remote_fs $network $syslog
|
|
|
|
# Default-Start: 2 3 4 5
|
|
|
|
# Default-Stop: 0 1 6
|
|
|
|
# Short-Description: GitLab git repository management
|
|
|
|
# Description: GitLab git repository management
|
|
|
|
### END INIT INFO
|
|
|
|
|
2013-12-09 08:05:50 -05:00
|
|
|
|
|
|
|
###
|
|
|
|
# DO NOT EDIT THIS FILE!
|
|
|
|
# This file will be overwritten on update.
|
|
|
|
# Instead add/change your variables in /etc/default/gitlab
|
2014-01-08 17:54:03 -05:00
|
|
|
# An example defaults file can be found in lib/support/init.d/gitlab.default.example
|
2013-12-09 08:05:50 -05:00
|
|
|
###
|
|
|
|
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
### Environment variables
|
|
|
|
RAILS_ENV="production"
|
2013-04-22 06:44:09 -04:00
|
|
|
|
2013-12-09 08:05:50 -05:00
|
|
|
# Script variable names should be lower-case not to conflict with
|
|
|
|
# internal /bin/sh variables such as PATH, EDITOR or SHELL.
|
2013-08-28 07:16:34 -04:00
|
|
|
app_user="git"
|
2013-10-24 08:55:40 -04:00
|
|
|
app_root="/home/$app_user/gitlab"
|
2013-08-27 07:30:06 -04:00
|
|
|
pid_path="$app_root/tmp/pids"
|
|
|
|
socket_path="$app_root/tmp/sockets"
|
|
|
|
web_server_pid_path="$pid_path/unicorn.pid"
|
|
|
|
sidekiq_pid_path="$pid_path/sidekiq.pid"
|
|
|
|
|
2013-10-29 12:21:54 -04:00
|
|
|
# Read configuration variable file if it is present
|
|
|
|
test -f /etc/default/gitlab && . /etc/default/gitlab
|
2013-08-27 07:30:06 -04:00
|
|
|
|
|
|
|
# Switch to the app_user if it is not he/she who is running the script.
|
|
|
|
if [ "$USER" != "$app_user" ]; then
|
2013-09-06 18:53:10 -04:00
|
|
|
sudo -u "$app_user" -H -i $0 "$@"; exit;
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
|
2013-12-09 08:05:50 -05:00
|
|
|
# Switch to the gitlab path, exit on failure.
|
2013-08-27 07:30:06 -04:00
|
|
|
if ! cd "$app_root" ; then
|
|
|
|
echo "Failed to cd into $app_root, exiting!"; exit 1
|
|
|
|
fi
|
|
|
|
|
2013-12-09 08:05:50 -05:00
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
### Init Script functions
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Gets the pids from the files
|
2013-08-27 07:30:06 -04:00
|
|
|
check_pids(){
|
|
|
|
if ! mkdir -p "$pid_path"; then
|
|
|
|
echo "Could not create the path $pid_path needed to store the pids."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
# If there exists a file which should hold the value of the Unicorn pid: read it.
|
|
|
|
if [ -f "$web_server_pid_path" ]; then
|
|
|
|
wpid=$(cat "$web_server_pid_path")
|
|
|
|
else
|
|
|
|
wpid=0
|
|
|
|
fi
|
|
|
|
if [ -f "$sidekiq_pid_path" ]; then
|
|
|
|
spid=$(cat "$sidekiq_pid_path")
|
2013-04-22 06:44:09 -04:00
|
|
|
else
|
2013-08-27 07:30:06 -04:00
|
|
|
spid=0
|
2013-04-22 06:44:09 -04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Called when we have started the two processes and are waiting for their pid files.
|
|
|
|
wait_for_pids(){
|
|
|
|
# We are sleeping a bit here mostly because sidekiq is slow at writing it's pid
|
|
|
|
i=0;
|
|
|
|
while [ ! -f $web_server_pid_path -o ! -f $sidekiq_pid_path ]; do
|
|
|
|
sleep 0.1;
|
|
|
|
i=$((i+1))
|
|
|
|
if [ $((i%10)) = 0 ]; then
|
|
|
|
echo -n "."
|
|
|
|
elif [ $((i)) = 301 ]; then
|
|
|
|
echo "Waited 30s for the processes to write their pids, something probably went wrong."
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
echo
|
|
|
|
}
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
# We use the pids in so many parts of the script it makes sense to always check them.
|
|
|
|
# Only after start() is run should the pids change. Sidekiq sets it's own pid.
|
|
|
|
check_pids
|
|
|
|
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Checks whether the different parts of the service are already running or not.
|
2013-08-27 07:30:06 -04:00
|
|
|
check_status(){
|
|
|
|
check_pids
|
|
|
|
# If the web server is running kill -0 $wpid returns true, or rather 0.
|
|
|
|
# Checks of *_status should only check for == 0 or != 0, never anything else.
|
|
|
|
if [ $wpid -ne 0 ]; then
|
|
|
|
kill -0 "$wpid" 2>/dev/null
|
|
|
|
web_status="$?"
|
2013-08-28 07:16:34 -04:00
|
|
|
else
|
|
|
|
web_status="-1"
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
if [ $spid -ne 0 ]; then
|
|
|
|
kill -0 "$spid" 2>/dev/null
|
|
|
|
sidekiq_status="$?"
|
2013-08-28 07:16:34 -04:00
|
|
|
else
|
|
|
|
sidekiq_status="-1"
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
2013-10-25 05:26:22 -04:00
|
|
|
if [ $web_status = 0 -a $sidekiq_status = 0 ]; then
|
|
|
|
gitlab_status=0
|
|
|
|
else
|
|
|
|
# http://refspecs.linuxbase.org/LSB_4.1.0/LSB-Core-generic/LSB-Core-generic/iniscrptact.html
|
|
|
|
# code 3 means 'program is not running'
|
|
|
|
gitlab_status=3
|
|
|
|
fi
|
2013-05-09 01:37:56 -04:00
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Check for stale pids and remove them if necessary.
|
2013-08-27 07:30:06 -04:00
|
|
|
check_stale_pids(){
|
|
|
|
check_status
|
|
|
|
# If there is a pid it is something else than 0, the service is running if
|
|
|
|
# *_status is == 0.
|
|
|
|
if [ "$wpid" != "0" -a "$web_status" != "0" ]; then
|
2013-08-28 07:16:34 -04:00
|
|
|
echo "Removing stale Unicorn web server pid. This is most likely caused by the web server crashing the last time it ran."
|
|
|
|
if ! rm "$web_server_pid_path"; then
|
2013-10-24 08:55:40 -04:00
|
|
|
echo "Unable to remove stale pid, exiting."
|
2013-08-28 07:16:34 -04:00
|
|
|
exit 1
|
|
|
|
fi
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
if [ "$spid" != "0" -a "$sidekiq_status" != "0" ]; then
|
2013-08-28 07:16:34 -04:00
|
|
|
echo "Removing stale Sidekiq web server pid. This is most likely caused by the Sidekiq crashing the last time it ran."
|
|
|
|
if ! rm "$sidekiq_pid_path"; then
|
|
|
|
echo "Unable to remove stale pid, exiting"
|
|
|
|
exit 1
|
|
|
|
fi
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## If no parts of the service is running, bail out.
|
2013-08-28 06:38:41 -04:00
|
|
|
exit_if_not_running(){
|
2013-08-27 07:30:06 -04:00
|
|
|
check_stale_pids
|
|
|
|
if [ "$web_status" != "0" -a "$sidekiq_status" != "0" ]; then
|
|
|
|
echo "GitLab is not running."
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Starts Unicorn and Sidekiq if they're not running.
|
2013-04-22 06:44:09 -04:00
|
|
|
start() {
|
2013-08-27 07:30:06 -04:00
|
|
|
check_stale_pids
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
if [ "$web_status" != "0" -a "$sidekiq_status" != "0" ]; then
|
|
|
|
echo -n "Starting both the GitLab Unicorn and Sidekiq"
|
|
|
|
elif [ "$web_status" != "0" ]; then
|
|
|
|
echo -n "Starting GitLab Sidekiq"
|
|
|
|
elif [ "$sidekiq_status" != "0" ]; then
|
|
|
|
echo -n "Starting GitLab Unicorn"
|
|
|
|
fi
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
# Then check if the service is running. If it is: don't start again.
|
|
|
|
if [ "$web_status" = "0" ]; then
|
|
|
|
echo "The Unicorn web server already running with pid $wpid, not restarting."
|
2013-04-22 06:44:09 -04:00
|
|
|
else
|
2013-08-27 07:30:06 -04:00
|
|
|
# Remove old socket if it exists
|
2013-08-27 09:04:20 -04:00
|
|
|
rm -f "$socket_path"/gitlab.socket 2>/dev/null
|
2013-10-24 08:55:40 -04:00
|
|
|
# Start the web server
|
|
|
|
RAILS_ENV=$RAILS_ENV script/web start &
|
2013-04-22 06:44:09 -04:00
|
|
|
fi
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
# If sidekiq is already running, don't start it again.
|
|
|
|
if [ "$sidekiq_status" = "0" ]; then
|
|
|
|
echo "The Sidekiq job dispatcher is already running with pid $spid, not restarting"
|
2013-04-22 06:44:09 -04:00
|
|
|
else
|
2013-10-24 08:55:40 -04:00
|
|
|
RAILS_ENV=$RAILS_ENV script/background_jobs start &
|
2013-04-22 06:44:09 -04:00
|
|
|
fi
|
2013-08-27 07:30:06 -04:00
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
# Wait for the pids to be planted
|
|
|
|
wait_for_pids
|
2013-08-27 07:30:06 -04:00
|
|
|
# Finally check the status to tell wether or not GitLab is running
|
2013-10-24 08:55:40 -04:00
|
|
|
print_status
|
2013-04-22 06:44:09 -04:00
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Asks the Unicorn and the Sidekiq if they would be so kind as to stop, if not kills them.
|
2013-08-27 07:30:06 -04:00
|
|
|
stop() {
|
2013-08-28 06:38:41 -04:00
|
|
|
exit_if_not_running
|
2013-10-24 08:55:40 -04:00
|
|
|
|
|
|
|
if [ "$web_status" = "0" -a "$sidekiq_status" = "0" ]; then
|
|
|
|
echo -n "Shutting down both Unicorn and Sidekiq"
|
|
|
|
elif [ "$web_status" = "0" ]; then
|
|
|
|
echo -n "Shutting down Sidekiq"
|
|
|
|
elif [ "$sidekiq_status" = "0" ]; then
|
|
|
|
echo -n "Shutting down Unicorn"
|
|
|
|
fi
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
# If the Unicorn web server is running, tell it to stop;
|
|
|
|
if [ "$web_status" = "0" ]; then
|
2013-10-24 08:55:40 -04:00
|
|
|
RAILS_ENV=$RAILS_ENV script/web stop
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
# And do the same thing for the Sidekiq.
|
|
|
|
if [ "$sidekiq_status" = "0" ]; then
|
2013-10-09 10:45:32 -04:00
|
|
|
RAILS_ENV=$RAILS_ENV script/background_jobs stop
|
2013-04-22 06:44:09 -04:00
|
|
|
fi
|
2013-08-27 07:30:06 -04:00
|
|
|
|
|
|
|
# If something needs to be stopped, lets wait for it to stop. Never use SIGKILL in a script.
|
2013-10-24 08:55:40 -04:00
|
|
|
while [ "$web_status" = "0" -o "$sidekiq_status" = "0" ]; do
|
2013-08-27 07:30:06 -04:00
|
|
|
sleep 1
|
|
|
|
check_status
|
2013-10-24 08:55:40 -04:00
|
|
|
printf "."
|
|
|
|
if [ "$web_status" != "0" -a "$sidekiq_status" != "0" ]; then
|
2013-08-27 07:30:06 -04:00
|
|
|
printf "\n"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2013-10-24 08:55:40 -04:00
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
sleep 1
|
|
|
|
# Cleaning up unused pids
|
|
|
|
rm "$web_server_pid_path" 2>/dev/null
|
|
|
|
# rm "$sidekiq_pid_path" # Sidekiq seems to be cleaning up it's own pid.
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
print_status
|
2013-04-22 06:44:09 -04:00
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Prints the status of GitLab and it's components.
|
|
|
|
print_status() {
|
2013-08-29 17:26:08 -04:00
|
|
|
check_status
|
|
|
|
if [ "$web_status" != "0" -a "$sidekiq_status" != "0" ]; then
|
|
|
|
echo "GitLab is not running."
|
|
|
|
return
|
|
|
|
fi
|
2013-08-27 07:30:06 -04:00
|
|
|
if [ "$web_status" = "0" ]; then
|
2013-10-24 08:55:40 -04:00
|
|
|
echo "The GitLab Unicorn web server with pid $wpid is running."
|
2013-04-22 06:44:09 -04:00
|
|
|
else
|
2013-10-24 08:55:40 -04:00
|
|
|
printf "The GitLab Unicorn web server is \033[31mnot running\033[0m.\n"
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
|
|
|
if [ "$sidekiq_status" = "0" ]; then
|
|
|
|
echo "The GitLab Sidekiq job dispatcher with pid $spid is running."
|
|
|
|
else
|
|
|
|
printf "The GitLab Sidekiq job dispatcher is \033[31mnot running\033[0m.\n"
|
|
|
|
fi
|
|
|
|
if [ "$web_status" = "0" -a "$sidekiq_status" = "0" ]; then
|
2013-09-26 14:01:22 -04:00
|
|
|
printf "GitLab and all its components are \033[32mup and running\033[0m.\n"
|
2013-04-22 06:44:09 -04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Tells unicorn to reload it's config and Sidekiq to restart
|
2013-08-27 07:30:06 -04:00
|
|
|
reload(){
|
2013-08-28 06:38:41 -04:00
|
|
|
exit_if_not_running
|
2013-08-27 07:30:06 -04:00
|
|
|
if [ "$wpid" = "0" ];then
|
2013-08-29 17:26:08 -04:00
|
|
|
echo "The GitLab Unicorn Web server is not running thus its configuration can't be reloaded."
|
2013-04-22 06:44:09 -04:00
|
|
|
exit 1
|
2013-08-27 07:30:06 -04:00
|
|
|
fi
|
2013-08-28 06:38:41 -04:00
|
|
|
printf "Reloading GitLab Unicorn configuration... "
|
2013-10-09 10:45:32 -04:00
|
|
|
RAILS_ENV=$RAILS_ENV script/web reload
|
2013-08-27 07:30:06 -04:00
|
|
|
echo "Done."
|
2013-08-29 17:26:08 -04:00
|
|
|
echo "Restarting GitLab Sidekiq since it isn't capable of reloading its config..."
|
2013-10-09 10:45:32 -04:00
|
|
|
RAILS_ENV=$RAILS_ENV script/background_jobs restart
|
2013-10-24 08:55:40 -04:00
|
|
|
|
|
|
|
wait_for_pids
|
|
|
|
print_status
|
2013-08-27 07:30:06 -04:00
|
|
|
}
|
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
## Restarts Sidekiq and Unicorn.
|
2013-08-29 17:26:08 -04:00
|
|
|
restart(){
|
|
|
|
check_status
|
|
|
|
if [ "$web_status" = "0" -o "$sidekiq_status" = "0" ]; then
|
|
|
|
stop
|
|
|
|
fi
|
|
|
|
start
|
|
|
|
}
|
|
|
|
|
2013-08-27 07:30:06 -04:00
|
|
|
|
2013-10-24 08:55:40 -04:00
|
|
|
### Finally the input handling.
|
2013-04-22 06:44:09 -04:00
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
start)
|
|
|
|
start
|
|
|
|
;;
|
|
|
|
stop)
|
|
|
|
stop
|
|
|
|
;;
|
|
|
|
restart)
|
2013-08-29 17:26:08 -04:00
|
|
|
restart
|
2013-04-22 06:44:09 -04:00
|
|
|
;;
|
|
|
|
reload|force-reload)
|
2013-08-27 07:30:06 -04:00
|
|
|
reload
|
2013-04-22 06:44:09 -04:00
|
|
|
;;
|
|
|
|
status)
|
2013-10-24 08:55:40 -04:00
|
|
|
print_status
|
2013-10-25 05:26:22 -04:00
|
|
|
exit $gitlab_status
|
2013-04-22 06:44:09 -04:00
|
|
|
;;
|
|
|
|
*)
|
2013-08-27 07:30:06 -04:00
|
|
|
echo "Usage: service gitlab {start|stop|restart|reload|status}"
|
2013-04-22 06:44:09 -04:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2013-08-27 09:04:20 -04:00
|
|
|
exit
|