java实现spring boot项目启动时,重启Windows进程

简介: java实现spring boot项目启动时,重启Windows进程

@[toc]

一、方法总述

前5个实现了在spring boot在Windows启动服务时候,杀死相应的进程的;
第6个组成了启动相应的进程的方式。

二、SpringBoot项目启动时自动执行指定方法

在SpringBoot中,有两种接口方式实现启动执行,分别是ApplicationRunner和CommandLineRunner,除了可接受参数不同,其他的大同小异,这里选择随机选择一种,因为不需要接收参数,所以无所谓哪一种;

@Component
@Order(value = 1)
public class start implements ApplicationRunner {
    private static Logger logger = LoggerFactory.getLogger(StartService.class);

    @Override
    public void run(ApplicationArguments args) throws Exception {
        logger.info("spring boot项目启动成功");
    }
    
}

三、查看进程是否存在的方法

根据传入的course进程名,进行判断,如果存在的话,返回true,不存在返回false,供后面kill进程使用;

  /**
     * 查看进程是否存活
     *
     * @param course 进程的名称
     * @return
     * @throws IOException
     */
    public boolean isLive(String course) throws IOException {

        BufferedReader bufferedReader = null;

        try {
            Process proc = Runtime.getRuntime().exec("tasklist -fi " + '"' + "imagename eq " + course + '"');
//            将获取到的进程打印出来
            bufferedReader = new BufferedReader(new InputStreamReader(proc.getInputStream(), "UTF-8"));
            String line = null;
            while ((line = bufferedReader.readLine()) != null) {
//            如果存在,则返回true
                if (line.contains(course)) {
                    return true;
                }
            }
            return false;
        } catch (Exception ex) {
            return false;
        } finally {
//            关闭资源
            if (bufferedReader != null) {
                try {
                    bufferedReader.close();

                } catch (Exception ex) {

                }
            }
        }
    }

四、杀死Windows进程的方法

根据传入的进程的名称course,去杀死相应的进程;

  /**
     * 杀死进程
     * @param course
     * @return
     * @throws IOException
     */
    public static String killProc(String course) throws IOException {
//        判断进程是否为空
        if (StringUtils.isNotBlank(course)) {
            course = "taskkill /F /IM " + course;
        }
        Runtime runtime = Runtime.getRuntime();
        Process process = runtime.exec("cmd /c " + course);
//            将获取到的进程打印出来
        BufferedReader br = new BufferedReader(new InputStreamReader(process.getInputStream(), "UTF-8"));
        String line = null;
        StringBuilder build = new StringBuilder();
        while ((line = br.readLine()) != null) {
            build.append(line);
        }
//        返回关闭的进程
        return build.toString();
    }

五、完整代码

public class start implements ApplicationRunner {

    /**
     * 关闭系统中存在的wps.exe进程
     */
    @Override
    public void run(ApplicationArguments applicationArguments) throws Exception {

        String course = "wps.exe";

        try {
            //查看进程是否存活
            boolean isLive = isLive(course);
            if (isLive) {
                // 存在,则杀死该进程
                killProc(course);
            }
        } catch (Exception e) {
        //杀死进程失败
            e.printStackTrace();
        }

    }

    /**
     * 查看进程是否存活
     *
     * @param course 进程的名称
     * @return
     * @throws IOException
     */
    public boolean isLive(String course) throws IOException {

        BufferedReader bufferedReader = null;

        try {
            Process proc = Runtime.getRuntime().exec("tasklist -fi " + '"' + "imagename eq " + course + '"');
//            将获取到的进程打印出来
            bufferedReader = new BufferedReader(new InputStreamReader(proc.getInputStream(), "UTF-8"));
            String line = null;
            while ((line = bufferedReader.readLine()) != null) {
//            如果存在,则返回true
                if (line.contains(course)) {
                    return true;
                }
            }
            return false;
        } catch (Exception ex) {
            return false;
        } finally {
//            关闭资源
            if (bufferedReader != null) {
                try {
                    bufferedReader.close();

                } catch (Exception ex) {

                }
            }
        }
    }

    /**
     * 杀死进程
     * @param course
     * @return
     * @throws IOException
     */
    public static String killProc(String course) throws IOException {
//        判断进程是否为空
        if (StringUtils.isNotBlank(course)) {
            course = "taskkill /F /IM " + course;
        }
        Runtime runtime = Runtime.getRuntime();
        Process process = runtime.exec("cmd /c " + course);
//            将获取到的进程打印出来
        BufferedReader br = new BufferedReader(new InputStreamReader(process.getInputStream(), "UTF-8"));
        String line = null;
        StringBuilder build = new StringBuilder();
        while ((line = br.readLine()) != null) {
            build.append(line);
        }
//        返回关闭的进程
        return build.toString();
    }
}

六、实现项目启动重启进程

如果想要实现在项目启动的时候,重启进程的话,只需要在关闭进程结束后,加上启动进程就可以了。

try {
    //查看进程是否存活
    boolean isLive = isLive(course);
    if (isLive) {
        // 存在,则杀死该进程
        killProc(course);
        //启动进程
        startProc(course);
    } else {
        //启动进程
        startProc(course);
    }
} catch (Exception e) {
    logger.error("重启/杀死提取程序失败。。。");
}

%%%%%最关键的:启动进程代码:%%%%%

/**
 *  启动进程
 * @throws IOException
 */
public static void startProc(String processName) {
    log.info("启动应用程序:" + processName);
    if (StringUtils.isNotBlank(processName)) {
        try {
            Desktop.getDesktop().open(new File(processName));
        } catch (Exception e) {
            e.printStackTrace();
            log.error("应用程序:" + processName + "不存在!");
        }
    }
}
目录
相关文章
|
5月前
|
前端开发 安全 Java
Spring Boot 便利店销售系统项目分包设计解析
本文深入解析了基于Spring Boot的便利店销售系统分包设计,通过清晰的分层架构(表现层、业务逻辑层、数据访问层等)和模块化设计,提升了代码的可维护性、复用性和扩展性。具体分包结构包括`controller`、`service`、`repository`、`entity`、`dto`、`config`和`util`等模块,职责分明,便于团队协作与功能迭代。该设计为复杂企业级应用开发提供了实践参考。
224 0
|
2月前
|
Java 关系型数据库 MySQL
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
342 2
|
2月前
|
分布式计算 Java 大数据
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
152 2
|
2月前
|
Java 测试技术 Spring
简单学Spring Boot | 博客项目的测试
本内容介绍了基于Spring Boot的博客项目测试实践,重点在于通过测试驱动开发(TDD)优化服务层代码,提升代码质量和功能可靠性。案例详细展示了如何为PostService类编写测试用例、运行测试并根据反馈优化功能代码,包括两次优化过程。通过TDD流程,确保每项功能经过严格验证,增强代码可维护性与系统稳定性。
151 0
|
2月前
|
存储 Java 数据库连接
简单学Spring Boot | 博客项目的三层架构重构
本案例通过采用三层架构(数据访问层、业务逻辑层、表现层)重构项目,解决了集中式开发导致的代码臃肿问题。各层职责清晰,结合依赖注入实现解耦,提升了系统的可维护性、可测试性和可扩展性,为后续接入真实数据库奠定基础。
257 0
|
3月前
|
网络协议 Java
在SpringBoot项目中使用Netty实现远程调用
本文介绍了使用Netty解决网络连接性能问题的方法,重点讲解了Netty的NIO特性及其在SpringBoot中的应用。Netty作为高效的NIO框架,支持非阻塞IO,能通过单线程管理多个客户端连接,简化TCP/UDP套接字服务器开发。文章详细展示了Netty在SpringBoot中实现远程调用的过程,包括服务端与客户端代码实现、依赖配置及测试验证。通过示例代码,如`NettyServer`、`NettyClientUtil`等,清晰说明了Netty的工作原理和实际应用,解决了半包等问题,并提供了完整的测试结果。
499 3
|
5月前
|
SQL 前端开发 Java
深入理解 Spring Boot 项目中的分页与排序功能
本文深入讲解了在Spring Boot项目中实现分页与排序功能的完整流程。通过实际案例,从Service层接口设计到Mapper层SQL动态生成,再到Controller层参数传递及前端页面交互,逐一剖析每个环节的核心逻辑与实现细节。重点包括分页计算、排序参数校验、动态SQL处理以及前后端联动,确保数据展示高效且安全。适合希望掌握分页排序实现原理的开发者参考学习。
337 4
|
5月前
|
Java Spring 容器
两种Spring Boot 项目启动自动执行方法的实现方式
在Spring Boot项目启动后执行特定代码的实际应用场景中,可通过实现`ApplicationRunner`或`CommandLineRunner`接口完成初始化操作,如系统常量或配置加载。两者均支持通过`@Order`注解控制执行顺序,值越小优先级越高。区别在于参数接收方式:`CommandLineRunner`使用字符串数组,而`ApplicationRunner`采用`ApplicationArguments`对象。注意,`@Order`仅影响Bean执行顺序,不影响加载顺序。
445 2
|
5月前
|
安全 前端开发 Java
Spring Boot 项目中触发 Circular View Path 错误的原理与解决方案
在Spring Boot开发中,**Circular View Path**错误常因视图解析与Controller路径重名引发。当视图名称(如`login`)与请求路径相同,Spring MVC无法区分,导致无限循环调用。解决方法包括:1) 明确指定视图路径,避免重名;2) 将视图文件移至子目录;3) 确保Spring Security配置与Controller路径一致。通过合理设定视图和路径,可有效避免该问题,确保系统稳定运行。
358 0
|
6月前
|
Java 数据库 微服务
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——指定项目配置文件
在实际项目中,开发环境和生产环境的配置往往不同。为简化配置切换,可通过创建 `application-dev.yml` 和 `application-pro.yml` 分别管理开发与生产环境配置,如设置不同端口(8001/8002)。在 `application.yml` 中使用 `spring.profiles.active` 指定加载的配置文件,实现环境快速切换。本节还介绍了通过配置类读取参数的方法,适用于微服务场景,提升代码可维护性。课程源码可从 [Gitee](https://gitee.com/eson15/springboot_study) 下载。
231 0