解决【spring boot】Process finished with exit code 0的问题

文章目录

  • 1. 复现错误
  • 2. 分析错误
  • 3. 解决问题

1. 复现错误

今天从https://start.spring.io下载配置好的spring boot项目:

在这里插入图片描述

启动后却报出如下错误:

在这里插入图片描述

即Process finished with exit code 0

2. 分析错误

Process finished with exit code 0翻译成中文进程已完成,退出代码为 0。

我们再次细看上图中的日志信息:

在这里插入图片描述

我们注意看这句话:Started DemoApplication in 0.875 seconds (JVM running for 1.423),它是说DemoApplication应用花了0.875秒的时间启动了,但JVM只运行了1.423秒。

DemoApplication就是我创建的应用。

正因为JVM只运行了1.423秒就挂了,导致这个错误的出现:Disconnected from the target VMaddress: 127.0.0.1:8233 , transport: ‘socket!。

jvm为什么会挂了?因为我们缺少web应用服务器,比如tomcat应用服务器。

但是,spring boot已经内置了tomcat服务器,有可能我的pom.xml没有引入集成tomcat的依赖?于是,检查我的pom.xml文件:


	4.0.0
	
		org.springframework.boot
		spring-boot-starter-parent
		2.6.0
		 
	
	com.example
	demo
	0.0.1-SNAPSHOT
	demo
	Demo project for Spring Boot
	
		8
	
	
		
			org.springframework.boot
			spring-boot-starter
		
		
			org.springframework.boot
			spring-boot-starter-test
			test
		
	

	
		
			
				org.springframework.boot
				spring-boot-maven-plugin
			
		
	

果然,我们的pom.xml文件中没有引入tomcat的依赖,而tomcat的依赖是在spring-boot-starter-web中。

spring-boot-starter-web依赖启动器的主要作用,是提供Web开发场景所需的底层所有依赖。

正是如此,在pom.xml中引入spring-boot-starter-web依赖启动器时,就可以实现Web场景开发,而不需要额外导入Tomcat服务器以及其他Web依赖文件等。

这些引入的依赖文件的版本号还是由spring-boot-starter-parent父依赖进行的统一管理。

3. 解决问题

因而,我们需要在pom.xml文件中,引入如下spring-boot-starter-web依赖即可:

	org.springframework.boot
	spring-boot-starter-web

此时,重新运行项目:

在这里插入图片描述

当然,我们还需要在对应的接口上加上@RestController等注解:

@RestController
@RequestMapping("/task")
public class TaskController {
  //省略业务逻辑......
}

本文来自网络,不代表协通编程立场,如若转载,请注明出处:https://net2asp.com/5794bf66c5.html