• Jenkins--第三关:Gitlab安装和配置


    一、概述

      首先,你要知道Gitlab/Github不是Git.

      Git是版本控制系统,Github是在线的基于Git的代码托管服务。.

      Github同时提供付费账户和免费账户。这两种账户都可以创建公开的代码仓库,但是付费账户也可以创建私有的代码仓库。

      Gitlab是一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。

    二、安装Git(非必须,系统一般有安装git 1.7)Git必看书籍Pro Git这本书(也可以看其电子版)绝对是Git入门和进深的不二选择。

    英文版:https://git-scm.com/book/en/v2

    中文版:https://git-scm.com/book/zh/v2

    1、依赖关系

    yum -y install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
    yum -y install gcc* perl-ExtUtils-MakeMaker xmlto asciidoc
    # wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
    # tar zxvf libiconv-1.14.tar.gz
    # cd libiconv-1.14
    # ./configure --prefix=/usr/local/libiconv
    # make -j 4 && make -j 4 install

    2、安装

    # yum remove git
    #注意,如果系统升级了python要修改/usr/bin/asciidoc 第一行
    为“#!/usr/bin/env python2” 。 /// (/usr/bin/python2)
    # tar zxvf v2.12.1.tar.gz
    # cd git-2.12.1
    # make configure
    # ./configure --prefix=/usr/local/git --with-iconv=/usr/local/libiconv
    # make -j 4 all doc
    # make -j 4 install install-doc install-html
    # echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/bashrc
    # echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/profile.d/git.sh
    # source /etc/bashrc // source /etc/profile

    查看版本号
    # git --version

    git version 2.12.1

    完成后,你可以使用 Git 来获取 Git 的升级:

      # git clone git://git.kernel.org/pub/scm/git/git.git

    三、安装Gitlab

    官方详细解释:https://about.gitlab.com/downloads/#centos6

    1. 准备
    #On Centos 6 and 7, the commands below will also open HTTP and SSH access in the system firewall.
    #这句是用来做防火墙的。避免用户通过ssh方式和http来访问
    lokkit -s http -s ssh

     yum -y install curl openssh-server openssh-clients postfix cronie
     service postfix start
     chkconfig postfix on
     lokkit -s http -s ssh
    service postfix start
    chkconfig postfix on
    ss -tnlp
    #无法启动则查看日志 tail -f /var/log/maillog

    2. 安装
    curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash
    sudo yum -y install gitlab-ce

    #If you are not comfortable installing the repository through a piped script, you can find the entire script here and select and download the package manually and install using
    #https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/
    curl -LJO https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/6/gitlab-ce-XXX.rpm/download
    rpm -i gitlab-ce-XXX.rpm

    3. 启动和配置
    #对GitLab进行编译。
    gitlab-ctl reconfigure

    	#Running handlers:
    	#Running handlers complete
    	#Chef Client finished, 108/329 resources updated in 01 minutes 12 seconds
    	#gitlab Reconfigured!
    #查看状态
    gitlab-ctl status
    	run: gitlab-workhorse: (pid 5359) 134s; run: log: (pid 5190) 161s
    	run: logrotate: (pid 5281) 149s; run: log: (pid 5280) 149s
    	run: nginx: (pid 5236) 155s; run: log: (pid 5235) 155s
    	run: postgresql: (pid 3547) 854s; run: log: (pid 2415) 1703s
    	run: redis: (pid 3555) 853s; run: log: (pid 2278) 1714s
    	run: sidekiq: (pid 5144) 167s; run: log: (pid 5143) 167s
    	run: unicorn: (pid 5089) 173s; run: log: (pid 5088) 173s
    ps -ef|grep unicorn
    	root       5087   2230  0 09:38 ?        00:00:00 runsv unicorn
    	root       5088   5087  0 09:38 ?        00:00:00 svlogd -tt /var/log/gitlab/unicorn
    	git        5089   5087  0 09:38 ?        00:00:00 /bin/bash /opt/gitlab/embedded/bin/gitlab-unicorn-wrapper
    	git        5107      1  2 09:38 ?        00:00:11 unicorn master -D -E production -c /var/opt/gitlab/gitlab-rails/etc/unicorn.rb /opt/gitlab/embedded/service/gitlab-rails/config.ru
    	git        5271   5107  0 09:39 ?        00:00:00 unicorn worker[0] -D -E production -c /var/opt/gitlab/gitlab-rails/etc/unicorn.rb /opt/gitlab/embedded/service/gitlab-rails/config.ru
    	git        5274   5107  0 09:39 ?        00:00:00 unicorn worker[1] -D -E production -c /var/opt/gitlab/gitlab-rails/etc/unicorn.rb /opt/gitlab/embedded/service/gitlab-rails/config.ru 
    

      

    #登录gitlab
    #第一次登录gitlab,需要为root用户修改密码,root用户也是gitlab的超级管理员

    #解决 80 端口被占用 和GitLab头像无法正常显示
    #原因:gravatar被墙 解决办法: 编辑 /etc/gitlab/gitlab.rb,将井号删除
    gitlab_rails['gravatar_plain_url'] = 'http://gravatar.duoshuo.com/avatar/%{hash}?s=%{size}&d=identicon'
    #并且
    external_url 'http://192.168.18.41:8888'

    #external_url 'http://192.168.18.13'  //测试物理机直接用得80端口,不推荐。
    #然后在命令行执行:

    gitlab-ctl reconfigure
    gitlab-rake cache:clear RAILS_ENV=production
    #gitlab-ctl reconfigure 会生成N多配置,请探索“/var/opt/gitlab/”。
    #直接nginx配置可以变更端口,但是GitLab头像无法正常显示。
    #若有读者发现变更端口后正常显示头像的方法请一定要分享给大家。
    #配置文件:/var/opt/gitlab/nginx/conf/gitlab-http.conf

    #然后事实上默认就生成有upstream gitlab-workhorse,所以改改listen的端口就足以。

    upstream gitlab {
    	server unix:/var/opt/gitlab/gitlab-workhorse/socket;
    }
    server {
        #侦听的9999端口,端口我改过N多个所有不用在意这条注释。
        listen       8888;
        server_name  *.renn.top;
        location / {
            proxy_pass   http://gitlab;    #在这里设置一个代理,和upstream的名字一样
            #以下是一些反向代理的配置可删除
            proxy_redirect             off;
            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
            proxy_set_header           Host $host;
            proxy_set_header           X-Real-IP $remote_addr;
            proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for;
            client_max_body_size       10m; #允许客户端请求的最大单文件字节数
            client_body_buffer_size    128k; #缓冲区代理缓冲用户端请求的最大字节数
            proxy_connect_timeout      300; #nginx跟后端服务器连接超时时间(代理连接超时)
            proxy_send_timeout         300; #后端服务器数据回传时间(代理发送超时)
            proxy_read_timeout         300; #连接成功后,后端服务器响应时间(代理接收超时)
            proxy_buffer_size          4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
            proxy_buffers              4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
            proxy_busy_buffers_size    64k; #高负荷下缓冲大小(proxy_buffers*2)
            proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
        }
    }
    

    End

    以下内容是我从网上找的并整理,请原谅粗心的我已忘记出处(毕竟阅读了30+的文章)。

    部分翻译自官方的E文,有不准确处望谅解。

    -------------------------------------
    运维
    # 启动所有 gitlab 组件:
    sudo gitlab-ctl start
    # 停止所有 gitlab 组件:
    sudo gitlab-ctl stop
    # 重启所有 gitlab 组件:
    sudo gitlab-ctl restart
    # 查看服务状态
    sudo gitlab-ctl status
    # 启动服务
    sudo gitlab-ctl reconfigure
    # 修改默认的配置文件
    sudo vim /etc/gitlab/gitlab.rb
    # 查看版本
    sudo cat /opt/gitlab/embedded/service/gitlab-rails/VERSION
    # echo "vm.overcommit_memory=1" >> /etc/sysctl.conf
    # sysctl -p
    # echo never > /sys/kernel/mm/transparent_hugepage/enabled
    # 检查gitlab
    gitlab-rake gitlab:check SANITIZE=true --trace
    # 查看日志
    sudo gitlab-ctl tail

    备份恢复

    #Gitlab 创建备份
    #使用Gitlab一键安装包安装Gitlab非常简单, 同样的备份恢复与迁移也非常简单,用一条命令即可创建完整的Gitlab备份:
    gitlab-rake gitlab:backup:create
    #以上命令将在/var/opt/gitlab/backups目录下创建一个名称类似为xxxxxxxx_gitlab_backup.tar的压缩包, 这个压缩包就是Gitlab整个的完整部分, 其中开头的xxxxxx是备份创建的时间戳。

    Gitlab 修改备份文件默认目录

    #修改/etc/gitlab/gitlab.rb来修改默认存放备份文件的目录:
    gitlab_rails['backup_path'] = '/mnt/backups'
    #修改后使用gitlab-ctl reconfigure命令重载配置文件。

    备份
    0 2 * * * /usr/bin/gitlab-rake gitlab:backup:create
    0 2 * * * /opt/gitlab/bin/gitlab-rake gitlab:backup:create

    恢复
    #首先进入备份 gitlab 的目录,这个目录是配置文件中的 gitlab_rails['backup_path'] ,默认为 /var/opt/gitlab/backups 。
    #然后停止 unicorn 和 sidekiq ,保证数据库没有新的连接,不会有写数据情况。

    # 停止相关数据连接服务
    # ok: down: unicorn: 0s, normally up
    gitlab-ctl stop unicorn
    # ok: down: sidekiq: 0s, normally up
    gitlab-ctl stop sidekiq

    # 从xxxxx编号备份中恢复
    # 然后恢复数据,xxxxx为备份文件的时间戳
    gitlab-rake gitlab:backup:restore BACKUP=xxxxxx

    # 启动Gitlab
    sudo gitlab-ctl start
    ----------------------------------------

  • 相关阅读:
    图片优化工具
    Mac显示和隐藏文件的命令
    C中调用LUA回调(LUA注册表)
    电信猫拨号再加路由器
    VMware NAT模式网络配置
    spring mvc 数据绑定
    银行存款余额调节表实例
    加强银行余额调节表在财务管理中的作用
    c语言typedef的用法-解惑阿!很多天书般的东西解释的不错(转)
    c语言指针详解(转载)
  • 原文地址:https://www.cnblogs.com/woodman/p/6625193.html
Copyright © 2020-2023  润新知