博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Ubuntu 16.04系统下搭建GitLab Server
阅读量:4092 次
发布时间:2019-05-25

本文共 3365 字,大约阅读时间需要 11 分钟。

一:"git" 家族的成员
首先解决一个容易混淆的问题,我也经常搞混:
git
是一种版本控制系统,是一个命令,是一种工具
gitlib
是用于实现git功能的开发库
github
是一个基于git实现的在线代码托管仓库,包含一个网站界面,向互联网开放
gitlab
是一个基于git实现的在线代码仓库托管软件,你可以用gitlab自己搭建一个类似于github一样的系统,一般用于在企业、学校等内部网络搭建git私服
二:安装GitLab的需求
硬件需求 
存储 
存储空间的大小主要取决于你将存储的Git仓库的大小。但根据 rule of thumb(经验法则) 你应该考虑多留一些空间用来存储Git仓库的备份。
如果你想使用弹性的存储空间,你可以考虑在分配分区的时候使用LVM架构,这样可以在后期需要的清空下添加硬盘在增加存储空间。
除此之外你还可以挂在一个支持NFS的分卷,比如NAS、 SAN、AWS、EBS。
如果你的服务器有足够大的内存和CPU处理性能,GitLab的响应速度主要受限于硬盘的寻道时间。 使用更快的硬盘(7200转)或者SSD硬盘会很大程度的提升GitLab的响应速度。
CPU 
·1 核心CPU最多支持100个用户,所有的workers和后台任务都在同一个核心工作这将导致GitLab服务响应会有点缓慢。
·2核心 支持500用户,这也是官方推荐的最低标准。
·4 核心支持2,000用户。
·8 核心支持5,000用户。
·16 核心支持10,000用户。
·32 核心支持20,000用户。
·64 核心支持40,000用户。
Memory 
安装使用GitLab需要至少4GB可用内存(RAM + Swap)! 由于操作系统和其他正在运行的应用也会使用内存, 所以安装GitLab前一定要注意当前服务器至少有4GB的可用内存. 少于4GB内存会导致在reconfigure的时候出现各种诡异的问题, 而且在使用过程中也经常会出现500错误.
·1GB 物理内存 + 3GB 交换分区 是最低的要求,但我们 强烈反对 使用这样的配置。 
·2GB 物理内存 + 2GB 交换分区 支持100用户,但服务响应会很慢。
·4GB 物理内存 支持100用户,也是 官方推荐 的配置。
·8GB 物理内存 支持 1,000 用户。
·16GB 物理内存 支持 2,000 用户。
·32GB 物理内存 支持 4,000 用户。
·64GB 物理内存 支持 8,000 用户。
·128GB 物理内存 支持 16,000 用户。
·256GB 物理内存 支持 32,000 用户。
即使你服务器有足够多的RAM, 也要给服务器至少分配2GB的交换分区。 因为使用交换分区可以在你的可用内存波动的时候降低GitLab出错的几率。
注意: Sidekiq的25个workers在查看进程(top或者htop)的时候会发现它会单独显示每个worker,但是它们是共享内存分配的,这是因为Sidekiq是一个多线程的程序。 
三:在Ubuntu 16.04搭建GitLab服务器操作过程
引言:在Ubuntu 16.04操作系统中搭建GitLab服务器(参考资料:https://about.gitlab.com/downloads/#ubuntu1604)
1.安装依赖包,运行命令
非root用户:sudo apt-get install curl openssh-server ca-certificates postfix
执行完成后,出现邮件配置,选择Internet那一项(不带Smarthost的)
详解
curl:是利用URL语法在命令行方式下工作的开源文件传输工具。
openssh-server:提供开放源代码的加密通讯软件
ca-certificates:现在很多网站和服务都使用了HTTPS进行链路加密、防止信息在传输中间节点被窃听和篡改。HTTPS的启用都需要一个CA证书,以保证加密过程是可信的。
postfix:电子邮件服务器
2.利用清华大学的镜像(https://mirror.tuna.tsinghua.edu.cn/help/gitlab-ce/)来进行主程序的安装。 
首先信任 GitLab 的 GPG 公钥:
curl https://packages.gitlab.com/gpg.key 2> /dev/null | sudo apt-key add - &>/dev/null
(如果下载过程中访问超时出错,请用curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash,并直接跳入gitlab-ce安装)
然后通过root用户利用vi新建并打开文件/etc/apt/sources.list.d/gitlab-ce.list,加入下载地址:
deb https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu xenial main
最后安装 gitlab-ce:
sudo apt-get update
sudo apt-get install gitlab-ce
3.执行配置并启动gitlab Server
sudo gitlab-ctl reconfigure

4.打开 sshd 和 postfix 服务

service sshd start 

systemctl postfix status //查看postfix状态

service postfix start 
5.了使 GitLab 社区版的 Web 界面可以通过网络进行访问,我们需要允许 80 端口通过防火墙,这个端口是 GitLab 社区版的默认端口。为此需要运行下面的命令(此操作可省略)
sudo iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT 
6.检查GitLab是否安装好并且已经正确启动运行,输入下面的命令
sudo gitlab-ctl status
获得如下几项相同启动结果,则说明GitLab运行正常
run: gitlab-workhorse: (pid 1148) 884s; run: log: (pid 1132) 884s
run: logrotate: (pid 1150) 884s; run: log: (pid 1131) 884s
run: nginx: (pid 1144) 884s; run: log: (pid 1129) 884s
run: postgresql: (pid 1147) 884s; run: log: (pid 1130) 884s
run: redis: (pid 1146) 884s; run: log: (pid 1133) 884s
run: sidekiq: (pid 1145) 884s; run: log: (pid 1128) 884s
run: unicorn: (pid 1149) 885s; run: log: (pid 1134) 885s
7.在浏览器地址栏中输入:http://127.0.0.1,即可访问GitLab的Web页面

注意:第一次登录web页面时需要对root用户设置密码

8.gtilab部分命令
sudo gitlab-ctl stop停止
sudo gitlab-ctl start开启
sudo gitlab-ctl restart重启
sudo gitlab-ctl status查看状态
sudo gitlab-ctl reconfigure确认配置(修改配置后,必须执行)
sudo gitlab-ctl tail 查看日志
9.卸载gitlab
执行如下四步:
sudo gitlab-ctl uninstall
sudo dpkg -r gitlab-ce
sudo rpm -e gitlab-ce
reboot(重启)

转载地址:http://cbjii.baihongyu.com/

你可能感兴趣的文章
SQL基础总结——20150730
查看>>
SQL join
查看>>
JavaScript实现页面无刷新让时间走动
查看>>
CSS实例:Tab选项卡效果
查看>>
前端设计之特效表单
查看>>
前端设计之CSS布局:上中下三栏自适应高度CSS布局
查看>>
Java的时间操作玩法实例若干
查看>>
JavaScript:时间日期格式验证大全
查看>>
pinyin4j:拼音与汉字的转换实例
查看>>
XML工具代码:SAX从String字符串XML内获取指定节点或属性的值
查看>>
时间日期:获取两个日期相差几天
查看>>
责任链模式 Chain of Responsibility
查看>>
高并发与大数据解决方案概述
查看>>
解决SimpleDateFormat线程安全问题NumberFormatException: multiple points
查看>>
MySQL数据库存储引擎简介
查看>>
处理Maven本地仓库.lastUpdated文件
查看>>
Kafka | 请求是怎么被处理的?
查看>>
Java并发编程1-线程池
查看>>
CentOS7,玩转samba服务,基于身份验证的共享
查看>>
计算机网络-网络协议模型
查看>>