美文网首页
gitlab和jenkins

gitlab和jenkins

作者: Freestyle_0f85 | 来源:发表于2019-11-09 16:06 被阅读0次

    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

    相关文章

      网友评论

          本文标题:gitlab和jenkins

          本文链接:https://www.haomeiwen.com/subject/nhrnbctx.html