centos 6.5安裝GitLab全過程和問題記錄

centos 6.5安裝GitLab全過程和問題記錄

 

GitLab,是一個使用 Ruby on Rails 開發的開源應用程序,與Github相似,可以瀏覽源代碼,管理缺陷和註釋,很是適合在團隊內部使用。 官方只提供了Debian/Ubuntu系統下的安裝說明文檔,若是須要在centos下安裝,能夠參考這篇:https://github.com /gitlabhq/gitlab-recipes/tree/master/install/centos,筆者依照這篇文章的說明,成功的在 centos系統上安裝了gitlab,分享一下本身的安裝過程和碰到的問題。node

安裝的英文文檔:centos-6-5-install-gitlab.zippython

先秀下安裝完成後的成果。mysql

centos 6.5安裝GitLab全過程和問題記錄

centos安裝gitlab成果linux

開始以前nginx

在開始以前請先查看官方的剛需文檔: https://github.com/gitlabhq/gitlabhq/blob/master/doc/install/requirements.md ,該文檔說明了系統,軟件和硬件等各方面的需求。詳細的瞭解這些,能夠避免碰到不少怪異的問題。c++

安裝步驟總覽git

  • 基礎操做系統(CentOS 6.4 Minimal,升級後爲6.5)
  • Ruby (版本: 2.0.0p353)
  • 建立項目運行用戶(建立git帳號,方便權限管理)
  • GitLab Shell(版本:1.8.0)
  • 數據庫(能夠支持mysql和PostgreSQL,這裏使用mysql,版本:5.1.17)
  • GitLab(版本:6.3.1)
  • Web服務器(可支持nginx和apache,這裏使用nginx,版本:1.0.15)
  • 防火牆(iptables)

一、安裝操做系統github

這個比較簡單,安裝完成以後記的配置下網絡,使其能夠在啓動時自動鏈接。然後須要升級系統和安裝一些相應的軟件和依賴包,如下逐一說明。web

Tips:若是不能鏈接國外的網絡,常常出現網絡錯誤或者couldn’t not resolve host這樣的錯誤,建議修改dns服務器爲8.8.8.8和8.8.4.4。redis

a、升級操做系統和安裝wget

$ sudo yum -y update
$ sudo yum -y install wget

升級完成後,系統版本是6.5。

筆者注:和英文文檔不一樣,筆者這裏是先升級系統和安裝wget,否則後面的操做會提示wget命令找到。

b、增長EPEL安裝源

EPEL,即Extra Packages for Enterprise Linux,這個軟件倉庫裏有不少很是經常使用的軟件,並且是專門針對RHEL設計的,對RHEL標準yum源是一個很好的補充,徹底無償使用,由 Fedora項目維護,因此若是你使用的是RHEL,或者CentOS,Scientific等RHEL系的linux,能夠很是放心的使用EPEL的 yum源。

下載並安裝GPG key

$ sudo wget -O /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 https://www.fedoraproject.org/static/0608B895.txt
$ sudo rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6

檢驗下是否安裝成功

$ sudo rpm -qa gpg*

安裝epel-release-6-8.noarch包

$ sudo rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm

提示:不要在乎x86_64,在i686的機器上同樣能使用。

c、增長PUIAS安裝源

PUIAS Linux是面向桌面和服務器的完整的操做系統,它靠編譯Red Hat Enterprise Linux的源代碼包來建立。除了這些上游的軟件包外,該項目還提供一些其餘的軟件倉庫:「Addons」包含了一般的Red Hat發行中未收入的額外軟件包,「Computational」提供專門針對科學計算的軟件,「Unsupported」則收入各類各樣的測試性軟件 包。該發行由美國普林斯頓 大學的高等研究所維護。

建立/etc/yum.repos.d/PUIAS_6_computational.repo,並添加以下內容:

[PUIAS_6_computational]
name=PUIAS computational Base $releasever - $basearch
mirrorlist=http://puias.math.ias.edu/data/puias/computational/$releasever/$basearch/mirrorlist
#baseurl=http://puias.math.ias.edu/data/puias/computational/$releasever/$basearch
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-puias

下載並安裝GPG key

$ sudo wget -O /etc/pki/rpm-gpg/RPM-GPG-KEY-puias http://springdale.math.ias.edu/data/puias/6/x86_64/os/RPM-GPG-KEY-puias
$ sudo rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-puias

檢驗下是否安裝成功

$ sudo rpm -qa gpg*

Tips:安裝完EPEL和PUIAS兩個源後,能夠檢測下:

$ sudo yum repolist

d、安裝GitLab的所需依賴包和工具

$ su -
$ yum -y groupinstall 'Development Tools'
$ yum -y install vim-enhanced readline readline-devel ncurses-devel gdbm-devel glibc-devel tcl-devel openssl-devel curl-devel expat-devel db4-devel byacc sqlite-devel gcc-c++ libyaml libyaml-devel libffi libffi-devel libxml2 libxml2-devel libxslt libxslt-devel libicu libicu-devel system-config-firewall-tui python-devel redis sudo wget crontabs logwatch logrotate perl-Time-HiRes git

RHEL提示 

若是部分包不能安裝,例如: eg. gdbm-devel, libffi-devel and libicu-devel,那麼增長rhel6的安裝源。

$ yum-config-manager --enable rhel-6-server-optional-rpms

e、配置redis

配置redis使其在開機時啓動:

$ sudo chkconfig redis on
$ sudo service redis start

f、配置郵件服務器

筆者注:這個過程筆者沒有配置,請參考英文文檔。

二、安裝Ruby

下載並編譯:

$ su -
$ mkdir /tmp/ruby && cd /tmp/ruby
$ curl --progress ftp://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p353.tar.gz | tar xz
$ cd ruby-2.0.0-p353
$ ./configure --prefix=/usr/local/
$ make && make install

安裝完成後,從新登陸終端確保$PATH生效,檢測ruby的安裝成功與否:

$ which ruby
/usr/local/bin/ruby
$ ruby -v
ruby 2.0.0p353 (2013-11-22 revision 43784) [x86_64-linux]

安裝bundle:

$ sudo gem install bundler --no-ri --no-rdoc

若是提示sudo: gem: command not found,使用root帳號登陸執行該命令便可。

三、系統用戶

建立用戶git

$ su -
$ adduser --system --shell /bin/bash --comment 'GitLab' --create-home --home-dir /home/git/ git

由於git用戶不須要登陸,因此這裏不須要設置git的密碼。

轉發全部郵件

筆者注:由於上面沒有配置發送郵件,這裏也省略。

四、配置GitLab shell

GitLab shell是專門爲GitLab開發的提供ssh訪問和版本管理的軟件。

先使用root登陸,然後切換成git

$ su -
$ su - git

克隆gitlab shell

$ git clone https://github.com/gitlabhq/gitlab-shell.git
$ cd gitlab-shell

切換成1.8.0版本,並編輯配置

$ git checkout v1.8.0
$ cp config.yml.example config.yml

這裏最重要的是將gitlab_url修改爲gitlab的訪問域名。形如:http://test.gitlab.com/

筆者注:若是gitlab是使用https訪問,則需將http替換成https,配置文件中的self_signed_cert要修改爲true,不然 gitlab shell在經過api和gitlab進行通訊的時候就會出現錯誤,致使項目push出錯。由於後面配置web服務器的時候是使用ssl,因此這裏要按照 ssl的方式配置。

Tips: 另外若是使用的域名是測試域名,不要忘記在系統的/etc/hosts作域名映射。

安裝一些須要的目錄和文件

$ ./bin/install

五、安裝數據庫

筆者這裏使用的是msyql,關於PostgreSQL的安裝請參考原文檔。

安裝mysql並設置開機啓動:

$ su -
$ yum install -y mysql-server mysql-devel
$ chkconfig mysqld on
$ service mysqld start

設置mysql root帳號的密碼:

$ /usr/bin/mysql_secure_installation

建立新用戶和數據庫給gitlab使用

# 登陸數據庫
$ mysql -u root -p
# 輸入root密碼
# 爲gitlab建立使用用戶
CREATE USER 'gitlab'@'localhost' IDENTIFIED BY 'gitlab帳號的密碼';

# 建立gitlaba使用的數據庫
CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;

# 給予gitlab用戶權限
GRANT SELECT, LOCK TABLES, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'gitlab'@'localhost';

# 登出數據庫
\q

六、安裝GitLab

將GitLab安裝在git的家目錄下:

$ su -
$ su - git

a、克隆GitLab並切換分支到6-3-stable

# 克隆GitLab
$ git clone https://github.com/gitlabhq/gitlabhq.git gitlab
# 進入gitlab目錄
$ cd /home/git/gitlab
# 切換到6-3-stable分支
$ git checkout 6-3-stable

b、配置項目

# 複製配置文件
$ cp config/gitlab.yml.example config/gitlab.yml

# 修改配置文件中的訪問域名
(your_domain_name爲項目的訪問域名)
$ sed -i 's|localhost|your_domain_name|g' config/gitlab.yml

# 設定log和tmp目錄全部者和權限
$ chown -R git log/
$ chown -R git tmp/
$ chmod -R u+rwX log/
$ chmod -R u+rwX tmp/

# 建立gitlab-satellites目錄
$ mkdir /home/git/gitlab-satellites

# 建立tmp/pids/和tmp/sockets/目錄,確保gitlab有相應的權限
$ mkdir tmp/pids/
$ mkdir tmp/sockets/
$ chmod -R u+rwX tmp/pids/
$ chmod -R u+rwX tmp/sockets/

# 建立public/uploads目錄
$ mkdir public/uploads
$ chmod -R u+rwX public/uploads

# 複製unicorn配置
$ cp config/unicorn.rb.example config/unicorn.rb

# 編輯unicorn配置
(筆者這裏採用默認配置)
$ vim config/unicorn.rb

# 配置git的用戶和郵件
$ git config --global user.name "GitLab"
$ git config --global user.email "gitlab@your_domain_name"
$ git config --global core.autocrlf input

這邊的配置比較複雜,細心些就好了。

c、配置數據庫訪問文件

$ cp config/database.yml.mysql config/database.yml

編輯config/database.yml,設置其中鏈接數據庫的帳號密碼,筆者的配置部分以下:

#
# PRODUCTION
#
production:
  adapter: mysql2
  encoding: utf8
  reconnect: false
  database: gitlabhq_production
  pool: 10
  username: gitlab
  password: "gitlab"
  # host: localhost
  # socket: /tmp/mysql.sock

修改其中username和password就能夠了,其中密碼就是上面數據庫步驟中建立gitlab用戶的密碼。

確保該文件只有git帳號有權限讀取。

$ chmod o-rwx config/database.yml

d、安裝Gems

$ su -
$ gem install charlock_holmes --version '0.6.9.4'
$ exit

安裝mysql包

$ cd /home/git/gitlab/
$ bundle install --deployment --without development test postgres puma aws

e、初始化數據和激活高級功能

$ cd /home/git/gitlab
$ bundle exec rake gitlab:setup RAILS_ENV=production

這步完成後,會生一個默認的管理員帳號:

admin@local.host
5iveL!fe

f、安裝啓動腳本

$ su -
$ wget -O /etc/init.d/gitlab https://raw.github.com/gitlabhq/gitlab-recipes/master/init/sysvinit/centos/gitlab-unicorn
$ chmod +x /etc/init.d/gitlab
$ chkconfig --add gitlab

開機時啓動

$ chkconfig gitlab on

g、檢測應用程序狀態

$ su - git
$ cd gitlab/
$ bundle exec rake gitlab:env:info RAILS_ENV=production
$ exit

能夠查看到系統、Ruby、GitLab和GitLab Shell的版本和其餘信息。

啓動GitLab實例

$ service gitlab start

h、查看應用更加詳細的信息

$ su - git
$ cd gitlab/
$ bundle exec rake gitlab:check RAILS_ENV=production

這裏會提示一個Init script up-to-date的錯誤,以下:

Init script up-to-date? ... no
Try fixing it:
Redownload the init script
For more information see:
doc/install/installation.md in section "Install Init Script"
Please fix the error above and rerun the checks.

原文說明不用介意這個問題。

七、安裝web服務器

筆者選擇的是nginx,關於apache方面的請參考原文檔

$ su -
$ yum -y install nginx
$ chkconfig nginx on
$ mkdir /etc/nginx/sites-available
$ mkdir /etc/nginx/sites-enabled
$ wget -O /etc/nginx/sites-available/gitlab https://raw.github.com/gitlabhq/gitlab-recipes/master/web-server/nginx/gitlab-ssl
$ ln -sf /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/gitlab

編輯/etc/nginx/nginx.conf,將 include /etc/nginx/conf.d/*.conf; 替換成 include /etc/nginx/sites-enabled/*;,就是修改額外加載的配置文件目錄。

編輯/etc/nginx/sites-available/gitlab,將配置中server_name替換成實際訪問的域名。

將nginx加入git用戶組

$ usermod -a -G git nginx
$ chmod g+rx /home/git/

添加ssl證書或者本身生成一個

$ cd /etc/nginx
$ openssl req -new -x509 -nodes -days 3560 -out gitlab.crt -keyout gitlab.key

啓動nginx

$ service nginx start

八、配置防火牆

配置iptables,使用戶能夠訪問http、https和ssh的端口。

$ lokkit -s http -s https -s ssh

從新啓動防火牆

$ service iptables restart

至此就算安裝完成了。默認的帳號密碼:

admin@local.host
5iveL!fe

問題記錄

a、網站不能添加用戶和建立項目問題?

查了下日誌,發現是權限的問題:

Errno::EACCES (Permission denied – /home/git/gitlab/log/application.log):

修改用戶和所屬用戶組爲git就能夠了。

b、沒法push?

在上面安裝GitLab shell步驟時,一開始筆者是將配置中的gitlab_url設置成http://test.gitlab.com/,結果在push的時候出錯了,後 來查看GitLab項目日誌,才發現GitLab shell和GitLab通訊的時候產生了一個301跳轉。這點經過GitLab的nginx配置也能看的出來。後來將http替換成 https,self_signed_cert設置成true就OK了。

總結

安裝的過程比較長,其中大部分時間花在了包的下載上。筆者之前沒有接觸過ruby,安裝的過程當中也瞭解了下Ruby、Gem、Bundle等軟件,受益匪 淺。通常來說,照着上面的步驟安裝,若是系統,軟件等版本都一致的話,應該能成功安裝。若是出現問題,能夠多查查日誌。GitLab項目的日誌在該項目的 log目錄內。GitLab shell的日誌在GitLab shell項目中的gitlab-shell.log

注:英文很差的朋友有福了,有興趣的朋友也能夠參與進來,也能夠直接使用已經漢化好的文件,地址:http://git.oschina.net/linxuix/Git-Lab-Zh。 來自:http://my.oschina.net/wzlee/blog/262181

相關文章
相關標籤/搜索