diff options
| author | Jacob Vosmaer <jacob@gitlab.com> | 2017-03-14 17:48:32 +0100 | 
|---|---|---|
| committer | Jacob Vosmaer <jacob@gitlab.com> | 2017-03-21 14:55:41 +0100 | 
| commit | 275b7797c1fa104e4a0b94823ed48ec7157a50a9 (patch) | |
| tree | 66119818e2db473e2cbbeeafb50a33ae7b89f108 | |
| parent | 49a9c2fbefde96e428eae72a76ceefeac9dbcad4 (diff) | |
| download | gitlab-ce-275b7797c1fa104e4a0b94823ed48ec7157a50a9.tar.gz | |
Add gitaly source installation instructions
| -rwxr-xr-x | bin/with_env | 16 | ||||
| -rw-r--r-- | config/gitlab.yml.example | 2 | ||||
| -rw-r--r-- | doc/install/installation.md | 27 | ||||
| -rw-r--r-- | doc/update/8.17-to-9.0.md | 14 | ||||
| -rwxr-xr-x | lib/support/init.d/gitlab | 67 | ||||
| -rw-r--r-- | lib/support/init.d/gitlab.default.example | 4 | ||||
| -rw-r--r-- | tmp/sockets/private/.gitkeep | 0 | 
7 files changed, 118 insertions, 12 deletions
| diff --git a/bin/with_env b/bin/with_env new file mode 100755 index 00000000000..e678fa2f0cc --- /dev/null +++ b/bin/with_env @@ -0,0 +1,16 @@ +#!/bin/sh +# Usage: with_env ENV_FILE COMMAND [ARGS...] +# +# This script lets you modify the environment of an executable before +# launching it. It uses an 'env file' which must contain lines like +# 'MY_VARIABLE="my value"'. +# +env_file=$1 +shift + +# Use set -a to export all variables defined in env_file. +set -a +. "${env_file}" +set +a + +exec "$@" diff --git a/config/gitlab.yml.example b/config/gitlab.yml.example index ba7f6773985..3747baf4c3b 100644 --- a/config/gitlab.yml.example +++ b/config/gitlab.yml.example @@ -450,7 +450,7 @@ production: &base      # This setting is obsolete because we expect it to be moved under      # repositories/storages in GitLab 9.1.      # -    # socket_path: tmp/sockets/gitaly.socket +    # socket_path: tmp/sockets/private/gitaly.socket    #    # 4. Advanced settings diff --git a/doc/install/installation.md b/doc/install/installation.md index 177e1a9378b..32297c9c8f0 100644 --- a/doc/install/installation.md +++ b/doc/install/installation.md @@ -456,6 +456,33 @@ Make GitLab start on boot:      sudo update-rc.d gitlab defaults 21 +### Install Gitaly + +As of GitLab 9.0 Gitaly is an **optional** component. Its +configuration is expected to change in GitLab 9.1. It is OK to wait +with setting up Gitaly until you upgrade to GitLab 9.1 or later. + +    # Fetch Gitaly source with Git and compile with Go +    sudo -u git -H bundle exec rake "gitlab:gitaly:install[/home/git/gitaly]" RAILS_ENV=production + +    # Restrict Gitaly socket access +    sudo chmod 0700 /home/git/gitlab/tmp/sockets/private +    sudo chown git /home/git/gitlab/tmp/sockets/private + +    # Configure Gitaly +    echo 'GITALY_SOCKET_PATH=/home/git/gitlab/tmp/sockets/private/gitaly.socket' | \ +      sudo -u git tee -a /home/git/gitaly/env + +    # Enable Gitaly in the init script +    echo 'gitaly_enabled=true' | sudo tee -a /etc/default/gitlab + +Next, edit `/home/git/gitlab/config/gitlab.yml` and make sure `socket_path` in +the `gitaly:` section is uncommented. + +    # <- gitlab.yml indentation starts here +      gitaly: +        socket_path: tmp/sockets/private/gitaly.socket +  ### Setup Logrotate      sudo cp lib/support/logrotate/gitlab /etc/logrotate.d/gitlab diff --git a/doc/update/8.17-to-9.0.md b/doc/update/8.17-to-9.0.md index b7ba970031c..140d3684c56 100644 --- a/doc/update/8.17-to-9.0.md +++ b/doc/update/8.17-to-9.0.md @@ -145,7 +145,15 @@ sudo -u git -H git fetch --all --tags  sudo -u git -H git checkout v5.0.0  ``` -### 9. Update configuration files +### 9. Optional: install Gitaly + +Gitaly is still an optional component of GitLab. If you want to save time +during your 9.0 upgrade **you can skip this step**. + +If you do want to set up Gitaly in GitLab 9.0 then follow [Gitaly section of the installation +guide](https://gitlab.com/gitlab-org/gitlab-ce/blob/9-0-stable/doc/install/installation.md#install-gitaly). + +### 10. Update configuration files  #### New configuration options for `gitlab.yml` @@ -282,14 +290,14 @@ For Ubuntu 16.04.1 LTS:  sudo systemctl daemon-reload  ``` -### 10. Start application +### 11. Start application  ```bash  sudo service gitlab start  sudo service nginx restart  ``` -### 11. Check application status +### 12. Check application status  Check if GitLab and its environment are configured correctly: diff --git a/lib/support/init.d/gitlab b/lib/support/init.d/gitlab index 5fd7f0f98bd..09e121e5120 100755 --- a/lib/support/init.d/gitlab +++ b/lib/support/init.d/gitlab @@ -48,6 +48,10 @@ gitlab_pages_pid_path="$pid_path/gitlab-pages.pid"  gitlab_pages_options="-pages-domain example.com -pages-root $app_root/shared/pages -listen-proxy 127.0.0.1:8090"  gitlab_pages_log="$app_root/log/gitlab-pages.log"  shell_path="/bin/bash" +gitaly_enabled=false +gitaly_dir=$(cd $app_root/../gitaly 2> /dev/null && pwd) +gitaly_pid_path="$pid_path/gitaly.pid" +gitaly_log="$app_root/log/gitaly.log"  # Read configuration variable file if it is present  test -f /etc/default/gitlab && . /etc/default/gitlab @@ -101,13 +105,20 @@ check_pids(){        gppid=0      fi    fi +  if [ "$gitaly_enabled" = true ]; then +    if [ -f "$gitaly_pid_path" ]; then +      gapid=$(cat "$gitaly_pid_path") +    else +      gapid=0 +    fi +  fi  }  ## 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 its pid    i=0; -  while [ ! -f $web_server_pid_path ] || [ ! -f $sidekiq_pid_path ] || [ ! -f $gitlab_workhorse_pid_path ] || { [ "$mail_room_enabled" = true ] && [ ! -f $mail_room_pid_path ]; } || { [ "$gitlab_pages_enabled" = true ] && [ ! -f $gitlab_pages_pid_path ]; }; do +  while [ ! -f $web_server_pid_path ] || [ ! -f $sidekiq_pid_path ] || [ ! -f $gitlab_workhorse_pid_path ] || { [ "$mail_room_enabled" = true ] && [ ! -f $mail_room_pid_path ]; } || { [ "$gitlab_pages_enabled" = true ] && [ ! -f $gitlab_pages_pid_path ]; } || { [ "$gitaly_enabled" = true ] && [ ! -f $gitaly_pid_path ]; }; do      sleep 0.1;      i=$((i+1))      if [ $((i%10)) = 0 ]; then @@ -164,7 +175,15 @@ check_status(){        gitlab_pages_status="-1"      fi    fi -  if [ $web_status = 0 ] && [ $sidekiq_status = 0 ] && [ $gitlab_workhorse_status = 0 ] && { [ "$mail_room_enabled" != true ] || [ $mail_room_status = 0 ]; } && { [ "$gitlab_pages_enabled" != true ] || [ $gitlab_pages_status = 0 ]; }; then +  if [ "$gitaly_enabled" = true ]; then +    if [ $gapid -ne 0 ]; then +      kill -0 "$gapid" 2>/dev/null +      gitaly_status="$?" +    else +      gitaly_status="-1" +    fi +  fi +  if [ $web_status = 0 ] && [ $sidekiq_status = 0 ] && [ $gitlab_workhorse_status = 0 ] && { [ "$mail_room_enabled" != true ] || [ $mail_room_status = 0 ]; } && { [ "$gitlab_pages_enabled" != true ] || [ $gitlab_pages_status = 0 ]; } && { [ "$gitaly_enabled" != true ] || [ $gitaly_status = 0 ]; }; then      gitlab_status=0    else      # http://refspecs.linuxbase.org/LSB_4.1.0/LSB-Core-generic/LSB-Core-generic/iniscrptact.html @@ -213,12 +232,19 @@ check_stale_pids(){        exit 1      fi    fi +  if [ "$gitaly_enabled" = true ] && [ "$gapid" != "0" ] && [ "$gitaly_status" != "0" ]; then +    echo "Removing stale Gitaly pid. This is most likely caused by Gitaly crashing the last time it ran." +    if ! rm "$gitaly_pid_path"; then +      echo "Unable to remove stale pid, exiting" +      exit 1 +    fi +  fi  }  ## If no parts of the service is running, bail out.  exit_if_not_running(){    check_stale_pids -  if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; }; then +  if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; } && { [ "$gitaly_enabled" != true ] || [ "$gitaly_status" != "0" ]; }; then      echo "GitLab is not running."      exit    fi @@ -243,6 +269,9 @@ start_gitlab() {    if [ "$gitlab_pages_enabled" = true ] && [ "$gitlab_pages_status" != "0" ]; then      echo "Starting GitLab Pages"    fi +  if [ "$gitaly_enabled" = true ] && [ "$gitaly_status" != "0" ]; then +    echo "Starting Gitaly" +  fi    # Then check if the service is running. If it is: don't start again.    if [ "$web_status" = "0" ]; then @@ -292,6 +321,16 @@ start_gitlab() {      fi    fi +  if [ "$gitaly_enabled" = true ]; then +    if [ "$gitaly_status" = "0" ]; then +      echo "Gitaly is already running with pid $gapid, not restarting" +    else +      $app_root/bin/daemon_with_pidfile $gitaly_pid_path \ +        $app_root/bin/with_env $gitaly_dir/env \ +          $gitaly_dir/gitaly >> $gitaly_log 2>&1 & +    fi +  fi +    # Wait for the pids to be planted    wait_for_pids    # Finally check the status to tell wether or not GitLab is running @@ -322,13 +361,17 @@ stop_gitlab() {      echo "Shutting down gitlab-pages"      kill -- $(cat $gitlab_pages_pid_path)    fi +  if [ "$gitaly_status" = "0" ]; then +    echo "Shutting down Gitaly" +    kill -- $(cat $gitaly_pid_path) +  fi    # If something needs to be stopped, lets wait for it to stop. Never use SIGKILL in a script. -  while [ "$web_status" = "0" ] || [ "$sidekiq_status" = "0" ] || [ "$gitlab_workhorse_status" = "0" ] || { [ "$mail_room_enabled" = true ] && [ "$mail_room_status" = "0" ]; } || { [ "$gitlab_pages_enabled" = true ] && [ "$gitlab_pages_status" = "0" ]; }; do +  while [ "$web_status" = "0" ] || [ "$sidekiq_status" = "0" ] || [ "$gitlab_workhorse_status" = "0" ] || { [ "$mail_room_enabled" = true ] && [ "$mail_room_status" = "0" ]; } || { [ "$gitlab_pages_enabled" = true ] && [ "$gitlab_pages_status" = "0" ]; } || { [ "$gitaly_enabled" = true ] && [ "$gitaly_status" = "0" ]; }; do      sleep 1      check_status      printf "." -    if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; }; then +    if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; } && { [ "$gitaly_enabled" != true ] || [ "$gitaly_status" != "0" ]; }; then        printf "\n"        break      fi @@ -343,6 +386,7 @@ stop_gitlab() {      rm "$mail_room_pid_path" 2>/dev/null    fi    rm -f "$gitlab_pages_pid_path" +  rm -f "$gitaly_pid_path"    print_status  } @@ -350,7 +394,7 @@ stop_gitlab() {  ## Prints the status of GitLab and its components.  print_status() {    check_status -  if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; }; then +  if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" != "0" ]; } && { [ "$gitaly_enabled" != true ] || [ "$gitaly_status" != "0" ]; }; then      echo "GitLab is not running."      return    fi @@ -383,7 +427,14 @@ print_status() {          printf "The GitLab Pages is \033[31mnot running\033[0m.\n"      fi    fi -  if [ "$web_status" = "0" ] && [ "$sidekiq_status" = "0" ] && [ "$gitlab_workhorse_status" = "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" = "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" = "0" ]; }; then +  if [ "$gitaly_enabled" = true ]; then +    if [ "$gitaly_status" = "0" ]; then +        echo "Gitaly with pid $gapid is running." +    else +        printf "Gitaly is \033[31mnot running\033[0m.\n" +    fi +  fi +  if [ "$web_status" = "0" ] && [ "$sidekiq_status" = "0" ] && [ "$gitlab_workhorse_status" = "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" = "0" ]; } && { [ "$gitlab_pages_enabled" != true ] || [ "$gitlab_pages_status" = "0" ]; } && { [ "$gitaly_enabled" != true ] || [ "$gitaly_status" = "0" ]; }; then      printf "GitLab and all its components are \033[32mup and running\033[0m.\n"    fi  } @@ -414,7 +465,7 @@ reload_gitlab(){  ## Restarts Sidekiq and Unicorn.  restart_gitlab(){    check_status -  if [ "$web_status" = "0" ] || [ "$sidekiq_status" = "0" ] || [ "$gitlab_workhorse" = "0" ] || { [ "$mail_room_enabled" = true ] && [ "$mail_room_status" = "0" ]; } || { [ "$gitlab_pages_enabled" = true ] && [ "$gitlab_pages_status" = "0" ]; }; then +  if [ "$web_status" = "0" ] || [ "$sidekiq_status" = "0" ] || [ "$gitlab_workhorse" = "0" ] || { [ "$mail_room_enabled" = true ] && [ "$mail_room_status" = "0" ]; } || { [ "$gitlab_pages_enabled" = true ] && [ "$gitlab_pages_status" = "0" ]; } || { [ "$gitaly_enabled" = true ] && [ "$gitaly_status" = "0" ]; }; then      stop_gitlab    fi    start_gitlab diff --git a/lib/support/init.d/gitlab.default.example b/lib/support/init.d/gitlab.default.example index f6642527639..9472c3c992f 100644 --- a/lib/support/init.d/gitlab.default.example +++ b/lib/support/init.d/gitlab.default.example @@ -84,3 +84,7 @@ mail_room_pid_path="$pid_path/mail_room.pid"  # shell other than "bash"  # The default is "/bin/bash"  shell_path="/bin/bash" + +# This variable controls whether the init script starts/stops Gitaly +gitaly_enabled=false +gitaly_log="$app_root/log/gitaly.log" diff --git a/tmp/sockets/private/.gitkeep b/tmp/sockets/private/.gitkeep new file mode 100644 index 00000000000..e69de29bb2d --- /dev/null +++ b/tmp/sockets/private/.gitkeep | 
