centos 6.5安装GitLab安装
1、安装操作系统
a、安装wget(系统版本是6.5)
#yum -y install wget
b、增加EPEL安装源
EPEL,即Extra Packages for Enterprise Linux,这个软件仓库里有很多非常常用的软件,而且是专门针对RHEL设计的,对RHEL标准yum源是一个很好的补充,完全免费使用,由 Fedora项目维护,所以如果你使用的是RHEL,或者CentOS,Scientific等RHEL系的linux,可以非常放心的使用EPEL的 yum源。
下载并安装GPG key
#wget -O /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 https://www.fedoraproject.org/static/0608B895.txt
# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
安装epel-release-6-8.noarch包
# rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
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
#wget -O /etc/pki/rpm-gpg/RPM-GPG-KEY-puiashttp://springdale.math.ias.edu/data/puias/6/x86_64/os/RPM-GPG-KEY-puias
#rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-puias
检验下是否安装成功
# rpm -qa gpg*
Tips:安装完EPEL和PUIAS两个源后,可以检测下:
#yum repolist
d、安装GitLab的所需依赖包和工具
# 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安装见备注)
备注:
#tar zxvf redis-3.0.0.tar.gz
#cd redis-3.0.0
#make && make install
配置redis使其在开机时启动:
# sudo chkconfig redis on
# sudo service redis start
f、配置邮件服务器(这里不做设置)
2、安装Ruby
下载并编译:
# 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
# cd /usr/local/bin/
# 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 notfound,使用root账号登录执行该命令即可。
安装过程中会出现下面的错误.解决方法:
[root@h77ruby-2.0.0-p353]# geminstall bundler --no-ri --no-rdoc
ERROR: Could not find a valid gem 'bundler' (>=0), here is why: Unable to download data from https://rubygems.org/ -Errno::ETIMEDOUT: Connection timed out - connect(2)(https://rubygems.org/latest_specs.4.8.gz)
是因为国内网络导致rubygems.org存放在Amazon S3上面的资源文件间歇性连接失败,用国内的RubyGems镜像(参见http://ruby.taobao.org/)替换官方镜像,方法如下:
[root@h77ruby-2.0.0-p353]# gemsources --remove https://rubygems.org/
https://rubygems.org/removed from sources
[root@h77ruby-2.0.0-p353]# gemsources -a https://ruby.taobao.org/
https://ruby.taobao.org/added to sources
[root@h77ruby-2.0.0-p353]# gemsources -l
*** CURRENT SOURCES***
https://ruby.taobao.org/
[root@h77ruby-2.0.0-p353]# geminstall bundler --no-ri --no-rdoc
Fetching:bundler-1.7.6.gem (100%)
Successfullyinstalled bundler-1.7.6
1 gem installed
3、系统用户
创建用户git
#adduser --system --shell /bin/bash --comment 'GitLab' --create-home --home-dir /home/git/ git
因为git用户不需要登录,所以这里不需要设置git的密码。
4、配置GitLab shell
GitLabshell是专门为GitLab开发的提供ssh访问和版本管理的软件。
先使用root登录,而后切换成git
# 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
5、安装数据库
这里使用的是msyql,(cmake+mysql见备注)
备注:
cmake安装
#tar zxvf cmake-3.0.0.tar.gz
#cd cmake-3.0.0
#./configure --prefix=/usr/local/cmake
#make && make install
设置环境变量
#vi /etc/profile
添加以下
PATH=/usr/local/cmake/bin:$PATH
wq!
使配置生效:
#source /etc/profile
mysql安装
#groupadd mysql
#useradd -g mysql mysql -s /bin/false
#mkdir -p /data/mysql
#chown -R mysql:mysql /data/mysql
#mkdir -p /usr/local/mysql
#tar zxvf mysql-5.5.17.tar.gz
#cd mysql-5.5.17
#cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DSYSCONFDIR=/etc
#make && make install
#cp -r /usr/local/mysql/support-files/my-large.cnf /etc/my.cnf
#sed -i '25a datadir = /data/mysql' /etc/my.cnf
#cd /usr/local/mysql/
#./scripts/mysql_install_db --user=mysql
#cp -r /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld
#sed -i "46s#basedir=#basedir=/usr/local/mysql#g" /etc/rc.d/init.d/mysqld
#sed -i "47s#datadir=#datadir=/data/mysql#g" /etc/rc.d/init.d/mysqld
#chmod 755 /etc/init.d/mysqld
#chkconfig mysqld on
#echo -e "export PATH=\$PATH:/usr/local/mysql/bin" >> /etc/profile
#ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
#ln -s /usr/local/mysql/include/mysql /usr/include/mysql
#service mysqld start
# chkconfig mysqld on
# service mysqld start
设置mysql root账号的密码:
# mysqladmin -u root password '123456'
创建新用户和数据库给gitlab使用
# 登录数据库
# mysql -u root -p
# 输入root密码
# 为gitlab创建使用用户
CREATE USER 'gitlab'@'localhost' IDENTIFIED BY '123456';
# 创建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
6、安装GitLab
将GitLab安装在git的家目录下:
#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
修改配置文件中
$ sed -i 's|localhost|192.169.1.171|g' config/gitlab.yml
备注:192.168.1.171是我要安装的机器
设定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
编辑resque.yml配置
$ vim config/resque.yml
development: redis://192.168.1.171:6379
test: redis://192.168.1.171:6379
production: redis://192.168.1.171:6379
配置git的用户和邮件
$ git config --global user.name "GitLab"
$ git config --global user.email "bb@aa.com"(以你真实的域名填写)
$ 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: "123456"
# 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包
$ su - git
$ cd /home/git/gitlab/
$ bundle install --deployment --without development test postgres puma aws
备注:
[转]Could not find modernizr-2.6.2 in any of the sources 解决办法:
[git@Git gitlab]$ vi Gemfile
source "https://rubygems.org"改为source "http://rubygems.org"
[git@Git gitlab]$ bundle install --deployment--without development test postgres
Fetching source indexfrom http://rubygems.org/
Fetchinghttps://github.com/gitlabhq/grit.git
Could not findmodernizr-2.6.2 in any of the sources
#出现错误:Could not find modernizr-2.6.2 in any of thesources
#解决办法:
[git@Git gitlab]$ vi Gemfile
第114行 gem"modernizr", "2.6.2"
更改改为:
第114行 gem "modernizr-rails", "2.7.1"
[git@Git gitlab]$ vi Gemfile.lock
第252行 modernizr (2.6.2)
更改改为:
第252行 modernizr-rails (2.7.1)
第523行 modernizr (= 2.6.2)
更改改为:
第523行 modernizr-rails (= 2.7.1)
#重新执行:
[git@Git gitlab]$ bundleinstall --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、安装启动脚本
# cd /home/git/gitlab
# cp lib/support/init.d/gitlab /etc/init.d/
# chmod +x /etc/init.d/gitlab
设置logarate
# cd /home/git/gitlab
# cp lib/support/logrotate/gitlab /etc/logrotate.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和GitLabShell的版本和其他信息。
启动GitLab实例
$ service gitlab start
h、查看应用更加详细的信息
$ su - git
$ cd gitlab/
$ bundle exec rake gitlab:check RAILS_ENV=production
7、安装web服务器
选择的是nginx,
$ su -
# yum -y install nginx
# chkconfig nginx on
# mkdir /etc/nginx/sites-available
# mkdir /etc/nginx/sites-enabled
#cd /home/git/gitlab# cp lib/support/nginx/gitlab /etc/nginx/sites-available/
# ln -s /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/gitlab
修改域名
vim /etc/nginx/sites-enabled/gitlab
server_name 192.168.1.171;
修改nginx配置文件其中
# Load configfiles from the /etc/nginx/conf.d directory
# The defaultserver is in conf.d/default.conf
# include/etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
重启服务
#/etc/init.d/nginx restart
8 测试
访问:http://192.168.1.171/