@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 $PID do kill -9 $id echo "killed $id" done echo "完结过程实现" #复制 jar 包到执行目录 echo "复制 jar 包到执行目录:cp $JAR_PATH/$JAR_NAME.jar $JAR_WORK_PATH" cp $JAR_PATH/$JAR_NAME.jar $JAR_WORK_PATH echo "复制 jar 包实现" cd $JAR_WORK_PATH #批改文件权限 chmod 755 $JAR_NAME.jar nohup /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
-
-
复制配置
-
填写抉择本人须要的配置
-