文章目录
- 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
文件:
project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
modelVersion>4.0.0modelVersion>
parent>
groupId>org.springframework.bootgroupId>
artifactId>spring-boot-starter-parentartifactId>
version>2.6.0version>
relativePath/>
parent>
groupId>com.examplegroupId>
artifactId>demoartifactId>
version>0.0.1-SNAPSHOTversion>
name>demoname>
description>Demo project for Spring Bootdescription>
properties>
java.version>8java.version>
properties>
dependencies>
dependency>
groupId>org.springframework.bootgroupId>
artifactId>spring-boot-starterartifactId>
dependency>
dependency>
groupId>org.springframework.bootgroupId>
artifactId>spring-boot-starter-testartifactId>
scope>testscope>
dependency>
dependencies>
build>
plugins>
plugin>
groupId>org.springframework.bootgroupId>
artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
project>
果然,我们的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
依赖即可:
dependency>
groupId>org.springframework.bootgroupId>
artifactId>spring-boot-starter-webartifactId>
dependency>
此时,重新运行项目:
当然,我们还需要在对应的接口上加上@RestController
等注解:
@RestController
@RequestMapping("/task")
public class TaskController {
//省略业务逻辑......
}