GitLab,是一个使用 Ruby on Rails 开发的开源应用程序,与Github相似,可以浏览源代码,管理缺陷和注释,很是适合在团队内部使用。node
官方只提供了Debian/Ubuntu系统下的安装说明文档,若是须要在centos下安装,能够参考这篇:https://github.com/gitlabhq/gitlab-recipes/tree/master/install/centos,笔者依照这篇文章的说明,成功的在centos系统上安装了gitlab,分享一下本身的安装过程和碰到的问题。python
安装的英文文档:centos-6-5-install-gitlab.zipmysql
开始以前linux
在开始以前请先查看官方的刚需文档: https://github.com/gitlabhq/gitlabhq/blob/master/doc/install/requirements.md ,该文档说明了系统,软件和硬件等各方面的需求。详细的了解这些,能够避免碰到不少怪异的问题。nginx
安装步骤总览c++
一、安装操做系统git
这个比较简单,安装完成以后记的配置下网络,使其能够在启动时自动链接。然后须要升级系统和安装一些相应的软件和依赖包,如下逐一说明。github
Tips:若是不能链接国外的网络,常常出现网络错误或者couldn’t not resolve host这样的错误,建议修改dns服务器为8.8.8.8和8.8.4.4。web
a、升级操做系统和安装wgetredis
$ 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
感谢
在安装的过程当中多亏了朋友雷志伟的帮忙,少走了很多弯路。此外他如今正在汉化GitLab,英文很差的朋友有福了,有兴趣的朋友也能够参与进来,也能够直接使用已经汉化好的文件,地址:http://git.oschina.net/linxuix/Git-Lab-Zh。