@TOC
Jenkins笔记
Jenkins笔记之新建工作:https://blog.csdn.net/weixin_...
Jenkins笔记之配置近程服务器:https://blog.csdn.net/weixin_...
Jenkins:参数化构建:多分支|多模块|回滚|打印日志:https://blog.csdn.net/weixin_...
1` 必要条件:装置环境Docker或者JDK+Maven+Git/Svn
2` 增加形式:从零配置、复制配置
从零配置
点击左侧性能列表----新建工作
填写工作名称,点击构建一个maven我的项目,点击确定
进入配置列表
- 配置构建历史
设置源码治理这里抉择git
多种认证形式任选其一构建触发器:依据本人的需要设置,简略的工作不须要配置。
构建环境:这里能够配置近程服务器的命令行,然而最好放在Build实现之后(Post Steps)再执行脚本,再Post Steps执行近程服务脚本,能够打印出日志。
Pre Steps 先Clean再install
Post Steps 多种公布步骤任你抉择
间接在Jenkis服务器通过脚本执行
[外链图片转存失败,源站可能有防盗链机制,倡议将图片保留下来间接上传(img-imZrHBWG-1629689671588)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210823104307405.png)]
执行脚本的命令须要应用用根门路
scp -P 2021 /data/jenkins/workdir/jobs/xxx/workspace/xxx/target/xxx.jar devops@内网IP:/home/devops/xxx/ssh -p 2021 devops@内网IP "/data/initsh/xxx.sh"
在指标服务器执行脚本,配置运行流程:Jenkins构建实现之后,连贯到指标服务器将Sources file文件的Jar复制到近程服务门路中,而后运行Exec Command脚本。
跳转到---》配置近程服务器
配置如下:- Source files
**/*
示意sskzmz这个job的工作目录下所有的文件和目录。 - Remove prefix 该操作是针对下面的source files目录,会移除匹配的目录。通常留空。
- Remote directory 该操作是基于设定的服务器目录进行。这里我的服务器配置是的/www. 因而这里应该写sites/sskzmz即可。
- Exec command 近程服务器执行的命令。例如能够输入 service nginx restart 或者/www/xx. sh 均可。
- 高级:
- Exclude files:排除的文件(在你传输目录的时候很有用,应用通配符,例如:/*.log,/*.tmp,.Git/)
- Pattern separator:分隔符(配置Transfer Set Source files的分隔符。如果你这儿更改了,下面的内容也须要更改)
- No default excludes:禁止默认的排除规定(具体的本人看帮忙)
- Make empty dirs:此选项会更改插件的默认行为。默认行为是匹配该文件是否存在,如果存在则创立目录寄存。选中此选项会间接创立一个目录寄存文件,即便是空目录。(集体了解)
- Remote directory is a date format:近程目录建设带日期的文件夹(须要在Remote directory中配置日期格局)
- Flatten files:只上传文件,不创立目录(除了近程目录)
- Exec timeout (ms):运行脚步的超时工夫(毫秒)
- Exec in pty:模仿一个终端执行脚步
- Add Transfer Set:减少一个配置
- Source files
sh 脚本(两种形式脚本统一)
#!/bin/bash#服务名称SERVER_NAME=xxx# 源jar门路,mvn打包实现之后,target目录下的jar包名称,也可抉择成为war包,war包可挪动到Tomcat的webapps目录下运行,这里应用jar包,用java -jar 命令执行 JAR_NAME=xxx# 源jar门路 #/usr/local/jenkins_home/workspace--->jenkins 工作目录#demo 我的项目目录#target 打包生成jar包的目录JAR_PATH=/home/devops/xxx/# 打包实现之后,把jar包挪动到运行jar包的目录--->work_daemon,work_daemon这个目录须要本人提前创立JAR_WORK_PATH=/data/project/xxx/echo "查问过程id-->$SERVER_NAME"PID=`ps -ef | grep "$SERVER_NAME" | awk '{print $2}'`echo "失去过程ID:$PID"echo "完结过程"for id in $PIDdo kill -9 $id echo "killed $id" doneecho "完结过程实现"#复制jar包到执行目录echo "复制jar包到执行目录:cp $JAR_PATH/$JAR_NAME.jar $JAR_WORK_PATH"cp $JAR_PATH/$JAR_NAME.jar $JAR_WORK_PATHecho "复制jar包实现"cd $JAR_WORK_PATH#批改文件权限chmod 755 $JAR_NAME.jarnohup /usr/local/java/bin/java -jar $JAR_NAME.jar >> /data/project/xxx/logs/info.log 2>&1 &
Extra 附加参考脚本
#!/bin/bash #这里可替换为你本人的执行程序,其余代码无需更改 APP_NAME=xxxxxxxx.jar #应用阐明,用来提醒输出参数 usage() { echo "Usage: sh 执行脚本.sh [start|stop|restart|status]" exit 1 } #检查程序是否在运行 is_exist(){ pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' ` #如果不存在返回1,存在返回0 if [ -z "${pid}" ]; then return 1 else return 0 fi } #启动办法 start(){ is_exist if [ $? -eq "0" ]; then echo "${APP_NAME} is already running. pid=${pid} ." else nohup /app/jdk1.8.0_45/bin/java -server -jar $APP_NAME --spring.profiles.active=test > ./console 2>&1 & echo "${APP_NAME} started" fi } #进行办法 stop(){ is_exist if [ $? -eq "0" ]; then kill -9 $pid echo "${APP_NAME} stoped" else echo "${APP_NAME} is not running" fi } #输入运行状态 status(){ is_exist if [ $? -eq "0" ]; then echo "${APP_NAME} is running. Pid is ${pid}" else echo "${APP_NAME} is NOT running." fi } #重启 restart(){ stop start } #依据输出参数,抉择执行对应办法,不输出则执行应用阐明 case "$1" in "start") start ;; "stop") stop ;; "status") status ;; "restart") restart ;; *) usage ;; esac
复制配置
填写抉择本人须要的配置