Spring Boot 应用自动退出剖析

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 今天因技术群里的小伙伴们在请教关于 Spring Boot 微服务应用启动成功后自动退出问题,故特此顺便整理下,以供大家在实际的业务场景中能够有所借鉴及参考。

    今天因技术群里的小伙伴们在请教关于 Spring Boot 微服务应用启动成功后自动退出问题,故特此顺便整理下,以供大家在实际的业务场景中能够有所借鉴及参考。    

   在实际的业务场景中,我们经常会遇到如下异常提示:“Process finished with exit code x “。通常表现为:创建好的 Spring Boot 微服务项目,启动时无异常,却立马自动退出,无论基于何种方式启动均无效且控制台无任何有效信息。此类异常的处理往往较为繁琐,尤其是在无任何 Log 、无明显关键字输出的场景下,尤为让人摸不着头脑。

    那么,针对此类问题,如何能够快速定位、分析?有没有相应的针对性解决方案呢?

其实,针对每一种可能出现的场景都有其独特的处理方式,常见的案例场景,具体如下所示:

    1、 无 Spring 框架日志输出

    此类异常往往无任何线索,没有相关的日志产生

    解决策略:

   针对此类型场景,若我们直接通过启动脚本或者 java -jar 命令行启动,且无任何 Spring 相关日志。此时,需要检测启动脚本文件,启动时定义 Java 虚拟机相关内存参数及垃圾回收策略,检查其语法:内存的适配性、回收算法的匹配性、命令行正确性以及完整性等。

    举一个简单的示例,例如:当部署的 Spring Boot 微服务 运行在 4C 8G 的虚拟机之上,若我们给应用程序分配的堆内存大小超过操作系统所分配的物理内存 8G时,则其是无法启动起来的。除此之外,若启动脚本文件中所定义的年轻代与年老代 GC 策略或模型不匹配,基于特定的环境约束,也有可能是无法启动成功的。当然,命令行正确性及完整性同样也会导致如上场景异常。

    2、 Process finished with exit code 1

    此类异常通常仅输出 Spring 框架日志,即输出框架版本信息,再无其他可用信息,或者借助 Debug 可打印更多信息。具体如下所示:

   (1)引用包异常

    解决策略:

    针对此类问题,往往建议强制异常捕获并打印出来,然后再次启动,可用的信息将会显示出来,通常可能因配置文件少了某一些组件的配置,导致项目启动过程中初始化组件失败。

  (2)Yaml、POM 及 XML 文件配置异常

    解决策

    针对此类问题,着重检查文件内容“格式”的规范性、“参数”的正确性以及可能存在的组件依赖性缺失。针对版本参数正确性问题,往往在 Maven下面的 Dependencies 中的Spring Boot 的版本与 pom.xml 文件中所定义的 Spring Boot 的版本不一致,导致启动异常。针对组件依赖性,可参考如下所示:


<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <!-- 移除对Tomcat的内置依赖 -->
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
        </exclusion>
    </exclusions>
</dependency>

    或如下,


<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
</dependency>

  (3)日志框架冲突异常

    解决策

    针对此类问题,往往因 Log4j 和 Common-logs 日志包冲突,为此,我们可通过以下方式解决,具体如下所示:

    方式1:解决冲突,排除掉 Slf4j、Common-logs 其中一方,Spring 使用 slf4j,那可以排除掉 Common-logs

    方式2:  打通Log4j 和 Common-logs,Maven 相关依赖如下所示:


<dependency>
     <groupId>org.slf4j</groupId>
     <artifactId>jcl-over-slf4j</artifactId>
</dependency>

    此依赖可以有效将 Log4j 输出到 Slf4j,从而从 Slf4j输出。

  (4)环境变量异常

    解决策略:

    针对此类异常,往往因程序启动过程中找不到对应的环境变量,无法正确加载环境配置,导致服务启动异常。此时,需要检测 Active Profiles 等相关参数正确性。具体如下所示:


#日志配置-选择一个日志输出环境
spring.profiles.active=dev

    3、 Process finished with exit code 0

    针对此类问题,主要表现为“兼容性”问题,程序往往能够正常运行,但同时出现自动退出现象,具体如下:

   (1)项目中组件依赖兼容性异常

    解决策略:

    针对此类异常,往往需要清除 Maven 工程下面的依赖,具体如下所示:


<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-tomcat</artifactId>
   <scope>provided</scope>
</dependency>

    若我们的环境不是基于 Maven工程,则需要将 spring-boot-starter-tomcat 这个包去除掉即可。

  (2)Spring Boot 不同版本兼容性异常

    解决策略:

    针对此类异常,往往需要对高版本的 Spring Boot 相关 pom.xml 进行调整,需要注意的时,以下依赖必须至少包含:


<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>

   或


<dependency>
  <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>

    综上所述,基于Spring Boot 应用自动退出的相关场景案例,本文简要剖析到此为止,其他不常见的场景以及解决策略暂未在本文中描述,大家有任何问题或建议,可以随时留言、沟通。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
17天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
98 1
|
28天前
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
2月前
|
安全 Java 网络安全
当网络安全成为数字生活的守护者:Spring Security,为您的应用筑起坚不可摧的防线
【9月更文挑战第2天】在数字化时代,网络安全至关重要。本文通过在线银行应用案例,详细介绍了Spring Security这一Java核心安全框架的核心功能及其配置方法。从身份验证、授权控制到防御常见攻击,Spring Security提供了全面的解决方案,确保应用安全。通过示例代码展示了如何配置`WebSecurityConfigurerAdapter`及`HttpSecurity`,帮助开发者有效保护应用免受安全威胁。
66 4
|
12天前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
18天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第8天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建并配置 Spring Boot 项目,实现后端 API 和安全配置。接着,使用 Ant Design Pro Vue 脚手架创建前端项目,配置动态路由和菜单,并创建相应的页面组件。最后,通过具体实践心得,分享了版本兼容性、安全性、性能调优等注意事项,帮助读者快速搭建高效且易维护的应用框架。
23 3
|
19天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第7天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建 Spring Boot 项目并配置 Spring Security。接着,实现后端 API 以提供菜单数据。在前端部分,使用 Ant Design Pro Vue 脚手架创建项目,并配置动态路由和菜单。最后,启动前后端服务,实现高效、美观且功能强大的应用框架。
20 2
|
23天前
|
人工智能 缓存 Java
深入解析Spring AI框架:在Java应用中实现智能化交互的关键
【10月更文挑战第12天】Spring AI 是 Spring 框架家族的新成员,旨在满足 Java 应用程序对人工智能集成的需求。它支持自然语言处理、图像识别等多种 AI 技术,并提供与云服务(如 OpenAI、Azure Cognitive Services)及本地模型的无缝集成。通过简单的配置和编码,开发者可轻松实现 AI 功能,同时应对模型切换、数据安全及性能优化等挑战。
|
6天前
|
存储 Java 数据管理
强大!用 @Audited 注解增强 Spring Boot 应用,打造健壮的数据审计功能
本文深入介绍了如何在Spring Boot应用中使用`@Audited`注解和`spring-data-envers`实现数据审计功能,涵盖从添加依赖、配置实体类到查询审计数据的具体步骤,助力开发人员构建更加透明、合规的应用系统。
|
13天前
|
XML Java 数据格式
Spring IOC容器的深度解析及实战应用
【10月更文挑战第14天】在软件工程中,随着系统规模的扩大,对象间的依赖关系变得越来越复杂,这导致了系统的高耦合度,增加了开发和维护的难度。为解决这一问题,Michael Mattson在1996年提出了IOC(Inversion of Control,控制反转)理论,旨在降低对象间的耦合度,提高系统的灵活性和可维护性。Spring框架正是基于这一理论,通过IOC容器实现了对象间的依赖注入和生命周期管理。
40 0
|
2月前
|
Java 对象存储 开发者
故障隔离与容错处理:Hystrix在Spring Cloud和Netflix OSS中的应用
故障隔离与容错处理:Hystrix在Spring Cloud和Netflix OSS中的应用
48 3