温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SpringBoot中项目执行脚本之自动拉取最新代码并重启的示例分析

发布时间:2021-07-23 11:07:09 来源:亿速云 阅读:125 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关SpringBoot中项目执行脚本之自动拉取最新代码并重启的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

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

/**
 * 执行系统命令
 * 
 * 
 * <br> 注意死锁问题
 * <br> 解决: 只要主进程在waitfor之前,能不断处理缓冲区中的数据就可以
 * 
 * @see <a href="https://blog.csdn.net/seapeak007/article/details/69668600" rel="external nofollow" >调用Process.waitfor导致的进程挂起</a>
 * 
 * @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中项目执行脚本之自动拉取最新代码并重启的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI