• gitlab与jenkins的自动化部署(通过webhook与ansible)


    gitlab与jenkins的自动化部署(通过webhook与ansilble)


    1、部署介绍

    gitlab服务器:192.168.1.49:80
    jenkins服务器:192.168.1.49:8180
    ps:由于两个服务运行在同一台服务器上面,因此,为了保证jenkins服务器能拉取到 gitlab的代码,把root的用户的公钥分别上传到gitlab admin用户跟jenkins admin用户当中去。jenkins我没有使用默认的端口8080,主要是我公司的gerrit架构会用到这个8080端口,所以为了防止冲突,改为8180端口


    2、gitlab安装 

    a) 第一步:安装相应的在依赖包(postfix或者sendmail),其中选择internet site这种网络smtp邮件服务器这种方式来发送邮件,其他一些依赖包:curl openssh-server ca-certificates postfix

    If you install Postfix to send email please select 'Internet Site' during setup. Instead of using Postfix you can also use Sendmail or configure a custom SMTP server . If you wish to use Exim, please configure it as an SMTP server.
    On Centos 6 and 7, the commands below will also open HTTP and SSH access in the system firewall.

    操作命令:
    sudo apt-get install curl openssh-server ca-certificates postfix


    b) 第二步:Add the GitLab package server and install the package. 下载gitlab安装包,并且安装
    方法1、增加yum源链接,使用sduo apt-get install gitlab-ee
    Apt-get安装Curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh|sudo bash
    操作命令:
    sudo apt-get install gitlab-ce

    If you are not comfortable installing the repository through a piped script, you can find the entire script here .
    Alternatively you can select and download the package manually and install using
    方法2、deb包安装下载deb包,然后安装

    下载: sudo wget https://packages.gitlab.com/gitlab/gitlab-ee
    安装: sudo dpkg -i gitlab-ce_8.1.2-ee.0_amd64.deb

    建议一般下载后再装

    c)第三步,启用配置,并且启动 GitLab
    操作命令:
    sudo gitlab-ctl reconfigure

    d) 第四步:打开网页,进行注册,使用默认密码
    http://192.168.0.177:80
    Username: rootPassword: 5iveL!fe

    e) 第五步:2.1.6. Upload your license(EE版本需要认证,CE) 这步我操作的时候是没有的
    Go toAdmin > Licenseand upload your.gitlab-licensefile.
    Don't have a license yet? Get a subscription.

    其实只要下载到gitlab ce包(ce是社区版,不用验证的),直接安装就行了,启动命令为gitlab-ctl reconfigure


    3、jenkins安装 

    a) Install Jenkins
    wget -q -O - https://jenkins-ci.org/debian/jenkins-ci.org.key | sudo apt-key add -
    sudo sh -c 'echo deb http://pkg.jenkins-ci.org/debian binary/ > /etc/apt/sources.list.d/jenkins.list'
    sudo apt-get update
    sudo apt-get install jenkins

    b) Starting Jenkins


    nohup java -Dorg.jenkinsci.plugins.gitclient.Git.timeOut=60 -Dfile.encoding=UTF-8 -Dhudson.DNSMultiCast.disabled=true -jar /usr/share/jenkins/jenkins.war --httpPort=8180 > /var/log/jenkins_log 2>&1 &

    (注意--httpPort=8180放在后面)

    c) 开启 jenkins页面为:192.168.0.179:8180
    http://xxxxx:8180/

    d) 插件安装
    Git Plugin
    SSH Plugin
    URL Trigger Plugin
    Gerrit Trigger Plugin
    Gitlab Hook
    Gitlab Merge Request Builder
    GitLab Plugin

    e) 注册用户
    先开启用户注册按钮,用户注册完毕以后,关闭用户注册


    4、配置jenkins拉取gitlab项目的账号的sshkey

    由于两个服务运行在同一台服务器上面,因此,为了保证jenkins服务器能拉取到 gitlab的代码,把root的用户的公钥分别上传到gitlab admin用户跟jenkins admin用户当中去。步骤我就不写了!


    5、配置jenkins项目

      1、登录192.168.1.49:8180
    点击新建:



    依次填写相关信息:(注意,项目安全这块是在日常管理中才会用到,如果简单测试可以忽略)



    源码管理:


    触发器:

    我这里选择得比较多,有push触发,也有merge触发

    构建:(通过shell来构建)


    我这里是通过简单的ansible来控制web服务器的压缩包scp,tar解压,还有指定软联接
    #变量WORKSPACE、GIT_URL是jenkins默认内置的变量

    #!/bin/bash 
    
    #变量WORKSPACE,GIT_URL是jenkins默认提供的变量
    cd $WORKSPACE
    
    #截取giturl中的产品
    product=`echo $GIT_URL| awk -F"/" '{print $NF}'|sed 's/.git//g'`
    
    #截取代码当前的前七位sha值
    sha=`cat .git/HEAD|cut -b 1-7`
    
    #指定日期
    d=`date +"%Y%m%d"`
    
    #指定压缩包的路径与包全称,包名(不带后缀)
    p_pathname=/tmp/"$product"_"$d"_"$sha".tar.gz
    p_name="$product"_"$d"_"$sha".tar.gz
    p_productname="$product"_"$d"_"$sha"
    
    #本地压缩
    tar -cf $p_pathname  $WORKSPACE/*
    
    #指定web服务器的包的存放位置
    p_store=/var/prod/"$product"/"$d"
    
    #指定web服务器的包解压位置
    p_target=$p_store/$p_productname
    
    #指定nginx网页代码位置
    www=/mnt/www/launcher.szprize.cn
    
    #dev代表web服务器,确保包解压路径存在
    ansible dev  -m shell -a "mkdir -p $p_target "
    #dev代表web服务器,ansible copy模块远程复制
    ansible dev -m copy -a "src=$p_pathname dest=$p_store/"
    #ansible 远程解压
    ansible dev -m shell -a "tar -xf $p_store/$p_name -C $p_target"
    #ansible 软联接
    ansible dev -m file -a "src=$p_target dest=$www state=link"#!/bin/bash 

    jenkins这边就配置完了

    但是注意:jenkins跟gitlab怎么通信触发呢?

    大家请留意触发器那块有一句话:
    Build when a change is pushed to GitLab. GitLab CI Service URL: http://192.168.1.49:8180/project/launcher
    它的意思的,gitlab ci接口可以通过http://192.168.1.49:8180/project/launcher来连接两者的有关系。



    6、gitlab设置webhook

    在对应的gitlab项目设置当中,设置webhooks

    当然,这里也可以设置triger事件:

    保存后会在底部,生成webhook,点击test,看jenkins界面是否触发了!





    登录jenkins界面:192.168.1.49:8180

    然后大功告成!


  • 相关阅读:
    Redis过期机制
    vim使用
    ex command in Linux with examples
    【转】Linux 文档编辑 : ex 命令详解
    vscode go语言环境搭建
    golang slice a 的地址和a[0]的地址不一样
    文件加锁,作用是用来做什么?以及使用细节
    文件锁
    go创建指定大小的文件,获取文件大小
    go 实现内存映射和进程间通信
  • 原文地址:https://www.cnblogs.com/to-be-rich/p/7655838.html
Copyright © 2020-2023  润新知