Centos 6.5 GitLab安装配置搭建详细过程 GitLab搭建详细过程

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,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搭建完毕!

  

原文地址:https://www.cnblogs.com/cndevops

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


linux下开机自启: 在/etc/init.d目录下新建文件elasticsearch 并敲入shell脚本: 注意, 前两行必须填写,且要注释掉。 第一行为shell前行代码,目的告诉系统使用shell。 第二行分别代表运行级别、启动优先权、关闭优先权,且后面添加开机服务会用到。 shell脚本
1、因为在centos7中/etc/rc.d/rc.local的权限被降低了,所以需要赋予其可执行权 chmod +x /etc/rc.d/rc.local 2、赋予脚本可执行权限假设/usr/local/script/autostart.sh是你的脚本路径,给予执行权限 chmod +x /usr
最简单的查看方法可以使用ls -ll、ls-lh命令进行查看,当使用ls -ll,会显示成字节大小,而ls- lh会以KB、MB等为单位进行显示,这样比较直观一些。 通过命令du -h –max-depth=1 *,可以查看当前目录下各文件、文件夹的大小,这个比较实用。 查询当前目录总大小可以使用d
ASP.NET Core应用程序发布linux在shell中运行是正常的。可一但shell关闭网站也就关闭了,所以要配置守护进程, 用的是Supervisor,本文主要记录配置的过程和过程遇到的问题 安装Supervisor 1 yum install python-setuptools
设置时区(CentOS 7) 先执行命令timedatectl status|grep 'Time zone'查看当前时区,如果不是时区(Asia/Shanghai),则需要先设置为中国时区,否则时区不同会存在时差。 #已经是Asia/Shanghai,则无需设置 [root@xia
vim /etc/sysconfig/network-scripts/ifcfg-eth0 BOOTPROTO="static" ONBOOT=yes IPADDR=192.168.8.106 NETMASK=255.255.252.0 GATEWAY=192.168.
一、安装gcc依赖 由于 redis 是用 C 语言开发,安装之前必先确认是否安装 gcc 环境(gcc -v),如果没有安装,执行以下命令进行安装 [root@localhost local]# yum install -y gcc 二、下载并解压安装包 [root@localhost local
第一步 On CentOS/RHEL 6.*: $ sudo rpm -Uvh http://li.nux.ro/download/nux/dextop/el6/x86_64/nux-dextop-release-0-2.el6.nux.noarch.rpm On CentOS/RHEL 7: $
/// <summary> /// 取小写文件名后缀 /// </summary> /// <param name="name">文件名</param> /// <returns>返回小写后缀,不带“.”</ret
which nohup .bash_profile中并source加载 如果没有就安装吧 yum provides */nohup nohup npm run start & nohup ./kibana &
1.1 MySQL安装 1.1.1 下载wget命令 yum -y install wget 1.1.2 在线下载mysql安装包 wget https://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm 1.1.3 安装My
重启 reboot shutdown -r now init 6 关闭 init 0 shutdown -h now shutdown -h 20:25 #8点25关机查看内存 free CPU利用率 top 日期 date 设置时间 date 033017002015 #月日时间年 日历 cal
1、firewalld的基本使用 启动: systemctl start firewalld 关闭: systemctl stop firewalld 查看状态: systemctl status firewalld 开机禁用 : systemctl disable firewalld 开机启用 :
1 下载并安装MySQL官方的 Yum Repository wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm 使用上面的命令就直接下载了安装用的Yum Repository,大概
CentOS6.x CentOS6中转用Upstrat代替以前的init.d/rcX.d的线性启动方式。 一、相关命令 通过initctl help可以查看相关命令 [root@localhost ~]# initctl help Job commands: start Start job. sto
1、使用命令:df -lk 找到已满磁盘 2、使用命令:du --max-depth=1 -h 查找大文件,删除
ifconfig:查看网卡信息 网卡配置文件位置: /etc/sysconfig/network-scripts/文件夹 nmtui:配置网卡 netstat -tlunp:查看端口信息 端口信息存储位置: /etc/services文件 route:查看路由信息 wget:下载网路文件,例如 wg
ps -ef:查看所有进程, ps -ef |grap firewalld 查看与firewalld相关的进程 which :查看进程:which firewalld kill 进程id:杀掉进程 kill 640,强制杀:kill -9 640 man:查看帮助,例如 man ps 查看
useradd:添加用户 useradd abc,默认添加一个abc组 vipw:查看系统中用户 groupadd:添加组groupadd ccna vigr:查看系统中的组 gpasswd:将用户abc添加到ccna组 gpasswd -a abc ccna groups abc:查看用户abc属