文章目录
jenkins+gitlab实现自动化部署平台
git
版本控制系统,顾名思义,版本控制就是一个管理我们文件版本的软件系统。同一份文件中会有不同的版本,编辑者会根据需求对新版本文件添加(修改、删除)内容等
gitlab
官网
私人代码仓库
公开的对应的是github
gitlab介绍
推荐阿里云下载
是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。
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 Shell
GitLab Shell有两个作用:为GitLab处理Git命令、修改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)代码。
如果你是从Git仓库拉取(pull)代码,GitLab Rails应用会全权负责处理用户鉴权和执行Git命令的工作;
如果你是向Git仓库推送(push)代码,GitLab Rails应用既不会进行用户鉴权也不会执行Git命令,它会把以下工作交由GitLab Shell进行处理:
1.调用GitLab Rails API 检查权限
2.执行pre-receive钩子(在GitLab企业版中叫做Git钩子)
3.执行你请求的动作
4.处理GitLab的post-receive动作
5.处理自定义的post-receive动作
GitLab Workhorse
GitLab Workhorse是一个敏捷的反向代理。它会处理一些大的HTTP请求,比如文件上传、文件下载、Git push/pull和Git包下载。其它请求会反向代理到GitLab Rails应用,即反向代理给后端的unicorn。
安装
配置要求:内存2G以上
Gitlab环境部署
阿里云购买也可以,不要钱
手动部署:
1、配置yum源
vim /etc/yum.repos.d/gitlab-ce.repo
复制以下内容:
[gitlab-ce]
name=gitlab-ce
baseurl=http://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6
Repo_gpgcheck=0
Enabled=1
Gpgkey=https://packages.gitlab.com/gpg.key
2、更新本地yum缓存
yum makecache
3、安装GitLab社区版
yum intall gitlab-ce #自动安装最新版
yum install gitlab-ce-x.x.x #安装指定版本
4.
vim /etc/gitlab/gitlab.rb 编辑配置文件写入当前主机IP,修改gitlab仓库路径
external_url '当前主机IP'
gitlab-ctl reconfigure 初始化gitlab
gitlab-ctl restart 重载服务
在网页访问输入密码大于八位即可;首次登录会强制用户修改密码。密码修改成功后,输入新密码进行登录。
'GitLab常用命令
gitlab-ctl start # 启动所有 gitlab 组件;
gitlab-ctl stop