设为首页 收藏本站
查看: 453|回复: 0

[经验分享] CentOS 自定义安装GitLab

[复制链接]

尚未签到

发表于 2018-4-26 12:45:37 | 显示全部楼层 |阅读模式
  准备工作和说明
  说明:
  本文主要参考官方文档而来
  有关回复邮件的设置请参考http://doc.gitlab.com/ce/incoming_email/README.html
  gitlab 安装路径为/data/git
  

  基于CentOS minimal 系统,系统安装时没有安装依赖包,可以安装开发包,也可依报错信息安装缺少依赖。
  主要涉及以下组件安装与配置

  •   依赖包

  •   Ruby
  •   Go
  •   System Users

  •   Database
  •   Redis
  •   GitLab
  •   Nginx
  

  1. 依赖包安装

  更新系统及软件包
#以 root 用户运行
yum update -y
yum upgrade -y  安装 vim wget

yum install vim wget -y  安装软件包
yum install -y zlib-devel libyaml-devel libffi-devel curl openssh-server libxml2-devel \
libxslt-devel libicu-devel logrotate python-docutils cmake openssh-clients openssl-devel \
libcurl-devel  安装开发工具
yum install gcc gcc-c++ wget
#或yum groupinstall 'Development Tools'  nodjs安装
  包管理器安装,源码安装,二进制文件安装任选其一
  

  包管理器

curl --silent --location https://rpm.nodesource.com/setup_4.x | bash -
yum -y install nodejs
yum install gcc-c++ make
# or: yum groupinstall 'Development Tools'  二进制包
wget -c https://nodejs.org/dist/v4.4.1/node-v4.4.1-linux-x64.tar.gz
SHASUMS256:f0a53527f52dbcab3b98921a6cfe8613e5fe26fb796624988f6d615c30305a95  node-v4.4.1-linux-x64.tar.gz
mkdir /usr/local/node
tar zxvf node-v4.4.1-linux-x64.tar.xz -C /usr/local/node --strip-components 1
ln -s /usr/local/node/bin/{node,npm} /usr/bin/  源码安装
  CentOS 6上需要 gcc-c++ 的版本不低于4.8,源码安装单独写篇文章

wget -c https://nodejs.org/dist/v4.4.1/node-v4.4.1.tar.gz
echo 'f3e604cc4d05a4810c37cd43a838a2dc4399d517bd1e8c53b7670dcffc4dc481  node-v4.4.1.tar.gz' \
| sha256sum -c - && tar zxf node-v4.4.1.tar.gz  Git软件
  确认git版本2.7.4或更高,否则源码安装git软件
git --version  

  安装依赖
yum install perl-devel gettext libcurl-devel  下载并解压git软件

curl -O --progress https://www.kernel.org/pub/software/scm/git/git-2.8.0.tar.gz
echo '2c6eee5506237e0886df9973fd7938a1b2611ec93d07f64ed3447493ebac90d1  git-2.8.0.tar.gz' \
| sha256sum -c - && tar zxf git-2.8.0.tar.gz
cd git-2.8.0  配置git准备编译:
./configure  编译软件包:
make prefix=/usr/local all  安装软件包:
make prefix=/usr/local install  建立软链接
ln -sf /usr/local/bin/git /usr/bin  注:一定要装libcurl-devel 开发包
  git是报 fatal: Unable to find remote helper for 'https'
  就是没装libcurl-devel开发包的原因

  安装邮件服务
yum install -y postfix  

  2. Ruby
  注:目前支持的Ruby 版本是 2.1.x, 2.2和2.3暂不支持
  下载Ruby 并校验文件:
wget -c https://cache.ruby-lang.org/pub/ruby/2.1/ruby-2.1.9.tar.gz
echo '034cb9c50676d2c09b3b6cf5c8003585acea05008d9a29fa737c54d52c1eb70c  ruby-2.1.9.tar.gz' \
| sha256sum -c - && tar zxf ruby-2.1.9.tar.gz
cd ruby-2.1.9  配置Ruby准备编译:
./configure --disable-install-rdoc  配置选项含义:
  --disable-install-rdoc
  禁用rdoc

  编译软件包:
make  安装软件包:
make install  创建软链接:
ln -sv /usr/local/bin/{ruby,gem,bundler} /usr/bin  更换Ruby源为国内镜像源:
sudo -u git -H gem sources --add https://ruby.taobao.org --remove https://rubygems.org  安装bundler:
sudo gem install bundler --no-ri --no-rdoc  更改bundler 源:
sudo -u git -H bundle config mirror.https://rubygems.org https://ruby.taobao.org  

  3. Go
  国内原因,只能使用国内的资源下载go了
  由于国内网站没有提供sha256校验码,无从校验了

wget http://www.golangtc.com/static/go/1.6/go1.6.linux-amd64.tar.gz
tar -C /usr/local -zxf go1.6.linux-amd64.tar.gz
ln -sf /usr/local/go/bin/{go,godoc,gofmt} /usr/local/bin/
ln -sv /usr/local/go/bin/go /usr/bin/
rm go1.6.linux-amd64.tar.gz  

  4. System Users
  创建一个使用GitLab的git用户:
useradd -c 'GitLab' git  

  5. Database
  本文使用MySQL数据库,版本不能高于5.5.14
yum install -y mysql mysql-server mysql-devel  确认MySQL版本:
mysql --version  设置MySQL 安全:
mysql_secure_installation  会要求设置mysql root口令,删除空密码用户,删除测试数据库
  

  创建GitLab 仓库的用户,并设置密码(替换$password变量):
mysql> CREATE USER 'git'@'localhost' IDENTIFIED BY '$password';
#设置数据库存储类型为INNODB
mysql> SET storage_engine=INNODB;
#创建GitLab 数据库 gitlabhq
mysql> CREATE DATABASE IF NOT EXISTS `gitlabhq` DEFAULT CHARACTER SET \
`utf8` COLLATE `utf8_unicode_ci`;
#赋予GitLab 用户对gitlabhq的操作权限
mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, CREATE TEMPORARY TABLES,  \
DROP, INDEX, ALTER, LOCK TABLES ON `gitlabhq`.* TO 'git'@'localhost';
#退出数据库管理
mysql> \q
#验证用户登录
sudo -u git -H mysql -u git -p -D gitlabhq
# 登录成功会显示 'mysql>' 提示符号
#退出数据库
mysql> \q  设置开机启动
chkconfig --add mysqld
chkconfig --level 2345 mysqld  

  6. Redis
  GitLab 使用的Redis 不能低于 2.8版本

  下载Redis,并解压文件:
wget -c  http://download.redis.io/releases/redis-3.0.7.tar.gz| tar -C /tmp -xzf redis-3.0.7.tar.gz
cd /tmp/redis-3.0.7  安装软件:
make install  创建软链接:
ln -sv /usr/local/bin/redis-cli /usr/bin/
ln -sv /usr/local/bin/redis-server /usr/bin/redis  

  配置redis 使用sockets:
  如已有redis服务,可更改以下redis文件名增加一个redis-gitlab服务(既将redis.conf,redis替换为redis-gitlab.conf,redis-gitlab)

#创建redis配置文件目录,并拷贝配置文件
mkdir /etc/redis && cp redis.conf /etc/redis/redis.conf
#禁用redis 监听TCP端口
sed -i 's/port .*/port 0/' /etc/redis/redis.conf
#后台方式运行
sed -i 's/^daemonize .*/daemonize yes/' /etc/redis/redis.conf
#配置redis 日志
sed -i 's/^logfile.*/logfile "\/data\/redis\/redis.log"/' /etc/redis/redis.conf
#配置redis存储路径
sed -i 's/^dir.*/dir \/data\/redis/' /etc/redis/redis.conf
#创建redis目录
mkdir /data/redis
chown redis.redis /data/redis
#启用redis socket
echo 'unixsocket /var/run/redis/redis.sock' | sudo tee -a /etc/redis/redis.conf
#赋予socket redis组的所有权限
echo 'unixsocketperm 770' | sudo tee -a /etc/redis/redis.conf
#创建socket目录,添加redis用户
mkdir /var/run/redis
useradd -M redis
chown redis:redis /var/run/redis
chmod 755 /var/run/redis
#添加git到redis组
usermod -aG redis git
#创建启动脚本
vim /etc/init.d/redis#!/bin/sh
#
# redis        init file for starting up the redis daemon
#
# chkconfig:   - 20 80
# description: Starts and stops the redis daemon.
# Source function library.
. /etc/rc.d/init.d/functions
name="redis-server"
exec="/usr/local/bin/$name"
pidfile="/var/run/redis.pid"
REDIS_CONFIG="/etc/redis/redis.conf"
[ -e /etc/sysconfig/redis ] && . /etc/sysconfig/redis
lockfile=/var/lock/subsys/redis
start() {
    [ -f $REDIS_CONFIG ] || exit 6
    [ -x $exec ] || exit 5
    echo -n $"Starting $name: "
    daemon --user ${REDIS_USER-redis} "$exec $REDIS_CONFIG"
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}
stop() {
    echo -n $"Stopping $name: "
    killproc -p $pidfile $name
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}
restart() {
    stop
    start
}
reload() {
    false
}
rh_status() {
    status -p $pidfile $name
}
rh_status_q() {
    rh_status >/dev/null 2>&1
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart}"
        exit 2
esac
exit $?  设置开机启动
chkconfig --add redis
chkconfig --level 2345 redis  

  7.GitLab
  安装GitLab 到自定义目录,这里以data 目录为例:
mkdir -vp /data/git && cd /data/git
sudo chown git:git /data/git/  

  克隆源:

sudo -u git -H git clone https://gitlab.com/gitlab-org/gitlab-ce.git -b 8-6-stable gitlab  配置GitLab:
cd /data/git/gitlab
#复制配置示例文件
sudo -u git -H cp config/gitlab.yml.example config/gitlab.yml  修改配置文件host,email_from,GitLab 主目录参数为实际值
  注:本例全文采用原始文件内容做展示,实际/home/git 应为/data/git
sudo -u git -H vim config/gitlab.yml32>     host: localhost
33>    port: 80 #如使用HTTPS,则将此端口修改为443
34>    https: false #启用或禁用HTTPS,默认false禁用,启用则改为true
61>     email_from: example@example.com
satellites:
386>     path: /home/git/gitlab-satellites/
gitlab_shell:
411>     path: /home/git/gitlab-shell/
414>     repos_path: /home/git/repositories/
415>     hooks_path: /home/git/gitlab-shell/hooks/  

#复制secrets示例文件
sudo -u git -H cp config/secrets.yml.example config/secrets.yml
sudo -u git -H chmod 0600 config/secrets.yml
#确认GitLab 对log  、tmp 目录可写
sudo chown -R git log/
sudo chown -R git tmp/
sudo chmod -R u+rwX,go-w log/
sudo chmod -R u+rwX tmp/
#确认GitLab 对 tmp/pids/ 和tmp/sockets/ 目录可写
sudo chmod -R u+rwX tmp/pids/
sudo chmod -R u+rwX tmp/sockets/
#创建插件上传目录
sudo -u git -H mkdir public/uploads/
#确认Gitlab 用户只能访问public/uploads/ 目录
#上传文件由gitlab-workhorse 服务
sudo chmod 0700 public/uploads
#修改CI 构建目录权限
sudo chmod -R u+rwX builds/
sudo chmod -R u+rwX shared/artifacts/  拷贝Unicorn配置示例,并修改配置文件

sudo -u git -H cp config/unicorn.rb.example config/unicorn.rb
sudo -u git -H vim config/unicorn.rb36> working_directory "/home/git/gitlab" # available in 0.94.0+
41> listen "/home/git/gitlab/tmp/sockets/gitlab.socket", :backlog => 1024
62> pid "/home/git/gitlab/tmp/pids/unicorn.pid"
67> stderr_path "/home/git/gitlab/log/unicorn.stderr.log"
68> stdout_path "/home/git/gitlab/log/unicorn.stdout.log"#确认内核数
nproc
#如果是高负载,可以开启cluster 集群模式
#设置工作线程数小于内核数
#示例的工作线程数为3 运行在2GB内存的服务上
sudo -u git -H vim config/unicorn.rb

# 复制rack_attack配置示例
sudo -u git -H cp config/initializers/rack_attack.rb.example config/initializers/rack_attack.rb
# 配置gitlab 全局用户设置
sudo -u git -H git config --global core.autocrlf input
# redis 配置文件
sudo -u git -H cp config/resque.yml.example config/resque.yml
# 修改redis 服务路径为实际值
sudo -u git -H editor config/resque.yml sudo -u git -H vim config/resque.yml
development: redis://localhost:6379
test: redis://localhost:6379
production: unix:/var/run/redis/redis.sock  

  GitLab 数据库配置文件:
sudo -u git cp config/database.yml.mysql config/database.yml
#更新配置文件的'database','username','password','host','socket'为实际数值
#生产环境只需配置第一段
vim config/database.yml
#设置文件为git 用户只读权限
sudo -u git -H chmod o-rwx config/database.yml  

  安装Gems:
sudo -u git -H bundle install --deployment --without development test postgres aws kerberos  

  安装 GitLab Shell :

  GitLab Shell 是专门用于gitlab的 SSH 和存储管理软件
#运行安装gitllab-shell 任务,使用你的redis sockte链接
sudo -u git -H bundle exec rake gitlab:shell:install REDIS_URL=unix:/var/run/redis/redis.sock \
RAILS_ENV=production
#默认gitlba-shell 配置信息是从GitLab 主配置文件读取生产,并修改为安装路径
sudo -u git -H vim /home/git/gitlab-shell/config.ymluser: git
gitlab_url:   #对应gitlab.yml 中的'host:' 值若,启用了HTTPS协议,则此url应使用HTTPS协议而非HTTP  
http_settings:
  self_signed_cert: false #若启用HTTPS协议,此处应开启证书验证,既此值为true
  #否则报Check GitLab API access: FAILED: Failed to connect to internal API 错误
repos_path: "/home/git/repositories/" #仓库文件目录
auth_file: "/home/git/.ssh/authorized_keys"
redis:
  bin: '' #redis 执行文件,此例应为/usr/local/bin/redis-cli
  namespace: resque:gitlab
  socket: "/var/run/redis/redis.sock" #redis socket路径
log_level: INFO
audit_usernames: false  

  安装gitlab-workhorse:
cd /data/git
sudo -u git -H git clone https://gitlab.com/gitlab-org/gitlab-workhorse.git
cd gitlab-workhorse
sudo -u git -H git checkout v0.7.1
sudo -u git -H make  

  初始化数据库并激活高级功能:
cd /data/git/gitlab
sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production --trace
#--trace 可跟踪初始化过程,便于查看错误
#'yes' 创建数据库表。
#创建完会看到登录帐号,并说明首次登录时创建密码  

  下面为初始化时指定root 口令和email
sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production \
GITLAB_ROOT_PASSWORD=yourpassword GITLAB_ROOT_EMAIL=youremail  

  secrets.yml:
  此文件存储着对话加密密钥和安全设置,将此文件备份到安全地方,备份位置要以防泄漏。
  

  安装启动脚本并修改参数为安装路径:
  注:此处只需修改/etc/default/gitlab 文件即可,不需要修改启动脚本

sudo cp lib/support/init.d/gitlab /etc/init.d/gitlab
sudo cp lib/support/init.d/gitlab.default.example /etc/default/gitlab
sudo vim /etc/default/gitlab
14> app_root="/home/$app_user/gitlab"  

  GitLab开机启动:
sudo chkconfig --add gitlab
sudo chkconfig --level 2345 gitlab on  

  安装 Logrotate,并修改为安装路径:
sudo cp lib/support/logrotate/gitlab /etc/logrotate.d/gitlab
sudo vim /etc/logrotate.d/gitlab
4> /home/git/gitlab/log/*.log {
13> /home/git/gitlab-shell/gitlab-shell.log {  

  检查应用状态:
  检查GitLab 安装配置是否正确
sudo -u git -H bundle exec rake gitlab:env:info RAILS_ENV=production  编制资产:
sudo -u git -H bundle exec rake assets:precompile RAILS_ENV=production  

  启动GitLab 服务:
sudo service gitlab start  

  8.Nginx
  由于centos默认没有nginx源,可采用源码编译安装,亦可添加yum源
  此处采用添加nginx yum源(可参考nginx官方设置)
#echo "[nginx]
>name=nginx repo
>baseurl=http://nginx.org/packages/centos/6/$basearch/
>gpgcheck=0
>enabled=1" > /etc/yum.repos.d/nginx.repo
#yum -y install nginxbaseurl=http://nginx.org/packages/OS/OSRELEASE/$basearch/
这里使用centos替换里OS,6替换了OSRELEASE  

  站点配置:
  复制站点配置示例文件
sudo cp lib/support/nginx/gitlab /etc/nginx/conf.d/gitlab.conf
#若使用HTTPS协议,则复制gitlab-ssl,配置对应内容及证书即可
sudo cp lib/support/nginx/gitlab-ssl /etc/nginx/conf.d/gitlab-ssl.conf  创建SSL 证书:
  由于此证书没有通过验证,所以在git客户端需要关闭证书验证功能
git config --global http.sslverify falsemkdir -p /etc/nginx/ssl/
cd /etc/nginx/ssl/
sudo openssl req -newkey rsa:2048 -x509 -nodes -days 3560 -out gitlab.crt -keyout gitlab.key
sudo chmod o-r gitlab.key  

  编辑配置文件,确认设置正确
vim /etc/nginx/conf.d/gitlab.confupstream gitlab-workhorse {
  server unix:/home/git/gitlab/tmp/sockets/gitlab-workhorse.socket fail_timeout=0;
}
server_name YOUR_SERVER_FQDN; #修改YOUR_SERVER_FQDN为实际域名
  location ~ ^/(404|422|500|502)\.html$ {
    root /home/git/gitlab/public;
    internal;
  }  

  测试配置
nginx -t  重启nginx服务
service nginx restart  

  确认应用状态

sudo -u git -H bundle exec rake gitlab:check RATLS_ENV=production  

  检测应用的过程中,有几处报错,其中有一处是目录权限问题,需要按照给出的提示进行修改
  sudo chmod -R ug+rwX,o-rwx /home/git/repositories/
  sudo chmod -R ug-s /home/git/repositories/
  sudo find /home/git/repositories/ -type d -print0 | sudo xargs -0 chmod g+s  

  自定义SSH 连接
  如果SSH 服务没有运行在默认端口,则必须修改GitLab SSH配置,参照如下格式添加配置
# Add to /home/git/.ssh/config
host localhost          # Give your setup a name (here: override localhost)
    user git            # Your remote git user
    port 2222           # Your port number
    hostname 127.0.0.1; # Your server name or IP  

  

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-452318-1-1.html 上篇帖子: linux IP地址设置方式 centos6.5 下篇帖子: Linux centos vi / vim 使用技巧汇总
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表