页面“Docker and docker-compose快速安装”与“Pipeline”之间的差异

来自linux中国网wiki
(页面间的差异)
跳到导航 跳到搜索
 
 
第1行: 第1行:
=参考=
+
=Jenkins Pipeline 简介=
[[Docker-compose教程]]
+
Jenkins pipeline 是 Jenkins 2.0 的精髓,,是帮助 Jenkins 实现 CI 到 CD 转变的重要角色。
  
[[Docker 镜像瘦身优化]]
+
简单来说,就是一套运行于 Jenkins 上的工作流框架,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂发布流程。
  
 +
Pipeline 的实现方式是一套 Groovy DSL,任何发布流程都可以表述为一段 Groovy 脚本,并且 Jenkins 支持从代码库直接读取脚本,从而实现了 Pipeline as Code 的理念。
  
[https://gitee.com/zhengqingya/docker-compose/tree/master docker-compose安装所有常用服务]
+
[https://www.cnblogs.com/itech/p/5633948.html  jenkins2 pipeline入门 ]
  
=[[Docker国内镜像的配置及使用]]=
+
官方文档
 +
流水线可以通过以下任一方式来创建:
  
=最后改DNS8.8.4.4=
+
    通过 Blue Ocean - 在 Blue Ocean 中设置一个流水线项目后,Blue Ocean UI 会帮你编写流水线的 Jenkinsfile 文件并提交到源代码管理系统。
  
=docker on cenos7=
+
    通过经典 UI - 你可以通过经典 UI 在 Jenkins 中直接输入基本的流水线。
<pre>#install docker
 
yum remove docker \
 
                  docker-client \
 
                  docker-client-latest \
 
                  docker-common \
 
                  docker-latest \
 
                  docker-latest-logrotate \
 
                  docker-logrotate \
 
                  docker-selinux \
 
                  docker-engine-selinux \
 
                  docker-engine
 
  
yum install -y yum-utils \
+
     在源码管理系统中定义 - 你可以手动编写一个 Jenkinsfile 文件,然后提交到项目的源代码管理仓库中。[3]
          device-mapper-persistent-data \
 
          lvm2
 
 
 
#如果在外网       
 
yum-config-manager \
 
    --add-repo \
 
     https://download.docker.com/linux/centos/docker-ce.repo
 
#如果在国内 这里不要用 ali dns  反而是在国内用 8.8.4.4速度正常 or 114.114.114.114
 
yum-config-manager \
 
    --add-repo \
 
    https://mirrors.ustc.edu.cn/docker-ce/linux/centos/docker-ce.repo
 
   
 
yum makecache fast
 
yum install docker-ce -
 
systemctl enable docker
 
systemctl start docker
 
  
#NOTE 不要用pip 安装 容易出事,见最下面的直接 curl  官方二进制包
+
使用两种方式定义流水线的语法是相同的。尽管 Jenkins 支持在经典 UI 中直接进入流水线,但通常认为最好的实践是在 Jenkinsfile 文件中定义流水线,Jenkins 之后会直接从源代码管理系统加载。
yum -y install vim wget curl yum-utils bash-completion bash-completion-extras epel-release lrzsz telnet python-pip
+
 
pip install docker-compose
+
=Jenkins Pipeline 支持两种语法=
 +
<pre>
 +
 
 +
 
 +
My-pipeline-job01 ->流水线语法    我好像没怎么用
 +
 
 +
Jenkins Pipeline 支持两种语法,一种 Declarative Pipeline(声明式),一种 ScriptedPipeline(脚本式)。
 +
 
 +
安装pipeline相关插件  全部要显示为Success  pending是不行的
  
mkdir -p /home/data/docker
 
  
echo '{"graph": "/home/data/docker"}' >/etc/docker/daemon.json
+
声明式的 Pipeline 限制用户使用严格的预选定义的结构,是一种声明
# cat /etc/docker/daemon.json
+
式的编程模型,对比脚本式的 Pipeline 学习起来更加简单;
{"graph": "/home/data/docker"}
 
  
systemctl restart docker
+
脚本式的 Pipeline 限制比较少,结构和语法的限制由 Groovy 本身决定,是一种命令式的编程模型。
 +
所以我们学习使用声明式的方式编写 jenkinsfile。
 +
一般来说 jenkinsfile 会被放在代码库的根目录下。
  
#验证docker储存位置
+
当然也可以在 Web 页面定义。
docker system info | grep "Root Dir"
+
 
 +
下面是两种不同方式的 jenkinsfile 示例
 
</pre>
 
</pre>
https://docs.docker.com/install/linux/docker-ce/centos/
+
==Jenkinsfile (声明式)==
  
=on debian=
 
==国内网络==
 
 
<pre>
 
<pre>
apt install sudo -y
 
sudo apt-get update
 
apt-get install -y gnupg2
 
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common
 
# step 2: 安装GPG证书
 
  
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/debian/gpg | sudo apt-key add -
+
pipeline {
# Step 3: 写入软件源信息
+
    agent any
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/debian $(lsb_release -cs) stable"
+
    stages {
# Step 4: 更新并安装Docker-CE
+
        stage('Build') {
sudo apt-get -y update
+
            steps {
sudo apt-get -y install docker-ce
+
                echo 'Building..'
 +
                }
 +
            }
 +
            stage('Test') {
 +
                steps {
 +
                    echo 'Testing..'
 +
                }
 +
            }
 +
            stage('Deploy') {
 +
                steps {
 +
                    echo 'Deploying....'
 +
                }
 +
            }
 +
        }
 +
    }
  
  安装指定版本的Docker-CE:
+
前面我们说过,声明式的Pipeline有严格的预定义格式结构,有固定的格式,外层必须是pipeline{},
# Step 1: 查找Docker-CE的版本:
+
紧接着是 agent  就是节点node ,agent也是固定的,pipeline紧跟着进来 一定是agent 参考上面的格式 后面的any是任何节点还是其中一个节点,指定某一个节点是自己指定,通过标签自己来指定节点
# apt-cache madison docker-ce
 
  
  Step 2: 安装指定版本的Docker-CE: (VERSION例如上面的17.03.1~ce-0~ubuntu-xenial)
+
指示 Jenkins 分配一个执行器和工作空间来执行下面的 Pipeline,
# sudo apt-get -y install docker-ce=[VERSION]
+
 
 +
  stages和steps是申明式Jenkinsfile必须的,stages是一个个阶段,所有的stage必须要定义在stages里,
 +
 
 +
stages(‘’) 括号里面是名称,这个阶段是什么名称,stages这个名称不能重复,同一个stage名称只能有一个
 +
 
 +
每一个stage下的 step 要定义在一个 steps 里,stages里面包含了step,具体的执行步骤都写在step里面 ,一行一个,可以写多行
 
</pre>
 
</pre>
 +
 +
==Jenkinsfile(脚本式)==
 +
<pre>
  
==国外网络==
+
node {
<pre>
+
    stage('Build') {
 +
        //
 +
    }
 +
    stage('Test') {
 +
        //
 +
    }
 +
    stage('Deploy') {
 +
        //
 +
    }
 +
}
 +
 
 +
在脚本式 jenkinsfile 里,你可以定义一个 node 或者多个 node 块,然后在 node 块里
 +
定义你的 stage,在 stage 里定义你的 step 即可
 +
</pre>
  
#Fri Nov  8 09:54:03 CST 2019
+
=进阶advance=
#apt  install software-properties-common  -y
 
  
apt-get remove docker docker-engine docker.io containerd runc
+
[https://www.jenkins.io/zh/doc/book/pipeline/getting-started/ .jenkins.io/zh/doc/book  流水线入门]
  
apt-get install -y \
+
[https://www.jenkins.io/zh/doc/book/pipeline/getting-started/ jenkins.io 流水线入门]
    apt-transport-https \
 
    ca-certificates \
 
    curl \
 
    gnupg2 \
 
    software-properties-common
 
  
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -
+
[https://zhuanlan.zhihu.com/p/143552791 Jenkins 声明式流水线的语法错误检查]
  
sudo apt-key fingerprint 0EBFCD88
+
[https://www.cnblogs.com/mingerlcm/p/12806076.html  Pipeline 语法生成器]
sudo add-apt-repository    "deb [arch=amd64] https://download.docker.com/linux/debian \
 
  $(lsb_release -cs) \
 
  stable"
 
apt-get update
 
sudo apt-get install -y docker-ce docker-ce-cli containerd.io
 
</pre>
 
https://docs.docker.com/install/linux/docker-ce/debian/
 
  
= 修改docker数据目录=
+
[https://www.jenkins.io/zh/doc/book/pipeline/syntax/ 流水线语法]
<pre>
 
  
#2020 centos and debian
 
mkdir -p /data/docker
 
  
echo '{"graph": "/data/docker"}' >/etc/docker/daemon.json
+
Jenkins2 下载与启动
# cat /etc/docker/daemon.json
+
jenkins2 插件安装
#{"graph": "/data/docker"}
+
jenkins2 hellopipeline
 +
jenkins2 pipeline介绍
 +
jenkins2 javahelloworld
 +
jenkins2 groovy入门
 +
jenkins2 pipeline入门
 +
jenkins2 pipeline高级
 +
jenkins2 Jenkinsfile
 +
jenkins2 multibranch
 +
jenkins2 Jenkinsfile和load
 +
jenkins2 groovy脚本参考
 +
jenkins2 pipeline实例
 +
jenkins2 pipeline插件的10个最佳实践
 +
jenkins2 pipeline 语法快速参考
  
systemctl restart docker
+
https://www.cnblogs.com/itech/category/245402.html?page=3
  
#验证docker储存位置
 
docker system info | grep "Root Dir"
 
</pre>
 
  
[https://www.cnblogs.com/hellxz/p/docker-change-data-root.html 修改Docker数据目录位置,包含镜像位置]
+
[https://www.cnblogs.com/itech/p/5646219.html jenkins2 pipeline高级 ]
  
https://www.cnblogs.com/davygeek/p/9940022.html
+
=pipeline for example=
  
=[[DockerHub镜像加速]]=
 
  
=docker-compose=
+
其实就是有点像share library
==国外==
+
流水线 -->定义
<pre>
+
<gallery>
 +
Jul012021Z1.png
 +
</gallery>
  
#如果在内网看下面的手工 或者找个国内的 镜像吧
+
然后有个叫jenkinsfile
  
sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
+
[https://blog.51cto.com/u_13760351/2527263  Jenkins--pipline 流水线部署Java后端项目]
  
sudo chmod +x /usr/local/bin/docker-compose
+
[https://blog.51cto.com/u_13760351/2526052  本地java代码上传Gitlab仓库]
  
curl -L "https://github.com/docker/compose/releases/download/1.25.0/docker-compose-Linux-x86_64" -o /usr/bin/docker-compose
+
[https://blog.51cto.com/u_13760351/2382103 Jenkins自动部署发布Java代码(完整教程]
sudo chmod +x /usr/local/bin/docker-compose
+
==java sprint boot ==
 +
Jenkins Pipeline 部署 SpringBoot 应用
  
#官方教程  有些机器 path没这个目录 
+
===java===
sudo curl -L "https://github.com/docker/compose/releases/download/1.25.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
+
<pre>修改/etc/profile文件,添加JAVA_HOME
  
docker-compose
+
vi /etc/profile
 +
在文件的最后面,加上以下代码
 +
export JAVA_HOME=/java/jdk1.8.0_171
 +
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
 +
export PATH=$JAVA_HOME/bin:$PATH
  
 +
#me on  kali xps
 +
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
 +
export M2_HOME=/usr/local/maven3
 +
export PATH=$PATH:$JAVA_HOME/bin:$M2_HOME/bin
 
</pre>
 
</pre>
  
==国内 和手工 ==
+
===maven ===
<pre>
+
<pre>wget -c https://mirrors.bfsu.edu.cn/apache/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
curl -L "https://get.daocloud.io/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
+
tar zxf apache-maven-3.8.1-bin.tar.gz
#curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
+
mv apache-maven-3.1.1 /usr/local/maven3
chmod +x /usr/local/bin/docker-compose
+
 
 +
vi /etc/profile然后还需要 配置环境变量。 #在适当的位置添加
 +
 
 +
export M2_HOME=/usr/local/maven3
 +
export PATH=$PATH:$JAVA_HOME/bin:$M2_HOME/bin
 +
 
 +
保存退出后运行下面的命令使配置生效,或者重启服务器生效。
 +
source /etc/profile
 +
 
 +
验证版本
 +
mvn -v
  
#firefox 直接下载居然很快
+
出现maven版本即成功
wget https://github.com/docker/compose/releases/download/1.25.0/docker-compose-Linux-x86_64
 
  
curl -L "https://github.com/docker/compose/releases/download/1.25.0/docker-compose-Linux-x86_64“
+
阿里云源
  
 +
<mirrors>
 +
    <mirror>
 +
      <id>alimaven</id>
 +
      <name>aliyun maven</name>
 +
      <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
 +
      <mirrorOf>central</mirrorOf>       
 +
    </mirror>
 +
</mirrors>
 
</pre>
 
</pre>
  
=trouble shooting=
+
===安装Jenkins部署SpringBoot应用===
==docker-compose up 启动容器服务超时错误:ERROR: An HTTP request took too long to complete. Retry with --verbose to obtain debug information. ==
+
jenkins 安装过程省略
 +
 
 +
登陆之后进入Manage Jenkins -> Global Tool Configuration 中进行配置Maven,Git,JDK
 +
可能不同环境有小许要修改
 +
 
 +
<gallery>Jul012021j1.png</gallery>
 +
 
 +
===新建Pipeline 项目===
 +
新建Item --> 名就叫 01_Eureka  再选中pipeline 最后确定  -->
 +
 
 +
配置Git仓库:
 +
http://mygitlab.com/root/01_eureka.git
 +
 
 
<pre>
 
<pre>
docker-compose up 启动容器服务超时错误:ERROR: An HTTP request took too long to complete. Retry with --verbose to obtain debug information.
+
tree .
 +
.
 +
└── jenkins_files
 +
    └── 01_eureka
 +
 
 +
1 directory, 1 file
  
 +
cat jenkins_files/01_eureka
  
由于docker-compose up 同时启动的服务过多,超过了请求HTTP限制的60s时间仍未全部成功启动起来,所以出现了超时错误:
+
node {
 +
  def mvnHome
 +
  def workspace = pwd()
 +
  def project_name = 'eureka-server-1.0.0.jar'
 +
  def project_log = 'eureka-server-1.0.0.log'
 +
  def project_home = 'app-centre/eureka-server'
 +
  def vm_ip = 'xxx.xxx.xxx.xxx'
 +
  def vm_port = '22'
 +
  def vm_user = 'root'
 +
  //代码获取
 +
  stage('Preparation') { // for display purposes
 +
  git branch: 'master',
 +
  url:' https://gitee.com/didispace/didi-eureka-server.git'
 +
  }
 +
  //构建
 +
  stage('Build') {
 +
      // Run the maven build
 +
      if (isUnix()) {
 +
        sh "/usr/local/maven3/bin/mvn -Dmaven.test.skip=true clean package"
 +
 +
      } else {
 +
        bat(/mvn -Dmaven.test.skip=true clean package/)
 +
      }
 +
  }
 +
 
 +
  //移动
 +
  stage('MV') {
 +
    sh "mv ${project_home}/target/${project_name} /usr/local/src/"
 +
  }
 +
 
 +
  //上传到服务器
 +
  stage('Upload VM') {
 +
    sh "scp -P ${vm_port} /usr/local/src/${project_name} ${vm_user}@${vm_port}:/usr/local/src/bk"
 +
//sh "ssh -p ${vm_port} ${vm_user}@${vm_ip} 'nohup java -jar /usr/local/src/${project_name} >> ${project_log} '"
 +
  }
 +
 
 +
 
 +
  //运行JAR包
 +
  stage('Run') {
 +
//sh "if (ps -ef| grep java|grep ${project_name})then (ps -ef| grep java|grep ${project_name}| awk '{print \$2}'|xargs kill -9) fi"
 +
    sh "ssh -p ${vm_port} ${vm_user}@${vm_ip} 'nohup java -jar /usr/local/src/${project_name} >${project_log} 2>&1 &'"
 +
  }
 +
}
 +
</pre>
  
    ERROR: An HTTP request took too long to complete. Retry with --verbose to obtain debug information.
+
流水线选项卡
              If you encounter this issue regularly because of slow network conditions, consider setting COMPOSE_HTTP_TIMEOUT to a higher value (current value: 60).
+
定义 : pipeline script from SCM
 +
SCM  repository URl http://mygitlab.com/root/01_eureka.git
  
其中60s是默认的时间。
+
Credentials 你的用户和密码
解决思路:
 
  
把 COMPOSE_HTTP_TIMEOUT 的值调大,并转为环境变量即可。
+
指定分支(为空时代表any) 我这里为 */main
  
解决步骤:
+
脚本路径  jenkins_files/01_eureka
  
先进入/etc/profile配置文件,执行命令:
+
====see also springboot ====
 +
[https://www.cnblogs.com/SimpleWu/p/13262966.html  Jenkins Pipeline 部署 SpringBoot 应用 ]
  
    vi /etc/profile
+
[https://juejin.cn/post/6844903955600769031 最优雅的Docker+Jenkins pipeline部署Spring boot项目 ]
  
然后在尾部添加上下面代码:
+
=docker=
  
    export COMPOSE_HTTP_TIMEOUT=500
+
[https://www.jenkins.io/doc/book/pipeline/docker/ Using Docker with Pipeline,官方文档]
    export DOCKER_CLIENT_TIMEOUT=500
+
=是Blue Ocean=
 +
https://www.jenkins.io/zh/doc/book/blueocean/
  
接着使/etc/profile配置文件生效,执行命令:
+
Blue Ocean 重新思考Jenkins的用户体验,从头开始设计Jenkins Pipeline, 但仍然与自由式作业兼容,Blue Ocean减少了混乱而且进一步明确了团队中每个成员 Blue Ocean 的主要特性包括:
  
     source /etc/profile
+
     持续交付(CD)Pipeline的 复杂可视化 ,可以让您快速直观地理解管道状态。
 +
    Pipeline 编辑器 - 引导用户通过直观的、可视化的过程来创建Pipeline,从而使Pipeline的创建变得平易近人。
 +
    个性化 以适应团队中每个成员不同角色的需求。
 +
    在需要干预和/或出现问题时 精确定位 。 Blue Ocean 展示 Pipeline中需要关注的地方, 简化异常处理,提高生产力
 +
    本地集成分支和合并请求, 在与GitHub 和 Bitbucket中的其他人协作编码时实现最大程度的开发人员生产力。
  
最后重新执行命令 docker-compose up 即可。
+
简言之:简化复杂可视化,提供更个性直观的界面,可以精准定位构建失败的位置
  
</pre>
+
[https://www.cnblogs.com/hellxz/p/pipeline_maven_build.html  Jenkins教程(四)安装BlueOcean与Maven构建 ]
  
<pre>
+
=see also=
删除volume 后报错 改一下 目录就好了
+
[https://www.cnblogs.com/mingerlcm/p/12790884.html Jenkins Pipeline介绍]
ERROR: stat /var/lib/docker/overlay2/bc5838430495b942c06a838d8bfecaf416211fa98cc2e3a2372a33ebb7d3061e: no such file or directory
 
  
 +
[https://www.cnblogs.com/mingerlcm/p/12727253.html jenkins从头到尾 目录]
  
echo '{"graph": "/home/data/docker"}' >/etc/docker/daemon.json
+
[https://www.cnblogs.com/mingerlcm/p/12799362.html Jenkins Pipeline示例]
  
</pre>
+
[https://www.cnblogs.com/mingerlcm/p/12799493.html  使用 pipeline 实现 monitor 仓库代码的发布 ]
===Error response from daemon: Get https://registry-1.docker.io/v2/: dial tcp: lookup registry-1.docker.io ===
 
<pre>
 
Unable to find image 'telegrammessenger/proxy:latest' locally
 
docker: Error response from daemon: Get https://registry-1.docker.io/v2/: dial tcp: lookup registry-1.docker.io on [::1]:53: read udp [::1]:58699->[::1]:53: read: connection refused.
 
  
 +
[https://www.cnblogs.com/itech/p/12747748.html  Jenkins pipeline jenkinsfile的两种写作方式声明式和脚本式 ]
  
restart docker
+
[https://objcoding.com/2019/02/16/docker-jenkins-pipeline/ 基于Jenkins Pipeline自动化部署知道个过程而已]
</pre>
 
==ERROR: Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)==
 
  
<pre>
 
原来是他们没开外网 坑
 
oot@dev-fincy-mq03:/data/apps/redis-cluster# docker-compose up  -d
 
Pulling redis-cluster-7004 (redis:5.0.4-alpine)...
 
ERROR: Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)
 
</pre>
 
  
https://docs.docker.com/compose/install/
+
[https://www.jianshu.com/p/bcd42b4f9885 Jenkins + Pipeline 自动化部署项目]
  
[https://www.jianshu.com/p/34d3b4568059 Docker快速安装以及换镜像源]
+
[https://www.jianshu.com/p/daf32c908ff9 Jenkins + Pipeline 构建流水线发布]
  
  [[category:ops]] [[category:Container]]
+
[https://www.cnblogs.com/itech/p/12747740.html Jenkins pipeline之声明式的jenkinsfile ]
 +
[[category:ops]] [[category:devops]]

2021年7月1日 (四) 12:47的版本

Jenkins Pipeline 简介

Jenkins pipeline 是 Jenkins 2.0 的精髓,,是帮助 Jenkins 实现 CI 到 CD 转变的重要角色。

简单来说,就是一套运行于 Jenkins 上的工作流框架,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂发布流程。

Pipeline 的实现方式是一套 Groovy DSL,任何发布流程都可以表述为一段 Groovy 脚本,并且 Jenkins 支持从代码库直接读取脚本,从而实现了 Pipeline as Code 的理念。

jenkins2 pipeline入门

官方文档 流水线可以通过以下任一方式来创建:

   通过 Blue Ocean - 在 Blue Ocean 中设置一个流水线项目后,Blue Ocean UI 会帮你编写流水线的 Jenkinsfile 文件并提交到源代码管理系统。
   通过经典 UI - 你可以通过经典 UI 在 Jenkins 中直接输入基本的流水线。
   在源码管理系统中定义 - 你可以手动编写一个 Jenkinsfile 文件,然后提交到项目的源代码管理仓库中。[3]

使用两种方式定义流水线的语法是相同的。尽管 Jenkins 支持在经典 UI 中直接进入流水线,但通常认为最好的实践是在 Jenkinsfile 文件中定义流水线,Jenkins 之后会直接从源代码管理系统加载。

Jenkins Pipeline 支持两种语法



My-pipeline-job01 ->流水线语法    我好像没怎么用 

Jenkins Pipeline 支持两种语法,一种 Declarative Pipeline(声明式),一种 ScriptedPipeline(脚本式)。

安装pipeline相关插件  全部要显示为Success  pending是不行的


声明式的 Pipeline 限制用户使用严格的预选定义的结构,是一种声明
式的编程模型,对比脚本式的 Pipeline 学习起来更加简单;

脚本式的 Pipeline 限制比较少,结构和语法的限制由 Groovy 本身决定,是一种命令式的编程模型。
所以我们学习使用声明式的方式编写 jenkinsfile。
一般来说 jenkinsfile 会被放在代码库的根目录下。

当然也可以在 Web 页面定义。

下面是两种不同方式的 jenkinsfile 示例

Jenkinsfile (声明式)


pipeline { 
    agent any
    stages { 
        stage('Build') { 
            steps { 
                echo 'Building..' 
                } 
            } 
            stage('Test') { 
                steps { 
                    echo 'Testing..' 
                } 
            } 
            stage('Deploy') { 
                steps { 
                    echo 'Deploying....' 
                } 
            } 
        }
    }

前面我们说过,声明式的Pipeline有严格的预定义格式结构,有固定的格式,外层必须是pipeline{},
紧接着是 agent  就是节点node ,agent也是固定的,pipeline紧跟着进来 一定是agent 参考上面的格式  后面的any是任何节点还是其中一个节点,指定某一个节点是自己指定,通过标签自己来指定节点

指示 Jenkins 分配一个执行器和工作空间来执行下面的 Pipeline,

 stages和steps是申明式Jenkinsfile必须的,stages是一个个阶段,所有的stage必须要定义在stages里,

stages(‘’) 括号里面是名称,这个阶段是什么名称,stages这个名称不能重复,同一个stage名称只能有一个

每一个stage下的 step 要定义在一个 steps 里,stages里面包含了step,具体的执行步骤都写在step里面 ,一行一个,可以写多行

Jenkinsfile(脚本式)


node { 
    stage('Build') { 
        // 
    } 
    stage('Test') { 
        // 
    } 
    stage('Deploy') { 
        // 
    } 
}

在脚本式 jenkinsfile 里,你可以定义一个 node 或者多个 node 块,然后在 node 块里
定义你的 stage,在 stage 里定义你的 step 即可

进阶advance

.jenkins.io/zh/doc/book 流水线入门

jenkins.io 流水线入门

Jenkins 声明式流水线的语法错误检查

Pipeline 语法生成器

流水线语法


Jenkins2 下载与启动 jenkins2 插件安装 jenkins2 hellopipeline jenkins2 pipeline介绍 jenkins2 javahelloworld jenkins2 groovy入门 jenkins2 pipeline入门 jenkins2 pipeline高级 jenkins2 Jenkinsfile jenkins2 multibranch jenkins2 Jenkinsfile和load jenkins2 groovy脚本参考 jenkins2 pipeline实例 jenkins2 pipeline插件的10个最佳实践 jenkins2 pipeline 语法快速参考

https://www.cnblogs.com/itech/category/245402.html?page=3


jenkins2 pipeline高级

pipeline for example

其实就是有点像share library 流水线 -->定义

然后有个叫jenkinsfile

Jenkins--pipline 流水线部署Java后端项目

本地java代码上传Gitlab仓库

Jenkins自动部署发布Java代码(完整教程

java sprint boot

Jenkins Pipeline 部署 SpringBoot 应用

java

修改/etc/profile文件,添加JAVA_HOME

vi /etc/profile
在文件的最后面,加上以下代码
export JAVA_HOME=/java/jdk1.8.0_171
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$JAVA_HOME/bin:$PATH

#me on  kali xps 
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
export M2_HOME=/usr/local/maven3
export PATH=$PATH:$JAVA_HOME/bin:$M2_HOME/bin

maven

wget -c https://mirrors.bfsu.edu.cn/apache/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz 
tar zxf apache-maven-3.8.1-bin.tar.gz 
mv apache-maven-3.1.1 /usr/local/maven3 

vi /etc/profile然后还需要 配置环境变量。 #在适当的位置添加

export M2_HOME=/usr/local/maven3
export PATH=$PATH:$JAVA_HOME/bin:$M2_HOME/bin

保存退出后运行下面的命令使配置生效,或者重启服务器生效。
source /etc/profile

验证版本
mvn -v

出现maven版本即成功

阿里云源

<mirrors>
    <mirror>
      <id>alimaven</id>
      <name>aliyun maven</name>
      <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
      <mirrorOf>central</mirrorOf>        
    </mirror>
</mirrors>

安装Jenkins部署SpringBoot应用

jenkins 安装过程省略

登陆之后进入Manage Jenkins -> Global Tool Configuration 中进行配置Maven,Git,JDK 可能不同环境有小许要修改

新建Pipeline 项目

新建Item --> 名就叫 01_Eureka 再选中pipeline 最后确定 -->

配置Git仓库: http://mygitlab.com/root/01_eureka.git

tree .
.
└── jenkins_files
    └── 01_eureka

1 directory, 1 file

cat jenkins_files/01_eureka

node {
   def mvnHome
   def workspace = pwd()
   def project_name = 'eureka-server-1.0.0.jar'
   def project_log = 'eureka-server-1.0.0.log'
   def project_home = 'app-centre/eureka-server'
   def vm_ip = 'xxx.xxx.xxx.xxx'
   def vm_port = '22'
   def vm_user = 'root'
   //代码获取
   stage('Preparation') { // for display purposes
	  git branch: 'master',
	  url:' https://gitee.com/didispace/didi-eureka-server.git'
   }
   //构建
   stage('Build') {
      // Run the maven build
      if (isUnix()) {
         sh "/usr/local/maven3/bin/mvn -Dmaven.test.skip=true clean package"
 
      } else {
         bat(/mvn -Dmaven.test.skip=true clean package/)
      }
   }
   
   //移动
   stage('MV') {
     sh "mv ${project_home}/target/${project_name} /usr/local/src/"
   }
   
   //上传到服务器
   stage('Upload VM') {
     sh "scp -P ${vm_port} /usr/local/src/${project_name} ${vm_user}@${vm_port}:/usr/local/src/bk"
	 //sh "ssh -p ${vm_port} ${vm_user}@${vm_ip} 'nohup java -jar /usr/local/src/${project_name} >> ${project_log} '"
   }
   
   
  //运行JAR包
  stage('Run') {
	 //sh "if (ps -ef| grep java|grep ${project_name})then (ps -ef| grep java|grep ${project_name}| awk '{print \$2}'|xargs kill -9) fi"
     sh "ssh -p ${vm_port} ${vm_user}@${vm_ip} 'nohup java -jar /usr/local/src/${project_name} >${project_log} 2>&1 &'"
  }
}

流水线选项卡 定义 : pipeline script from SCM SCM repository URl http://mygitlab.com/root/01_eureka.git

Credentials 你的用户和密码

指定分支(为空时代表any) 我这里为 */main

脚本路径 jenkins_files/01_eureka

see also springboot

Jenkins Pipeline 部署 SpringBoot 应用

最优雅的Docker+Jenkins pipeline部署Spring boot项目

docker

Using Docker with Pipeline,官方文档

是Blue Ocean

https://www.jenkins.io/zh/doc/book/blueocean/

Blue Ocean 重新思考Jenkins的用户体验,从头开始设计Jenkins Pipeline, 但仍然与自由式作业兼容,Blue Ocean减少了混乱而且进一步明确了团队中每个成员 Blue Ocean 的主要特性包括:

   持续交付(CD)Pipeline的 复杂可视化 ,可以让您快速直观地理解管道状态。
   Pipeline 编辑器 - 引导用户通过直观的、可视化的过程来创建Pipeline,从而使Pipeline的创建变得平易近人。
   个性化 以适应团队中每个成员不同角色的需求。
   在需要干预和/或出现问题时 精确定位 。 Blue Ocean 展示 Pipeline中需要关注的地方, 简化异常处理,提高生产力
   本地集成分支和合并请求, 在与GitHub 和 Bitbucket中的其他人协作编码时实现最大程度的开发人员生产力。

简言之:简化复杂可视化,提供更个性直观的界面,可以精准定位构建失败的位置

Jenkins教程(四)安装BlueOcean与Maven构建

see also

Jenkins Pipeline介绍

jenkins从头到尾 目录

Jenkins Pipeline示例

使用 pipeline 实现 monitor 仓库代码的发布

Jenkins pipeline jenkinsfile的两种写作方式声明式和脚本式

基于Jenkins Pipeline自动化部署知道个过程而已


Jenkins + Pipeline 自动化部署项目

Jenkins + Pipeline 构建流水线发布

Jenkins pipeline之声明式的jenkinsfile