• centos6上搭建gitlab


     

     一、前提

    1. 系统:Centos 6.5
    2. 软件版本:gitlab-7.8.4
    3. Selinux:关闭
    4. 防火墙规则:先清空(搭建好了后续自己添加相关放行规则)

    二、yum源配置和相关依赖包

      1.添加epel源和PUIAS_6_computational源

    1
    # yum -y install epel-release

         创建该文件并添加以下内容:

    1
    2
    3
    4
    5
    6
    7
    # vim /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

      获取和导入相关验证文件

    1
    2
    3
    # 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
    # rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-puias
    # yum repolist

      2.安装依赖包

    1
    2
    3
    4
    5
    6
    7
    # yum install -y vim lrzsz wget gcc gcc-c++ make makeconf cmake
    # yum -y update
    # yum -y groupinstall 'Development Tools'
    # yum -y install readline readline-devel ncurses-devel gdbm-devel glibc-devel tcl-devel openssl-devel curl-devel expat-devel db4-devel byacc sqlite-devel libyaml libyaml-devel libffi libffi-devel libxml2 libxml2-devel libxslt libxslt-devel libicu libicu-devel system-config-firewall-tui redis sudo wget crontabs logwatch logrotate perl-Time-HiRes git cmake libcom_err-devel.i686 libcom_err-devel.x86_64 nodejs cmake libicu-devel libicu openssl openssl-devel
     
    查看安装的git版本,需要1.7.12以上,有PUIAS源会装1.8
    # git --version

    三、安装Ruby

      1.查看是否安装有Ruby

    1
    # rpm -qa | grep ruby

      2.安装Ruby

    1
    2
    3
    4
    5
    6
    # mkdir /tmp/ruby && cd /tmp/ruby
    # curl --progress ftp://ftp.ruby-lang.org/pub/ruby/2.1/ruby-2.1.2.tar.gz | tar xz
    # cd ruby-2.1.2
    # ./configure --disable-install-rdoc
    # make
    # make prefix=/usr/local install

      3.安装Bundler Gem

    1
    # gem install bundler --no-doc

        可能会报以下错误,这是因为国内网络导致rubygems.org存放在Amazon S3上面的资源文件间接性链接失败,用国内的RubyGems镜像(参见http://ruby.taobao.org/)替换官方镜像

        

        更换镜像地址:

    1
    2
    # gem sources --remove https://rubygems.org/        # 删除原镜像地址
    # gem sources -a https://ruby.taobao.org/           # 添加新镜像地址

        查看是否更换成功:

        

        再次安装:

         

    四、创建系统用户git

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    # adduser --system --shell /bin/bash --comment 'GitLab' --create-home --home-dir /home/git/ git
    让git用户可以找到/usr/local/bin命令,并可以使用sudo
    # visudo
    找到这一行:
    Defaults    secure_path = /sbin:/bin:/usr/sbin:/usr/bin
    在后面添加 /usr/local/bin :
    Defaults    secure_path = /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin
    再找到这一行:
    root    ALL=(ALL)       ALL
    在下一行添加:
    git    ALL=(ALL)       ALL

    五、安装MySQL

      1.前提

        这里的数据库需要安装Mysql 5.5以上的版本,而epel源默认只有5.1,所以需要添加有Mysql 5.5的源

    1
    2
    3
    4
    5
    # rpm -qa | grep mysql   # 查看是否安装比较低版本的mysql,然后卸载
    # yum remove -y mysql*
    # yum install -y mysql55-server mysql55-devel mysql55 postfix # 安装5.5版本
    # chkconfig mysqld on   # 设置开机启动
    # service mysqld start

        要求是InnoDB引擎,登陆查看是否为InnoDB引擎

       

        如果不是可以用SET storage_engine=INNODB设置,或者修改my.cnf文件后重启mysql

      2.配置GitLab使用的数据库

    1
    2
    3
    4
    5
    > CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
    > GRANT SELECT, LOCK TABLES, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'git'@'localhost' identified by 'git';
    > GRANT SELECT, LOCK TABLES, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'git'@'127.0.0.1' identified by 'git';
    > flush privileges;
    > exit;

    六、安装Redis

      安装Reids

    1
    2
    3
    # yum -y install redis
    # chkconfig redis on
    # cp /etc/redis.conf /etc/redis.conf.orig

      下面这条命令会把redis.conf的端口设置为0,而redis.conf.orig不变

    1
    2
    3
    # sed 's/^port .*/port 0/' /etc/redis.conf.orig | sudo tee /etc/redis.conf
    # echo 'unixsocket /var/run/redis/redis.sock' | sudo tee -a /etc/redis.conf
    # echo -e 'unixsocketperm 0770' | sudo tee -a /etc/redis.conf

      授权/var/run/redis给redis权限

    1
    2
    3
    # mkdir -p /var/run/redis/
    # chown redis:redis /var/run/redis
    # chmod 755 /var/run/redis

      将git加入redis组,并启动Redis

    1
    2
    # usermod -aG redis git
    # service redis start

    七、安装GitLab

      1.克隆GitLab

    1
    2
    3
    # su - git
    # cd /home/git
    # git clone https://gitlab.com/larryli/gitlab.git -b 7-8-zh gitlab

      2.配置

        切换至GitLab目录下面,复制一份配置文件

    1
    2
    # cd gitlab
    # cp config/gitlab.yml.example config/gitlab.yml

        确保GitLab可以对 log 和 tmp 目录有写入权限

    1
    2
    3
    4
    # chown -R git log/
    # chown -R git tmp/
    # chmod -R u+rwX log/
    # chmod -R u+rwX tmp/

        为satelites创建目录

    1
    2
    # mkdir /home/git/gitlab-satellites
    # chmod u+rwx,g=rx,o-rwx /home/git/gitlab-satellites

        确保GitLab可以对 tmp/pids、tmp/sockets、public/uploads目录有写入权限

    1
    2
    3
    # chmod -R u+rwX tmp/pids/
    # chmod -R u+rwX tmp/sockets/
    # chmod -R u+rwX  public/uploads

        从配置案例复制一份unicorn配置文件,并修改配置文件中的timeout选项的值为600(防止仓库文件太大,拉取时间过长出现超时)

    1
    2
    3
    4
    5
    # su -
    # cd /home/git/gitlab
    # sudo -u git -H cp config/unicorn.rb.example config/unicorn.rb
    # vim gitlab/config/unicorn.rb
    修改timeout 600

        从配置案例复制一份rack attack配置文件

    1
    # sudo -u git -H cp config/initializers/rack_attack.rb.example config/initializers/rack_attack.rb

        为git用户配置git全局配置

    1
    2
    3
    # sudo -u git -H git config --global user.name "GitLab"
    # sudo -u git -H git config --global user.email "xxxxxx@qq.com"
    # sudo -u git -H git config --global core.autocrlf input

        配置redis连接

    1
    # sudo -u git -H cp config/resque.yml.example config/resque.yml

        配置GitLab数据库设置

    1
    2
    # sudo -u git cp config/database.yml.mysql config/database.yml
    # vim config/database.yml

        只需配置生产的部分(第一部分),用户名和密码

        

        配置好以后运行该命令

    1
    # sudo -u git -H chmod o-rwx config/database.yml

        配置GitLab绑定的域名或者IP

    1
    2
    3
    # vim config/gitlab.yml
    修改host为gitlab的域名为你主机的IP地址(有两项,test一项应该没有影响,不过也修改吧)
    host:主机IP

        安装Gems

    1
    # sudo -u git -H bundle install --deployment --without development test postgres aws

        可能会报错,还是大陆访问官网的问题,替换成https://ruby.taobao.org,然后再安装

        

        替换命令:

    1
    # sed -i '/^source/s/https://rubygems.org/https://ruby.taobao.org/' Gemfile

        安装GitLab shell

    1
    # sudo -u git -H bundle exec rake gitlab:shell:install[v2.5.4] REDIS_URL=unix:/var/run/redis/redis.sock RAILS_ENV=production

        初始化数据库

    1
    # sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production

        如果想要自己设置GitLab的root默认登陆密码则运行以下命令:

    1
    # sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production GITLAB_ROOT_PASSWORD=yourpassword

        默认登陆账号密码

    1
    2
    login.........root
    password......5iveL!fe

        配置启动脚本

    1
    # cp lib/support/init.d/gitlab /etc/init.d/

        配置日志切割

    1
    # cp lib/support/logrotate/gitlab /etc/logrotate.d/gitlab

        运行命令检测GitLab和它的环境是否正确

    1
    # sudo -u git -H bundle exec rake gitlab:env:info RAILS_ENV=production

        运行命令结果截图如下:

        

        拉取GitLab静态资源文件

    1
    # sudo -u git -H bundle exec rake assets:precompile RAILS_ENV=production

        修改配置文件的gitlab_url为主机IP或者域名

    1
    # vim /home/git/gitlab-shell/config.yml

        启动GitLab实例

    1
    # service gitlab start

    八、配置Nginx

      安装和配置开机启动(这里用yum安装,也可以自己编译安装)

    1
    2
    # yum install -y nginx
    # chkconfig nginx on

      下载Nginx配置文件,并命名为gitlab.conf

    1
    # wget -O /etc/nginx/conf.d/gitlab.conf https://gitlab.com/gitlab-org/gitlab-ce/raw/master/lib/support/nginx/gitlab

      把nginx加入到git组

    1
    2
    # usermod -a -G git nginx
    # chmod g+rx /home/git/

      修改gitlab.conf文件

    1
    2
    3
    4
    5
    # vim /etc/nginx/conf.d/gitlab.conf
    server unix:/home/git/gitlab/tmp/sockets/gitlab-workhorse.socket fail_timeout=0; 修改为 server unix:/home/git/gitlab/tmp/sockets/gitlab.socket fail_timeout=0;
    listen 0.0.0.0:80 default_server;   修改为 listen 80;
    listen [::]:80 default_server;       该行删除
    server_name YOUR_SERVER_FQDN;  修改为 server_name 主机IP

      启动Nginx

    1
    # service nginx start

    九、访问

      访问地址,http://主机IP或者域名,第一次登陆后就需要修改root用户的密码,然后再去掉GitLab的用户注册功能。到此GitLab搭建完毕!

      

  • 相关阅读:
    artDialog组件应用学习(二)
    artDialog组件应用学习(一)
    MVC Request.UrlReferrer为null
    jquery的toggle()方法
    Windows 和 Linux 下生成以当前时间命名的文件
    再提供一种解决Nginx文件类型错误解析漏洞的方法
    Nginx 1.5.2 + PHP 5.5.1 + MySQL 5.6.10 在 CentOS 下的编译安装
    架构师对话
    Nginx 0.8.x + PHP 5.2.13(FastCGI)搭建胜过Apache十倍的Web服务器
    Nginx 0.7.x + PHP 5.2.6(FastCGI)+ MySQL 5.1 在128M小内存VPS服务器上的配置优化
  • 原文地址:https://www.cnblogs.com/kaishirenshi/p/12559175.html
Copyright © 2020-2023  润新知