欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

Linux系统上Gitlab客户端安装配置全攻略

程序员文章站 2024-02-04 14:22:52
这篇文章主要介绍了Linux系统上Gitlab客户端的安装配置方法,GitLab 是一个用于仓库管理系统的开源项目,需要Ruby环境的支持,需要的朋友可以参考下... 16-01-14...

1. 安装依赖包
请记住,debian 默认并没有安装 sudo,请使用 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

数据库
sqlite

复制代码
代码如下:

sudo apt-get install -y sqlite3 libsqlite3-dev

mysql

复制代码
代码如下:

sudo apt-get install -y mysql-server mysql-client libmysqlclient-dev
# login to mysql
$ mysql -u root -p
# create the gitlab production database
mysql> create database if not exists `gitlabhq_production` default character set `utf8` collate `utf8_unicode_ci`;
# create the mysql user change $password to a real password
mysql> create user 'gitlab'@'localhost' identified by '$password';
# grant proper permissions to the mysql user
mysql> grant select, insert, update, delete, create, drop, index, alter on `gitlabhq_production`.* to 'gitlab'@'localhost';

postgresql

复制代码
代码如下:

sudo apt-get install -y postgresql-9.2 postgresql-server-dev-9.2
# connect to database server
sudo -u postgres psql -d template1
# add a user called gitlab. change $password to a real password
template1=# create user gitlab with password '$password';
# create the gitlab production database
template1=# create database if not exists gitlabhq_production;
# grant all privileges on database
template1=# grant all privileges on database gitlabhq_production to gitlab;
# quit from postgresql server
template1=# \q
# try connect to new database
$ su - gitlab
$ psql -d gitlabhq_production -u gitlab

(译者注:以上3种数据库根据需要安装其一即可)

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. 安装 gitolite
为 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

将 gitlab 用户添加到 git 用户组:

复制代码
代码如下:

sudo usermod -a -g git gitlab

将 git 用户添加到 gitlab 用户组:

复制代码
代码如下:

sudo usermod -a -g gitlab git

生成密钥:

复制代码
代码如下:

sudo -h -u gitlab ssh-keygen -q -n '' -t rsa -f /home/gitlab/.ssh/id_rsa

克隆 gitlab 的 gitolite 分支源代码:

复制代码
代码如下:

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/

检查:退出并重新登录以使 git 用户组生效

复制代码
代码如下:

# 克隆 admin 资源库以将 localhost 添加到 known_hosts
# 并且确认 gitlab 用户有权访问 gitolite
sudo -u gitlab -h git clone git@localhost:gitolite-admin.git /tmp/gitolite-admin
# 如果执行成功,你可以将其删除
sudo rm -rf /tmp/gitolite-admin

重要! 如果你不能克隆 gitolite-admin 资源库,请不要继续本次安装,请根据 trouble shooting guide 并且确认你已经小心的完成上文的全部步骤。

笔者注:这一步测试能否克隆成功。本人没有注意这个提示,完成后续安装后发现怎么都不能通过git@localhost:gitolite-admin.git的方式克隆工程,原因就是ssh认证失败,所以请务必确认这一点。顺便说下本人ssh认证失败的原因: /etc/ssh/sshd_config配置文件里面pubkeyauthentication的值为no,意味着不允许公钥认证,改为yes就可以了。如果还是不能克隆,重复下第3步,并且注意每个命令是否执行成功。或者删除git和gitlab用户,重新执行第3步。


4. 克隆 gitlab 源代码并安装先决条件

复制代码
代码如下:

sudo gem install charlock_holmes --version '0.6.8'
sudo pip install pygments
sudo gem install bundler
cd /home/gitlab
# get gitlab code. use this for stable setup
sudo -h -u gitlab git clone -b stable https://github.com/gitlabhq/gitlabhq.git gitlab

(2013/1/6,最近发现最新的版本是4.0.0.rc2,这个版本已经没有支持sqlite,而我选择sql数据库的时候没有成功,
克隆之后执行、

复制代码
代码如下:

sudo -u gitlab git checkout 2.9.1

可以回到2.9.1的版本,这个版本既支持sqlite,其gitlab管理界面也较美观。3.1.0以后的版本管理界面都有点难看。)

复制代码
代码如下:

# skip this for stable setup.(笔者注:执行了上个命令就不用执行这个命令了)
# master branch (recent changes, less stable)
sudo -h -u gitlab git clone -b master https://github.com/gitlabhq/gitlabhq.git gitlab
cd gitlab
# rename config files
sudo -u gitlab cp config/gitlab.yml.example config/gitlab.yml

选择你希望使用的数据库
         笔者注:建议选择sqlite

复制代码
代码如下:

# sqlite
sudo -u gitlab cp config/database.yml.sqlite config/database.yml
# mysql
sudo -u gitlab cp config/database.yml.mysql config/database.yml
# postgresql
sudo -u gitlab cp config/database.yml.postgres config/database.yml
# 修改 config/database.yml 确认输入了正确的用户名/密码

安装数据库 gems

复制代码
代码如下:

# mysql
sudo -u gitlab -h bundle install --without development test sqlite postgres --deployment
# 或者 postgres
sudo -u gitlab -h bundle install --without development test sqlite mysql --deployment
# 或者 sqlite
sudo -u gitlab -h bundle install --without development test mysql postgres --deployment

初始化数据库

复制代码
代码如下:

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

设置 gitlab hooks

复制代码
代码如下:

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,恭喜!你可以继续进行下一步。

5. 设置 web server
应用可以用下一个命令行动:

复制代码
代码如下:

# 用于测试目的
sudo -u gitlab bundle exec rails s -e production
# 用于守护进程
sudo -u gitlab bundle exec rails s -e production -d

默认登录用户名及密码:

笔者注:记住这个用户名和密码,在通过浏览器登录gitlab工程主页的时候有用。

复制代码
代码如下:

admin@local.host
5ivel!fe


6. 运行 resque 进程(用于处理工作队列)

复制代码
代码如下:

# 手动启动
sudo -u gitlab bundle exec rake environment resque:work queue=* rails_env=production background=yes
# gitlab 启动脚本
sudo -u gitlab ./resque.sh
# 如果你使用 root 运行此脚本,会导致 /home/gitlab/gitlab/tmp/pids/resque_worker.pid 文件的拥有者为 root
# 将导致 resque 在下一次系统初始化中无法启动

自定义 resque 使用的 redis 连接

如果你希望 resque 连接到一个非标准端口号或另一台服务器上的 redis,你可以在 config/resque.yml 文件修改连接信息:

复制代码
代码如下:

production: redis.example.com:6379

好了,我们已经拥有了一个工作正常的 gitlab 了,但请继续下去,有一些事情是必须完成的。

7.nginx 与 unicorn
(1). unicorn

复制代码
代码如下:

cd /home/gitlab/gitlab
sudo -u gitlab cp config/unicorn.rb.example config/unicorn.rb
sudo -u gitlab bundle exec unicorn_rails -c config/unicorn.rb -e production -d

(2). nginx

复制代码
代码如下:

# 初次安装 nginx
sudo apt-get install nginx
# 添加gitlab 到 nginx sites
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**
# 为起初的 ip 地址与准备让 gitlab 服务的域名
sudo vim /etc/nginx/sites-enabled/gitlab

笔者注:本人最初的时候不知道这个配置文件怎么配置,在浏览器里输入服务器ip的时候老是出现“welcome to nginx”页面。
后来的配置是

复制代码
代码如下:

listion 80; #监听所有80端口的客户端请求
server_name: 192.168.1.120; #这是我ubuntu服务器的ip地址。因为我们是小组局域网访问,所以直接配ip地址就可以了。远程访问的话可以通过vpn链接。
# 重启 nginx:
sudo /etc/init.d/nginx restart

(3). init 脚本
在 /etc/init.d/gitlab 创建 init 脚本:

复制代码
代码如下:

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 /etc/init.d/gitlab restart