gitlab安装介绍
GitLab简介 GitLab 是一个用于仓库管理系统的开源项目。使用Git作为代码管理工具,并在此基础上搭建起来的web服务。可 通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可 以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊 天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用。
常用的网站:
官网:https://about.gitlab.com/
国内镜像:https://mirrors.tuna.tsinghua.edu.cn/gitlab‐ce/yum/
安装环境:
1、 CentOS 6或者7
2、 2G内存(实验)生产(至少4G)
3、 安装包:gitlab‐ce‐10.2.2‐ce
4、 禁用防火墙,关闭selinux
1.yum install ‐y curl policycoreutils‐python openssh‐server # 安装依赖
2.rz ‐bye gitlab‐ce‐10.2.2‐ce.0.el7.x86_64.rpm # 上传gitlab安装包 下载方式可通过
3.rmp -ivh gitlab‐ce‐10.2.2‐ce.0.el7.x86_64.rpm 安装gitlab
4.vim /etc/gitlab/gitlab.rb # gitlab 配置文件
更改url地址为本机IP地址 external_url 'http://10.0.0.160'
5.gitlab‐ctl reconfigure # 更改配置文件后需重新配置
/opt/gitlab/ # gitlab的程序安装目录 /var/opt/gitlab # gitlab目录数据目录 /var/opt/gitlab/git‐dfata # 存放仓库数据
gitlab‐ctl status # 查看目前gitlab所有服务运维状态
gitlab‐ctl stop # 停止gitlab服务 gitlab‐ctl stop nginx # 单独停止某个服务
gitlab‐ctl tail # 查看所有服务的日志 Gitlab的服务构成:
nginx: 静态web服务器
gitlab‐workhorse: 轻量级的反向代理服务器
logrotate:日志文件管理工具 postgresql:数据库
redis:缓存数据库
sidekiq:用于在后台执行队列任务(异步执行)。(Ruby)
unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。(Ruby Web Server,主要使用Ruby编写)
gitlab汉化:
1、下载汉化补丁
git clone https://gitlab.com/xhang/gitlab.git 2、查看全部分支版本
git branch ‐a
3、对比版本、生成补丁包
git diff remotes/origin/10‐2‐stable remotes/origin/10‐2‐stable‐zh > ../10.2.2‐zh.diff
4、停止服务器
gitlab‐ctl stop
5、打补丁
patch ‐d /opt/gitlab/embedded/service/gitlab‐rails ‐p1 < /tmp/10.2.2‐zh.diff
6、启动和重新配置
gitlab‐ctl start
gitlab‐ctl reconfigure
gitlab的使用
1、配置外观
管理区域‐外观
2、关闭自动注册‐可根据实际需求操作
管理区域‐设置‐关闭自动注册
3、创建组‐用户‐项目
创建组
image.png
image.png
创建用户
image.png
image.png
image.png
设置密码
image.png
4、把用户添加到组里面
管理区域-选择创建的oldboy组进行添加用户、权限给开发人员-增加用户到群组
image.png
5、创建仓库
管理区域-创建仓库
image.png
6、登陆dev用户测试是否能看到空的git‐test仓库
7、添加ssh‐keys到gitlab 注:一个服务器的key只能添加到一个gitlab服务器上,一个用户可以添加多个key ssh‐keygen ‐t rsa
8、添加远程仓库、推送本地代码到远程仓库
git remote add origin git@10.0.0.203:oldboy/get_test.git # 添加远程仓库
git remote rename origin old‐origin # 远程 origin 如果已经存在则重新命名或者新添加仓库名 称不同
git push ‐u origin ‐‐all # 推送代码到远程仓库
8、克隆代码到另外一台主机
如果不做认证会让输入gitlab的密码、我们使用key进行认证
ssh‐keygen ‐t rsa
把公钥复制到dev用户下进行测试 然后在克隆代码
git clone git@10.0.0.203:oldboy/get_test.git
测试推送代码到dev下
git branch dev
git checkout dev
touch dev
git add .
git commit ‐m "add dev"
git push ‐u origin dev # 推送dev分支到远程仓库
提交合并请求进行分支合并到master主分支
合并后在gitlab服务端master上没有dev、要先进行pull
cd /root/git_data
git pull
9、设置保护主分支
image.png测试dev分支推送代码则显示为拒绝,如果还是可以推送请查看配置保护分支选项
[root@web01 get_test]# git checkout master
[root@web01 get_test]# git merge dev
[root@web01 get_test]# git push ‐u origin master
10、返回master端测试推送,由于其他分支进行推送,和master端内容不一致,所以无法进行推送,使用git pull把代码拉取到本地,或者git fetch 把代码拉取到本地仓库后进行合并(注意:git pull = git tetch+git merge)
设置保护主分支,不让开发直接提交代码,怎么合并分支请求
1.分支用户下操作
image.png image.png image.png
2.root用户下操作
image.png
jenkins
官网 jenkins.io Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开 放易用的软件平台,使软件的持续集成变成可能。
1、上传jdk和jenkins包
[root@jenkins wzt]# ll
total 238448
-rw-r--r-- 1 root root 170023183 Aug 9 14:49 jdk-8u181-linux-x64.rpm
-rw-r--r-- 1 root root 74141787 Aug 9 14:49 jenkins-2.99-1.1.noarch.rpm
2、安装rpm包
[root@jenkins wzt]# rpm -ivh jenkins-2.99-1.1.noarch.rpm
[root@jenkins wzt]# rpm -ivh jdk-8u181-linux-x64.rpm
3、配置jenkins/etc/sysconfig/jenkins
启动用户修改为root JENKINS_USER="root"
4、启动并加入开机自启
systemctl enable jenkins
systemctl start jenkins
#进入页面之后
系统管理--全局工具配置--高级--升级站点--aliyun
#上传插件
cd /var/lib/jenkins/plugins
上传plugins.tar.gz
tar xf plugins.tar.gz 解压压缩包
重启jenkins服务器
systemctl restart jenkins
1、如果jenkins启动用户是jenkins,则无法拉取代码,因为我们是把root的公钥推送到gitlab普通用户
dev下(dev属于ops组,所以可以拉取代码)
2、jenkins用户启动,需要把root公钥放到deploy下
项目--settings--repository-deploy keys
网友评论