今天从https://start.spring.io下载配置好的spring boot项目:
启动后却报出如下错误:
即Process finished with exit code 0
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父依赖进行的统一管理。
因而,我们需要在pom.xml文件中,引入如下spring-boot-starter-web依赖即可:
org.springframework.boot spring-boot-starter-web
此时,重新运行项目:
当然,我们还需要在对应的接口上加上@RestController等注解:
@RestController @RequestMapping("/task") public class TaskController { //省略业务逻辑...... }