jenkins安装和简单部署

jenkins安装和简单部署

jenkins历史

jenkins是一款非常好用的团队CI(Continuous Integration)工具。它可以使你的构建,集成,发布,开发流程自动化。减轻各个环节所耗时间。同时可以自行研发插件并用于自己工作环境中。

简单描述一下jenkins构建到发部程序的过程:

首先##开发人员(提交代码至代码仓库) —> “jenkins(执行构建任务) —> 先去代码仓库拉取相应的代码至workspace —> 根据所定义的编译流程(如pom.xml) —> 在编译过程中可以test(测试)程序” —> 发部至工作环境直至服务可用
在jenkins工作的过程,每一步都有提示,并且可以发邮件等信息来提示构建的人员。

安装jenkins

因为jenkins由java语言所写,所以下载的jenkins只是一个war包。官网地址:https://jenkins.io/
本次安装是由tomcat程序安装

  1. jenkins-2.60.3-1.1.noarch.rpm 直接下载rpm包,并且提供jdk和tomcat
##安装jenkins rpm包
]# rpm -ivh jenkins-2.60.3-1.1.noarch.rpm
]# rpm -ql jenkins
/etc/init.d/jenkins
/etc/logrotate.d/jenkins
/etc/sysconfig/jenkins
/usr/lib/jenkins
/usr/lib/jenkins/jenkins.war    ###就是这个war包,只需要此包放置#
/usr/sbin/rcjenkins
/var/cache/jenkins
/var/lib/jenkins
/var/log/jenkins

##部署tomcat容器和jdk
]# tar xf apache-tomcat-7.0.81.tar.gz
]# mv  apache-tomcat-7.0.81 jenkins

]# tar xf jdk-8u144-linux-x64.tar.gz
]# mv jdk1.8.0_144 jdk

##在tomcat容器里添加jdk的环境变量
]# vim tomcat/bin/startup.sh
export JAVA_HOME=/server/jdk
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

##将之前安装的jenkins所得的war给复制到webapp目录下,然后重启即可(这里也可以自行搭配nginx做反向代理)
]# mv /usr/lib/jenkins/jenkins.war /server/jenkins/webapps/
]# bash /server/jenkins/bin/startup.sh



  1. 安装完成后,变可打开浏览器访问192.168.1.156:8080/jenkins

前面简单的安装过程,这里就不详述了。中间安装的插件可自行选择。也可默认安装。

  • 下图中红色方框内是需要更改的,黄色方框是需要修改的。

  • 黄色方框解决方法:在server.xml加入URIEncoding="UTF-8"

  • 可增加邮件提醒功能:系统设置->email notification 只需要填写 smtp.163.com
    注意的地方有两点:
    第一:首先你的打开你接收邮箱的smtp功能
    第二:在配置填写密码时,不是邮箱登陆密码,而是上面那一步填写的密码(也就是开启邮件)



  1. 配置全局工具配置

    这里面的选项都是jenkins所要用到的基础的工具

推荐安装插件:
- Deploy to container Plugin //这个是部署tomcat的插件
- Multiple SCMs plugin //可以选择添加多个Git库的插件

jdk,maven,git等插件我个人都是手动下载安装,也可在jenkins里选择安装



  1. 配置用户安全访问策略:

Configure Global Security -> 启用安全 -> 项目矩阵授权策略 (这里得提醒一下,在配置用户时需要先创建用户,并且先apply)
注意:
- 记得给admin所有权限,这个不是默认就是admin拥有所有权限
- 在构建的项目里也需要添加用户权限,里面也是需要给admin权限,切忌,要不然admin就看不到项目了
- 在“全局安全配置”中打开安全矩阵,后就可以在项目里添加各种安全机制。

简单介绍一个和安全配置小项的功能,其实从字面意思上就可以看的懂
- 最大的权限是Overall的Administer,拥有该权限可以干任何事情。
- 最基本的权限是Overall的Read,用户必须赋予阅读的权限,不然什么都看不到。
- 其他的每个权限都可根据字面意思来

推荐安装插件:
- Audit Trail plugin //将用户的更改记录在一特殊的日志文件中
- JobConfigHistory plugin //允许你保存jenkins系统配置和job配置文件以前版本的副本


在以上基本的配置完成后,接下来就可以添加实例了:

添加实例:

General :常规设置

  • 正常都是添加一个自由风格的软件项目,但是我比较推荐使用Pipeline,但是得写jenkinsfile文件来串联起来(流水线)。"流水线"非常适合于一些比较复杂的实例。也是一个自动化方能力方面的提升。建议使用。







  • 启用项目安全:就和上面的安全一样,控制用户权限,必须控制
  • 丢弃旧的构建:提示意思已经很明确了
  • 参数化构建:顾名思义,就是在点击"构建"时,可以根据所提供的参数去"构建"出不同的代码。很好用

接下来简单描述一下"参数化构建"两个常用的方法


- Choice Parameter:选择参数来进行构建
- Name:名称,也就是变量
- Choices:可选择的,选择其中一个,就是给Name名称变量赋值。
- Description:描述

示例:

一:变量选择

直接输出变量,即可测试。之后"保存"->"Build with Parameters"->"选择值"->"开始构建"

选择no,在查看"Console Output"

可以很清晰的看到,输出的值就是我选择的值。

二:字符选择

添加默认值,也就是在参数化构建时,如果您不修改参数,就是使用这个默认值就赋值变量。

我这里将默认值修改成"Hello World!!!"

这里也是成功的。OK,参数化构建就说到这里,其他更高级使用方法,去官网查吧!


源码管理

以git为例

  • repository url:填写仓库的地址
  • Credentials:这里需要配置拉取git源码的用户名和密码
  • Branches to build:这里是提供的拉取代码版本号,可以使用"变量","正则"等,可点击绿色方框,查看指引。


这里其实还有一个编译工具如,maven,gradle等的配置项需要填写,这里也不说明了。


构建触发器

  • 触发远程构建:自动化构建,拼接URL后写入代码中可以实现在脚本或者工具执行构建
  • Build after other projects are built: 构建与其他项目构建后,用于上下游项目有关联的时候
  • Build periodically:定时执行构建
  • GitHub hook trigger for GITScm polling:这个是git钩子的功能,如果有钩子,则触发相应的规则
  • Poll SCM: 设置定时检查代码仓库是否有变更,有变更则构建
    • minute,0-59 //这里需要注意的,在分钟这里需要加"H"这个标志,如果不加会报错。就如上图的例子
    • hour,0-23
    • day,0-31
    • month,1-12
    • week,0-7



构建环境

  • Delete workspace before build starts : 在构建之前清空工作空间
  • Abort the build if it's stuck : 如果构建出现问题则终止构建
  • Add timestamps to the Console Output:给控制台输出增加时间戳
  • Use secret text(s) or file(s) : 使用加密文件或者文本

构建

构建后

构建就是编译的过程,只要有代码,编译的配置文件(pom.xml)等文件,就会自动构建。
构建后,可以通过shell脚本或"deploy war/ear to a container"可自动部署
构建完成后,还可以邮件通知用户等等功能



  • WAR/EAR files:输入war包的相对路径,如我的war包在新建目录的target下
  • context path:输入用来访问tomcat的名称,localhost:8080
  • add container:增加容器,一般选tomcat 7X就可以。这里的username与password需要到tomcat的conf文件夹中的tomcat--users.xml修改。
  • tomcat URL: 就是你希望把war包部署到的tomcat所在IP地址,最后面不需要再加斜杠/。tomcat-users.xml中的用户名及密码默认是注释掉的,所以需要删除注释,也可以直接复制以下代码到之前。如果只是删除注释的话好像部署不会成功,还需要增加manager开头的三个role才可以。

  • Recipients : 收件人邮件地址


最后"保存"->"构建",查看"Console Output"日志是否正常。一个实例已经配置好,并正常运行

原文地址:https://www.cnblogs.com/dance-walter/p/8444142.html