1、代码流水线管理

  • Pipeline名词顾名思义就是流水线的意思,因为公司可能会有很多项目。如果使用jenkins构建完成后,开发构建项目需要一项一项点击,比较麻烦。所以出现pipeline名词。
  • 代码质量检查完毕之后,我们需要将代码部署到测试环境上去,进行自动化测试。
新建部署代码项目
  1. 点击新建



  2. 填写构建任务的描述

  3. 新增构建步骤,执行Shell脚本

    • 温馨提示:执行命令主要涉及的是权限问题,我们要搞明白,jenkins是以什么权限来执行命令的。那么问题来了,我们现在192.168.56.11(Jenkins所在机器)上,如果在想192.168.56.12上执行命令。需要怎么做呢?如下

    • 我们做无秘钥有2种分案:

      1. 使用jenkins用户将秘钥分发给192.168.56.12上
      2. 使用root用户将秘钥分发给192.168.56.12上,如果使用root用户还要进行visudo授权。因为Web上默认执行命令的用户是jenkins
    • 1、我们使用root做密码验证

      • 这里我们的key已经做好,如果没做可以直接 ssh-keygen -t ras 来生成秘钥
      • 我们将192.168.56.11上的公钥复制到192.168.56.12上

        [root@linux-node1 ~]# cat .ssh/id_rsa.pub
      ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQChVQufrGwqP5dkzIU4ZwXCjRuSvMVGN5lJdvL/QFckmlVphWMsQw06VsPhgcI1NDjGbKOh5pbjrylyJUCig5YIJ1xuMOZ2YAK32SceMxnVhEb/G4wNb9VMsGQ/Vs4CxrU1HdATktH9zDAV4Qz81x2POYJW5B5LAvwZ4owqnIpZ7o3ya6xBxEvCIMSVtD17oKrNqAphsg+e68KvRexiNCEbCbRGGq3bKevgiDsWpSGnCYsJC0+cSrUxuzEO3G6AqGI/qR3nOeg91rOsoAP3FpFjBKgb/sXggkwwjmGIqFXJrUG+XmczeF4kG/rUrNbdy84e5RyHoIS3XKnJuRjTxHyD root@linux-node1 [root@linux-node2 ~]# vim .ssh/authorized_keys
      ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQChVQufrGwqP5dkzIU4ZwXCjRuSvMVGN5lJdvL/QFckmlVphWMsQw06VsPhgcI1NDjGbKOh5pbjrylyJUCig5YIJ1xuMOZ2YAK32SceMxnVhEb/G4wNb9VMsGQ/Vs4CxrU1HdATktH9zDAV4Qz81x2POYJW5B5LAvwZ4owqnIpZ7o3ya6xBxEvCIMSVtD17oKrNqAphsg+e68KvRexiNCEbCbRGGq3bKevgiDsWpSGnCYsJC0+cSrUxuzEO3G6AqGI/qR3nOeg91rOsoAP3FpFjBKgb/sXggkwwjmGIqFXJrUG+XmczeF4kG/rUrNbdy84e5RyHoIS3XKnJuRjTxHyD root@linux-node1 [root@linux-node1 ~]# ssh 192.168.56.12
      The authenticity of host '192.168.56.12 (192.168.56.12)' can't be established.
      ECDSA key fingerprint is b5:74:8f:f1:03:2d:cb:7d:01:28:30:12:34:9c:35:8c.
      Are you sure you want to continue connecting (yes/no)? yes
      Warning: Permanently added '192.168.56.12' (ECDSA) to the list of known hosts.
      Last login: Sat Dec 17 02:14:31 2016 from 192.168.56.1
      [root@linux-node2 ~]# ll
      total 4
      -rw-------. 1 root root 1021 Dec 13 05:56 anaconda-ks.cfg #现在SSH连接就不需要密码了 授权jenkins用户,使用visudo或者编辑配置文件/etc/sudoers
      [root@linux-node1 ~]# vim /etc/sudoers
      92 jenkins ALL=(ALL) NOPASSWD:/usr/bin/ssh
      #jenkins授权所有主机,不需要密码执行ssh。切记不要授权ALL
    • 我们在192.168.56.12上写一个简单shell脚本,检测是否可以执行成功。正式环境可以写一个自动化部署的脚本


     [root@linux-node2 ~]# echo "echo "hello word"" >demo.sh
    [root@linux-node2 ~]# chmod +x demo.sh
    [root@linux-node2 ~]# ll demo.sh
    -rwxr-xr-x 1 root root 16 Dec 17 02:24 demo.sh
    • jenkins编写执行脚本

  4. 然后我们点击立即构建

  5. 构建成功,如下

将代码质量管理和测试部署连接起来
  1. 安装jenkins插件parameterized(git钩子)

  2. 安装Jenkins的maven-plugin插件Pipeline Maven Integration Plugin

  3. 选择构建任务demo-deploy进行配置

  4. 在配置中增加构建后操作步骤Trigger parameterized build on other projects

  5. Projects to build是为构建设置一个项目。例如我们想构建完代码项目后执行测试的,这里就填写测试的构建任务。

    • Projects to build:需要构建的项目(job)名,如果有多个项目用,分隔。
    • Trigger when build is:构建触发的条件
      • Stable 成功(稳定)(等价于successful)
      • Unstable 不稳定
      • Stable or unstable but not failed 成功(稳定)或者不稳定,但是没有失败
      • Unstable or Failed but not stable 不稳定或者失败,但是没有成功(稳定)
      • Failed 失败
      • Complete (always trigger) 完成(总是触发)
    • Trigger build without parameters:构建的job不带参数(选择后下面的参数无效)
      • 没有特别的需求,参数可以忽略。
      • Add Parameters:添加参数
        • Boolean parameters 布尔参数(键值对)
        • Build on the same node 在同一个节点上构建
        • Current build parameters 当前构建参数
        • Parameters from properties file 从属性文件获取参数
        • Predefined parameters 预定义参数
        • Restrict matrix execution to a subset 限制矩阵执行的一个子集
        • Subversion revision svn版本
  6. 最后点击保存,点击构建。效果如下:



    • 这样我们每次点击demo-deploy,它就会在构建完成之后再对auto-deploy进行构建
将构建任务加入Build Pipeline View
  1. 下载pipeline,这样只需要构建一个项目,就会帮我们完成所有相关项目的构建

  2. 安装完成后,我们点击首页的+号,新建一个视图

  3. 点击OK

  4. pipeline 配置



  5. 点击保存后,pipeline视图如下:

  6. 点击Run

    • 这样就可以先对代码质量进行管理,然后就开始部署了
  7. 构建成功后:

  8. 这样我们下次想看pipeline视图的时候,点击上面的demo-pipeline即可

2、Jenkins + gitlab集成

Jenkins + gitlab集成后,实现的功能是:开发写好代码提交至gitlab上,即代码开始push到gitlab上之后,jenkins会自动帮我们立即构建。

  1. 安装一个gitlab钩子的插件,如下

  2. 安装完插件之后我们就开始配置钩子脚本

  3. 这里需要我们在服务器里面写一个令牌,在jenkins上也写一个令牌。这两个可以连接到一起就可以了。

    • 因为用到了令牌我们还需要在安装一个插件,否则将无法使用。因为令牌是需要登录之后才会有,所以需要有一个管理的插件,插件搜索:Build Aut,如下

  4. 为了令牌的安全性,我们在Jenkins所在机器上使用openssl生成一个

     [root@linux-node1 ~]# openssl rand -hex 10
    0a37c6d7ba1fe3472e26



5. 然后我们点击保存即可,因为jenkins上也提示我们需要在gitlab上添加钩子脚本,点击我们创建的项目,如下



6. 选中Webhooks



7. 使用Build插件后,url如下:

	http://192.168.56.11:8080/buildByToken/build?job=auto-deploy&token=0a37c6d7ba1fe3472e26
# auto-deploy=项目名称(构建时的项目名称)
# 0a37c6d7ba1fe3472e26=jenkins填写的令牌



8. 然后点击Add Webhook



9. 下方就会出现我们这个选项,我们点击Test进行测试



10. 测试结果



11. 向git服务器提交代码,验证是否可以自动部署:

	[root@linux-node1 ~]# echo "Build Token Root Plugin" > index.html
[root@linux-node1 ~]# git add index.html [root@saltmaster ~/weather]# git commit -m "text"
[root@linux-node1 ~]# git push origin master
  1. jenkins服务器的日志记录:

    [root@linux-node1 ~]# tail -f /var/log/jenkins/jenkins.log



13. jenkins项目构建:



14. 访问web界面验证代码是否最新

15. jenkins控制台输出信息如下:

持续集成与自动化部署---代码流水线管理及Jenkins和gitlab集成的更多相关文章

  1. 持续集成+自动化部署[代码流水线管理及Jenkins和gitlab集成]

    转载:https://www.abcdocker.com/abcdocker/2065 一.代码流水线管理 Pipeline名词顾名思义就是流水线的意思,因为公司可能会有很多项目.如果使用jenkin ...

  2. Asp.net Core 使用Jenkins + Dockor 实现持续集成、自动化部署(一):Jenkins安装

    2019/1/31更新,经过我一段时间的使用 建议大家的jenkins还是不要使用docker方式安装 建议大家的jenkins还是不要使用docker方式安装 建议大家的jenkins还是不要使用d ...

  3. Asp.net Core 使用Jenkins + Dockor 实现持续集成、自动化部署(二):部署

    前面又是废话 我之前写过: Asp.Net Core 程序部署到Linux(centos)生产环境(一):普通部署 Asp.Net Core 程序部署到Linux(centos)生产环境(二):doc ...

  4. .NET持续集成与自动化部署之路第二篇——使用NuGet.Server搭建公司内部的Nuget(包)管理器

    使用NuGet.Server搭建公司内部的Nuget(包)管理器 前言     Nuget是一个.NET平台下的开源的项目,它是Visual Studio的扩展.在使用Visual Studio开发基 ...

  5. Jenkins+Maven+Git搭建持续集成和自动化部署的配置手记

    前言    持续集成这个概念已经成为软件开发的主流,可以更频繁的进行测试,尽早发现问题并提示.自动化部署就更不用说了,可以加快部署速度,并可以有效减少人为操作的失误.之前一直没有把这个做起来,最近的新 ...

  6. .NET持续集成与自动化部署之路第一篇——半天搭建你的Jenkins持续集成与自动化部署系统

    .NET持续集成与自动化部署之路第一篇(半天搭建你的Jenkins持续集成与自动化部署系统) 前言     相信每一位程序员都经历过深夜加班上线的痛苦!而作为一个加班上线如家常便饭的码农,更是深感其痛 ...

  7. NET持续集成与自动化部署

    https://www.cnblogs.com/hunternet/p/9590287.html 相信每一位程序员都经历过深夜加班上线的痛苦!而作为一个加班上线如家常便饭的码农,更是深感其痛.由于我们 ...

  8. Jenkins学习总结(3)——Jenkins+Maven+Git搭建持续集成和自动化部署的

    前言 持续集成这个概念已经成为软件开发的主流,可以更频繁的进行测试,尽早发现问题并提示.自动化部署就更不用说了,可以加快部署速度,并可以有效减少人为操作的失误.之前一直没有把这个做起来,最近的新项目正 ...

  9. .NET 半天搭建Jenkins持续集成与自动化部署系统

    前言 相信每一位程序员都经历过深夜加班上线的痛苦!而作为一个加班上线如家常便饭的码农,更是深感其痛.由于我们所做的系统业务复杂,系统庞大,设计到多个系统之间的合作,而核心系统更是采用分布式系统架构,由 ...

随机推荐

  1. Nginx简单的负载均衡(一)

    Nginx是一个高性能的http和反向代理服务器,官方测试nginx能够支支撑5万并发链接,并且cpu.内存等资源消耗却非常低,运行非常稳定. 1.应用场景 1.http服务器.Nginx是一个htt ...

  2. C语言简单编译预处理-笔记

    预处理指令 所谓预处理,是指,在编译之前对程序源码进行初步的转换,产生新的源代码提供给编译器.预处理时主要完成:包含其他源文件,定义宏,根据条件决定编译时是否包含某些代码(>防止重复包含某些文件 ...

  3. nvm Nodejs 版本管理器 安装及配置

    1.如果已安装nodejs请先卸载干净 nodejs:删除C:\Program Files\nodejs 文件夹 npm:删除C:\Users\{用户名}\AppData\Roaming\npm 文件 ...

  4. 今日份Java

    package util; import java.sql.*; public class DBUtil { static String url = "jdbc:mysql://localh ...

  5. k8s 在Centos上 安装

    k8s安装步骤: 1.所有机器上执行以下命令,准备安装环境:(注意是所有机器,主机master,从机node都要安装) 1.1.安装epel-release源(EPEL (Extra Packages ...

  6. HTTP协议、时间戳、防盗链的一些概念

    HTTP协议 什么是HTTP协议 (HyperText Transfer Protocol,超文本传输协议)是因特网上应用最为广泛的一种网络传输协议,所有的WWW文件都必须遵守这个标准. HTTP是一 ...

  7. Pycharm控制台乱码问题

    PS:如我般的小白都会遇到中文乱码问题,那么怎么解决呢?其实非常简单,鼠标点点就好,请看下面: 如下乱码: 解决方法: 按如下步骤File→Settings→Editor→File Encodings ...

  8. 【巨杉数据库SequoiaDB】省级农信国产分布式数据库应用实践

    本文转载自<金融电子化> 原文链接:https://mp.weixin.qq.com/s/WGG91Rv9QTBHPsNVPG8Z5g 随着移动互联网的迅猛发展,分布式架构在互联网IT技术 ...

  9. Linux内核提权漏洞(CVE-2019-13272)

    漏洞描述 kernel / ptrace.c中的ptrace_link错误地处理了想要创建ptrace关系的进程的凭据记录,这允许本地用户通过利用父子的某些方案来获取root访问权限 进程关系,父进程 ...

  10. ActiveMQ的JMS消息可靠机制

    JMS消息可靠机制 ActiveMQ消息签收机制: 客戶端成功接收一条消息的标志是一条消息被签收,成功应答. 消息的签收情形分两种: 1.带事务的session 如果session带有事务,并且事务成 ...