Jenkins详细教程

Jenkins详细教程
1.背景
 
  在实际开发中,我们经常要一边开发一边测试,当然这里说的测试并不是程序员对自己代码的单元测试,而是同组程序员将代码提交后,由测试人员测试;
 
  或者前后端分离后,经常会修改接口,然后重新部署;
 
  这些情况都会涉及到频繁的打包部署;
 
  手动打包常规步骤:
 
  1.提交代码
 
  2.问一下同组小伙伴有没有要提交的代码
 
  3.拉取代码并打包(war包,或者jar包)
 
  4.上传到Linux服务器
 
  5.查看当前程序是否在运行
 
  6.关闭当前程序
 
  7.启动新的jar包
 
  8.观察日志看是否启动成功
 
  9.如果有同事说,自己还有代码没有提交……再次重复1到8的步骤!!!!!(一上午没了)
 
  那么,有一种工具能够实现,将代码提交到git后就自动打包部署勒,答案是肯定的:Jenkins
 
  当然除了Jenkins以外,也还有其他的工具可以实现自动化部署,如Hudson等
 
  只是Jenkins相对来说,使用得更广泛。
 
2.Jenkins服务器搭建及基本配置
 
2.1.简介
 
  Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。
 
2.2.Jenkins自动化部署实现原理
 
 2.3.Jenkins部署环境
 
  基本环境:
 
  1.jdk环境,Jenkins是java语言开发的,因需要jdk环境。
 
  2.git/svn客户端,因一般代码是放在git/svn服务器上的,我们需要拉取代码。
 
  3.maven客户端,因一般java程序是由maven工程,需要maven打包,当然也有其他打包方式,如:gradle
 
  以上是自动化部署java程序jenkins需要的基本环境,请自己提前安装好,下面着重讲解Jenkins的安装部署配置。
 
2.4.Jenkins安装
 
  1.下载安装包jenkins.war;
 
  2.在安装包根路径下,运行命令 java -jar jenkins.war --httpPort=8080,(linux环境、Windows环境都一样);
 
  补充:一个童鞋遇到的问题,反馈说,git自动触发时报错403,启动加如下参数可以解决问题
 
  nohup java -jar -Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true  /usr/local/jenkins/jenkins.war --httpPort=8080  &
 
  3.打开浏览器进入链接 http://localhost:8080.
 
  4.填写初始密码,激活系统
 
  5.进入插件安装选择
 
  这里建议选择,推荐安装的插件,保证基本常用的功能可以使用。
 
  选择后,进入插件安装页面
 
  6.设置初始用户和密码
 
  7.进入系统,安装完成
 
  注意,如果还是进入不了系统,需要稍等一下,或者刷新页面,如果还是进入不了,需要重新启动jenkinds服务器。
 
2.5.Jenkins基本配置
 
2.5.1.系统初始化配置 
 
  1.Configure System (系统设置)
 
  在系统设置这里,我们只需要设置最后面的一项,配置远程服务器地址,
 
  即我们代码最终运行的服务器地址信息,就像我们之前手动部署时使用xshell登录Linux服务器一样,
 
  当然这里是可以配置多台远程Linux服务器的,配置完成后点击保存即可,为后面我们配置自动化部署做准备,配置如下图
 
  2.Configure  Global Security (全局安全配置)
 
  a.配置用户相关的权限
 
  b.配置钩子程序(当用代码更新时通知)访问权限,避免报403错误
 
  默认是勾选上了的,这里去掉勾选
 
  3.Global Tool Configuration (全局工具配置 )
 
  a.配置maven的全局settings路径
 
  b.配置jdk
 
  c.配置git
 
  d.配置maven的安装路径
 
   4.配置必要插件
 
   主要是检查如下这两个插件是否已安装
 
  插件1:Publish over SSH
 
  插件2:Deploy to container Plugin
 
  到这里,我们配置一个自动化部署的的java程序(springBoot+maven+gitHub),基本必要配置就差不多了,后面配置过程中如果需要在配置。

推荐阅读