Установка GitLab под Ubuntu 12.04

Следующие указания по установке созданы и проверены только под Debian/Ubuntu.

Перед установкой проверте требования.
ВАЖНО

Будьте уверены, что вы исполнили все нижеприведенные указания.

Базовая установка.

Базовая установка GitLab предлагается со следующими пакетами:

  • ruby 1.9.3
  • mysql as main db
  • gitolite v3 fork by gitlab
  • nginx + unicorn

Установка состоит из следующих шагов:

  1. Пакеты / зависимости
  2. Ruby
  3. Пользователи
  4. Gitolite
  5. Mysql
  6. GitLab.
  7. Nginx

1. Пакеты / зависимости
Помните, что sudo не установлен в Debian по умолчанию. Вы должны запустить следующие команды как root:

apt-get update && 
apt-get upgrade && 
apt-get install sudo

Теперь установим пакеты:

sudo apt-get update
sudo apt-get upgrade
sudo apt-get install -y wget curl gcc checkinstall libxml2-dev libxslt-dev
   libcurl4-openssl-dev libreadline6-dev libc6-dev libssl-dev 
   libmysql++-dev make build-essential zlib1g-dev 
   libicu-dev redis-server openssh-server git-core python-dev 
   python-pip libyaml-dev postfix libpq-dev
sudo pip install pygments

2. Установка Ruby

wget http://ftp.ruby-lang.org/pub/ruby/1.9/ruby-1.9.3-p194.tar.gz
tar xfvz ruby-1.9.3-p194.tar.gz
cd ruby-1.9.3-p194
./configure
make
sudo make install

3. Пользователи
Добавляем пользователя для git:

sudo adduser \
--system \
--shell /bin/sh \
--gecos 'git version control' \
--group \
--disabled-password \
--home /home/git \
git

Добавляем пользователя для GitLab:

# ubuntu/debian
sudo adduser --disabled-login --gecos 'gitlab system' gitlab

Добавляем наших пользователей к группам:

sudo usermod -a -G git gitlab
sudo usermod -a -G gitlab git

Генерируем ключь:

sudo -H -u gitlab ssh-keygen -q -N '' -t rsa -f /home/gitlab/.ssh/id_rsa

4. Gitolite
Клонируем GitLab:

sudo -H -u git git clone -b gl-v304 https://github.com/gitlabhq/gitolite.git /home/git/gitolite

Устанавливаем:

cd /home/git
sudo -u git -H mkdir bin
sudo -u git sh -c 'echo -e "PATH=\$PATH:/home/git/bin\nexport PATH" >> /home/git/.profile'
sudo -u git sh -c 'gitolite/install -ln /home/git/bin'
sudo cp /home/gitlab/.ssh/id_rsa.pub /home/git/gitlab.pub
sudo chmod 0444 /home/git/gitlab.pub
sudo -u git -H sh -c "PATH=/home/git/bin:$PATH; gitolite setup -pk /home/git/gitlab.pub"

 

 

Права доступа:

sudo chmod -R g+rwX /home/git/repositories/
sudo chown -R git:git /home/git/repositories/
# Клонируем репозиторий админа
# & проверте права доступа к gitolite
sudo -u gitlab -H git clone git@localhost:gitolite-admin.git /tmp/gitolite-admin
# если все прошло нормально, то вы можете удалить это sudo rm -rf /tmp/gitolite-admin

Важно! Если вы не можете клонировать репозиторий - НЕ ПРОДОЛЖАЙТЕ УСТАНАВЛИВАТЬ, ПРОВЕРТЕ ВСЕ ЛИ ВЫ ДЕЛАЛИ ПРАВЕЛЬНО.

5. База данных MySQL

sudo apt-get install -y mysql-server mysql-client libmysqlclient-dev
# Входим в MySQL
$ mysql -u root -p
# создаем базу даних GitLab production 
mysql> CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
# Создаем пользователей MySQL и меняем $password на реальный пароль mysql> CREATE USER 'gitlab'@'localhost' IDENTIFIED BY '$password';
# Додаем права доступа
mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'gitlab'@'localhost';

6. GitLab

cd /home/gitlab
# Используем эту команду для стабильной версии
sudo -H -u gitlab git clone -b stable https://github.com/gitlabhq/gitlabhq.git gitlab
# Или
sudo -H -u gitlab git clone -b master https://github.com/gitlabhq/gitlabhq.git gitlab

Копируем конфиги

cd gitlab
# Переименовываем файл конфигурации
sudo -u gitlab cp config/gitlab.yml.example config/gitlab.yml
# Копируем mysql db config
# проверьте следующие поля username/password в config/database.yml
sudo -u gitlab cp config/database.yml.mysql config/database.yml # Копируем unicorn config
sudo -u gitlab cp config/unicorn.rb.example config/unicorn.rb

Устанавливаем gem

cd /home/gitlab/gitlab
sudo gem install charlock_holmes --version '0.6.9'
sudo gem install bundler
sudo -u gitlab -H bundle install --without development test sqlite postgres --deployment

Настраиваем клиент git 

Gitlab needs to be able to commit and push changes to gitolite. Git requires a username and email in order to be able to do that.

sudo -u gitlab -H git config --global user.email "gitlab@localhost"
sudo -u gitlab -H git config --global user.name "Gitlab"

Установка приложения

sudo -u gitlab bundle exec rake gitlab:app:setup RAILS_ENV=production

Установка хуков GitLab

sudo cp ./lib/hooks/post-receive /home/git/.gitolite/hooks/common/post-receive
sudo chown git:git /home/git/.gitolite/hooks/common/post-receive

Проверка статуса приложения:

sudo -u gitlab bundle exec rake gitlab:app:status RAILS_ENV=production
# OUTPUT EXAMPLE
Starting diagnostic
config/database.yml............exists
config/gitlab.yml............exists
/home/git/repositories/............exists
/home/git/repositories/ is writable?............YES
remote: Counting objects: 603, done.
remote: Compressing objects: 100% (466/466), done.
remote: Total 603 (delta 174), reused 0 (delta 0)
Receiving objects: 100% (603/603), 53.29 KiB, done.
Resolving deltas: 100% (174/174), done.
Can clone gitolite-admin?............YES
UMASK for .gitolite.rc is 0007? ............YES
/home/git/share/gitolite/hooks/common/post-receive exists? ............YES

Если вы получили все YES - поздравляю! Вы можете запустить GitLab.
Создаем скрипт инициализации в /etc/init.d/gitlab:

sudo wget https://raw.github.com/gitlabhq/gitlab-recipes/master/init.d/gitlab -P /etc/init.d/
sudo chmod +x /etc/init.d/gitlab

Автостарт GitLab:

sudo update-rc.d gitlab defaults 21

Теперь вы можете запустить GitLab:

sudo service gitlab start

7. Nginx

# Для начала установим
sudo apt-get install nginx
# Добавим GitLab к сайтам nginx
sudo wget https://raw.github.com/gitlabhq/gitlab-recipes/master/nginx/gitlab -P /etc/nginx/sites-available/
sudo ln -s /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/gitlab
# Измените **YOUR_SERVER_IP** и **YOUR_SERVER_FQDN**
sudo vim /etc/nginx/sites-enabled/gitlab # Перегружаем nginx:
sudo /etc/init.d/nginx restart
Done! Visit YOUR_SERVER for gitlab instance
You can login via web using admin generated with setup:
admin@local.host
5iveL!fe Advanced setup tips:
Checkout databases.md for postgres or sqlite
Customizing Resque's Redis connection
If you'd like Resque to connect to a Redis server on a non-standard port or on a different host, you can configure its connection string in the config/resque.yml file:
production: redis.example.com:6379 **Ok - we have a working application now. ** **But keep going - there are some things that should be done **

ВСЕ!!! РАБОТАЙТЕ И НАСЛАЖДАЙТЕСЬ GITLAB-ом.

LikeMe: