jenkins使用Send build artifacts over SSH发布jar包目录配置

本测试用ruoyi-plus的代码。

1 [GitLab 自动触发 Jenkins 构建_jenkins构建触发器没有build when a change is pushed to git-CSDN博客](https://blog.csdn.net/wangyiyungw/article/details/81776972)

2 [jenkins使用Send build artifacts over SSH遇到的坑-CSDN博客](https://blog.csdn.net/goxingman/article/details/129749284)

多层级配置ssh远程传送构建物:

1 在ssh配置帐号密码时要配置一个默认的远程目录

2 配置Source files:jenkins工作空间后的打包项目目录:即$SERVER_NAME后面的部分:

```

如:JAR_PATH=/var/lib/jenkins/workspace/$SERVER_NAME/ruoyi-admin/target

ruoyi-admin/target/slcsp-2supply.jar

```

3 配置目录:目标机器的目录:Remote directory[

](http://192.168.0.243:8081/job/slcsp-2supply/configure# "Help for feature: Remote directory")

如:slcsp/slcsp-2supply

则会把jar包发送给默认远程目录+Remote directory

配置后可以看日志

```

#!/bin/sh

#进入jar所在路径

cd /usr/local/slcsp/slcsp-2supply

#查看运行记录,并停止进程

BUILD_ID=DONTKILLME #后台执行

pid=(ps -ef\|grep slcsp-2supply.jar\|grep -v grep \| awk '{print 2}')

function stop(){

if [ -n "$pid" ]

then

echo "pid进程 :$pid"

kill -9 $pid

else

echo "进程没有启动"

fi

}

stop

sleep 5s

#启动运行程序

nohup /usr/local/java/jdk-17.0.11/bin/java -Xms512m -Xmx1024m -jar /usr/local/slcsp/slcsp-2supply/slcsp-2supply.jar --spring.profiles.active=dev /dev/null 2>&1 &

```

日志:

```

Standard Commons Logging discovery in action with spring-jcl: please remove commons-logging.jar from classpath in order to avoid potential conflicts

SSH: Connecting from host [TestServer-1]

SSH: Connecting with configuration [slcsp-dev-239] ...

SSH: Creating session: username [root], hostname [192.168.0.239], port [22]

SSH: Connecting session ...

SSH: Connected

SSH: Opening SFTP channel ...

SSH: SFTP channel open

SSH: Connecting SFTP channel ...

SSH: Connected

SSH: cd [/usr/local]

SSH: OK

SSH: cd [/usr/local]

SSH: OK

SSH: cd [slcsp/slcsp-2supply]

SSH: OK

SSH: put [slcsp-2supply.jar]

SSH: Opening exec channel ...

SSH: EXEC: channel open

SSH: EXEC: STDOUT/STDERR from command

```

问题:

复制代码
jenkins远程ssh启动程序后日志报错:
复制代码
SSH: Disconnecting configuration [slcsp-dev-239] ...
ERROR: Exception when publishing, exception message [Exec timed out or was interrupted after 120,006 ms]
Build step 'Send build artifacts over SSH' changed build result to UNSTABLE
Finished: UNSTABLE

解决:

方案一:延长 SSH 执行超时时间

在 Jenkins 配置中调整 SSH 步骤的超时设置:

登录 Jenkins;

进入你的项目配置页面;

找到 Send build artifacts over SSH 步骤;

修改 Exec command timeout (ms) 设置,例如设为 300000(5 分钟);

默认是 120000(2 分钟)

相关推荐
种棵二叉树6 小时前
Idea 查找引用jar包依赖来源的Maven pom坐标
maven·intellij-idea·jar
风屿.8 小时前
IDEA推送到gitlab,jenkins识别,然后自动发布到需要的主机
运维·gitlab·jenkins
XMYX-08 小时前
SkyWalking 报错:sw_profile_task 索引缺失问题分析与解决
运维·jenkins·skywalking
TPBoreas1 天前
Jenkins服务器配置密钥对
运维·服务器·jenkins
万山y1 天前
es疑惑解读
大数据·elasticsearch·jenkins
程序员老王wd1 天前
Jenkins+Docker+Harbor快速部署Spring Boot项目详解
spring boot·docker·jenkins
188_djh1 天前
# 终端执行 java -jar example.jar 时(example.jar为项目jar包)报错:“没有主清单属性” 的解决方法
java·pycharm·jar·cmd·没有主清单属性·java -jar
默心2 天前
centos把jar包配置成服务并设置开机自启
linux·centos·jar
咖喱年糕2 天前
【VMware】虚拟机运行 Linux Ubuntu、MAC 安装和配置
linux·ubuntu·macos·ssh·vmware·unlocker·vmware tools