前言
本文主要内容:
1、参考或在拷贝官网等其他网络的指导文档,记录个人在阿里云ECS服务器[配置参数: ubuntu_16.04 1核 2GB内存 20GB 高效磁盘 + 40GB 高效磁盘]安装GitLab version 13.6.4的过程。
2、如何使用GitLab
1、GitLab是基于Rubby on Rails的开源版本管理系统,实现自托管的Git项目仓库,可以通过web页面访问公开的或在私有的项目。
2、GitLab与Github类似,可以实现浏览原代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。
3、团队成员可以利用内置的简单聊天程序(Wall)进行交流。
4、它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。
Git的家族成员
Git:是一种版本控制系统,是一个命令,是一种工具。
Gitlib:是用于实现Git功能的开发库。
Github:是一个基于Git实现的在线代码托管仓库,包含一个网站界面,向互联网开放。
GitLab:是一个基于Git实现的在线代码仓库托管软件,你可以用gitlab自己搭建一个类似于Github一样的系统,一般用于在企业、学校等内部网络搭建git私服。
Gitlab的服务构成
Nginx:静态web服务器。
gitlab-shell:用于处理Git命令和修改authorized keys列表。
gitlab-workhorse:轻量级的反向代理服务器。
logrotate:日志文件管理工具。
postgresql:数据库。
redis:缓存数据库。
sidekiq:用于在后台执行队列任务(异步执行)。
unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。
GitLab工作流程
Git Shell
GitLab Shell有两个作用:(1)为GitLab处理Git命令;(2)修改authorized keys列表。
当通过SSH访问GitLab Server时,GitLab Shell会:
1)限制执行预定义好的Git命令(git push, git pull, git annex)
2)调用GitLab Rails API 检查权限
3)执行pre-receive钩子(在GitLab企业版中叫做Git钩子)
4)执行你请求的动作 处理GitLab的post-receive动作
5)处理自定义的post-receive动作当通过http(s)访问GitLab Server时,工作流程取决于你是从Git仓库拉取(pull)代码还是向git仓库推送(push)代码。
1)如果你是从Git仓库拉取(pull)代码,GitLab Rails应用会全权负责处理用户鉴权和执行Git命令的工作;
2)如果你是向Git仓库推送(push)代码,GitLab Rails应用既不会进行用户鉴权也不会执行Git命令,它会把以下工作交>由GitLab Shell进行处理:
GitLab Workhorse
GitLab Workhorse是一个敏捷的反向代理。它会处理一些大的HTTP请求,比如文件上传、文件下载、Git push/pull和Git包下载。其它请求会反向代理到GitLab Rails应用,即反向代理给后端的unicorn。
GitLab环境部署
小知识:阿里云ECS服务器的内存2GB偏小,默认无swap内存,首次安装GitLab后,导致ECS服务器,访问超级缓慢。同时,目前银两不足,需求不够旺盛,只得卸载Gitab,然后根据云服务器 ECS Linux SWAP 配置概要说明,配置4GB的swap交换分区解决此问题。有时间,学习配置GitLab后端,关闭非必要的高内存服务。
方法一:镜像部署
方法二:手动在线部署
$su //切换root用户
//1)更新
#apt-get update
//2)安装依赖项
#apt-get install -y curl openssh-server ca-certificates
#apt-get -y install language-pack-zh-hans //语言包
#apt-get install -y postfix
//3)将GitLab包添加到仓库
#curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bash
//4)安装
#apt-get install gitlab-ee
//5)修改IP配置地址
#vim /etc/gitlab/gitlab.rb
EXTERNAL_URL="http://localhost:19000"
//6)重新读取配置与测试
#gitlab-ctl reconfigure
#gitlab-ctl status
//7)测试
#curl http://localhost:19000
<html><body>You are being <a href="http://localhost:19000/users/sign_in">redirected</a>.</body></html>
//8)配置ECS的安全组规则
// NOTICE:因为是阿里云ECS服务器,需要采取参考
// 参考https://jingyan.baidu.com/article/03b2f78c31bdea5ea237ae88.html
// 配置阿里云ECS服务器放行
说明:配置ECS的安全组规则
1、登录控制台-选择ECS
2、选择安全组-选择配置规则
3、参考添加新规则
方法三:手动离线部署
GitLab使用
登录GitLab
1、在浏览器,输入ECS的公网IP地址以及端口,访问GitLab的Web管理页面。第一次配置,需要配置root的用户名与密码。
2、输入用户名,密码登录GitLab的Web管理页面。
在GitLab的Web管理页面,创建Project
使用ssh-keygen生成密钥文件.ssh/id_rsa.pub。
使用Gitab的Web管理页面创建项目
1、在GitLab的Web管理页面,点击-Create A Project
2、输入Project Name、Project Description、Visiablity Level;
3、如图,完成项目创建
4、添加导入ssh-keygen生成的key
1)点击右上角的用户头像,选择Settings
2)选择SSH Keys
拷贝 ~/.ssh/id_rsa.pub 的公钥,然后点击Add Key完成公钥的添加
3)配置~/.ssh.id_rsa的私钥文件在Git客户机生效
$vim ~/.ssh/config //创建或在修改ssh的配置文件
添加下面的内容:
5、项目地址,如图所示
使用Git命令,配置本地git仓库,克隆远程git仓库,并提交更新
~/IdeaProjects$git config --global user.name "root" //配置用户名
~/IdeaProjects$git config --global user.email "njjackzhong@126.com" //配置email
~/IdeaProjects$git clone git@aliyun-ecs:root/core-java.git //clone代码
~/IdeaProjects$cd learn-java //文件在此处
~/IdeaProjects/learn-java$cp -r core-java.iml .idea/ src/ ../core-java/ //拷贝文件
~/IdeaProjects/learn-java$git add . //将.文件夹下的所有文件添加到git的index中
~/IdeaProjects/learn-java$git commit -m "init commit" //提交本地仓库
~/IdeaProjects/learn-java$git push //push到部署在ECS的Git仓库
问题
问题一:提示LANG或在LC_*错误
initdb.bin: invalid locale settings; check LANG and LC_* environment variables
解决办法:
#apt-get -y install language-pack-zh-hans
问题二:在卸载gitlab然后再次安装执行sudo gitlab-ctl reconfigure的时候往往会出现:ruby_block[supervise_redis_sleep] action run,会一直卡无法往下进行!
解决方案:
1、按住CTRL+C强制结束;
2、运行:sudo systemctl restart gitlab-runsvdir;
3、再次执行:sudo gitlab-ctl reconfigure
GitLab官网
GitLab的安装及使用
gitlab从安装到维护
指定ssh key访问git
安装GitLab出现ruby_block[supervise_redis_sleep] action run