重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章给大家分享的是有关SpringBoot中项目执行脚本之自动拉取最新代码并重启的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联一直秉承“诚信做人,踏实做事”的原则,不欺瞒客户,是我们最起码的底线! 以服务为基础,以质量求生存,以技术求发展,成交一个客户多一个朋友!为您提供成都网站制作、成都网站建设、成都网页设计、小程序开发、成都网站开发、成都网站制作、成都软件开发、重庆APP软件开发是成都本地专业的网站建设和网站设计公司,等你一起来见证!
gitPullThenRestart.sh
# 日期: 20191230 # 作者: 何鹏举 # 说明: 项目部署在阿里云上, 每次编译打包上传比较麻烦, 因此编写此脚本, 用于应用内可以点击按钮进行自动重启. # 备注: 1) 阿里云的插件也是需要每次上传到OSS再启动, 上传的jar包比较大(大部分是第三方依赖), 感觉不好 # 2) 使用jenkins, 就一个项目再去搭建一套jenkins, 必要性也不是很大 # 以下代码中 /root/hekele 为git clone的项目路径, /root/app 为部署的路径 # 刷新环境变量 source ~/.bashrc # 切换到git项目目录拉取最新代码, 并进行mvn的打包 cd /root/hekele git pull cd /root/hekele/java mvn clean install # 杀掉当前项目的进程 ps -ef|grep hekele.jar | awk '{print $2}' | while read pid do kill -9 $pid done # 复制jar包, 强制覆盖(忽略提醒), 由于CentOS的.bashrc中打开cp的-i选项, 即可使用-f也不行, 所以还是先删除再复制 rm -f /root/app/hekele.jar cp /root/hekele/java/target/hekele.jar /root/app/ # 后台启动项目 nohup java -jar /root/app/hekele.jar >> /root/app/hekele.log 2>&1 & # 查看日志(备注: kill掉之后, 其复制jar包和启动还是执行了, 原因暂时未知... 此句话在手动启动可用, 自动重启实测也没影响) tail -f /root/app/hekele.log
JavaController
@ApiOperation("拉取最新代码然后重启应用") @GetMapping("gitPullThenRestart") public R gitPullThenRestart() { // 必须开启一个新线程, 从而返回给浏览器, 否则浏览器得不到响应, 还会再次发送 new Thread(() -> ExecUtil.execCommand(restartShell)).start(); return R.ok().setErrmsg("正在重新启动, 请稍等"); }
JavaExecUtil
/** * 执行系统命令 * * *
注意死锁问题 *
解决: 只要主进程在waitfor之前,能不断处理缓冲区中的数据就可以 * * @see 调用Process.waitfor导致的进程挂起 * * @author he_pe * */ @Slf4j public class ExecUtil { public static void execCommand(String command) { log.info("begin exec os command: " + command); Process process; try { process = Runtime.getRuntime().exec(command); //开启新线程处理正常输出 和 错误输出 newThreadLogInputStream(process.getInputStream()); newThreadLogInputStream(process.getErrorStream()); // 阻塞当前进程,直到命令结束 process.waitFor(); // 不会阻塞进程,但是调用时如果没有完成会报错 if (process.exitValue() != 0) { log.error("exec os command failure: " + command); } else { log.info("exec os command success: " + command); } } catch (Exception e) { log.error(e.getMessage(), e); } } private static void newThreadLogInputStream(InputStream is){ new Thread(() -> { try(InputStream inputStream = is; BufferedReader bufr = new BufferedReader(new InputStreamReader(inputStream))){ String out = null; while ((out = bufr.readLine()) != null) { log.info(out); } } catch (IOException e) { } }).start(); } }
感谢各位的阅读!关于“SpringBoot中项目执行脚本之自动拉取最新代码并重启的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!