系列文章目录
文章目录
前言
一、问题案例
1、maven项目compile时候出现告警warn
告警提示:
Parameter 'compilerVersion' (user property 'maven.compiler.compilerVersion') is deprecated: This parameter is no longer evaluated by the underlying compilers, instead the actual version of the javac binary is automatically retrieved. [INFO] Recompiling the module because of changed source code.
解决:
这个警告消息来自 Maven 编译器插件,提示参数 compilerVersion
已被弃用,并且不再由底层编译器评估。相反,Javac 二进制文件的实际版本会自动检索。
compilerVersion
参数已被弃用,这意味着即使你在 Maven 配置中指定了这个参数,它也不会影响编译器的行为。Maven 编译器插件会自动确定并使用已安装的 Java 编译器版本。
解决方法一:
如果你在 pom.xml
文件中指定了 compilerVersion
参数,可以安全地移除它。相反,应该确保你正确配置了 source
和 target
参数来指定编译的 Java 版本。
解决方法二:
添加这两句解决问题是因为它们明确地指定了 Maven 编译器插件的配置。具体来说:
```xml
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version> <!-- 确保使用最新版本 -->
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
```
1. **`maven-compiler-plugin` 的配置**:- `maven-compiler-plugin` 是 Maven 用于编译 Java 源代码的插件。它负责将源代码编译成字节码。
- 指定插件的版本(例如 `3.8.1`)确保你使用的是最新的稳定版本,这样可以避免已知的错误或不兼容问题。
2. **`<source>` 和 `<target>` 参数**:
- 这两个参数用来指定 Java 语言的版本。
- `<source>` 定义了编译源代码时使用的 Java 版本。
- `<target>` 定义了生成字节码时的目标 Java 版本。
- 例如,如果你的项目使用 Java 17,`<source>` 和 `<target>` 都应该设置为 `17`。
- 这些设置帮助 Maven 编译器插件确定要使用的 Java 语言特性和字节码格式。
### 解决问题的原因
- **明确的编译器设置**: 当你指定 `<source>` 和 `<target>` 版本时,Maven 编译器插件知道你想要使用哪种 Java 版本。这消除了插件猜测或自动检测的必要性,并且避免了可能的警告或错误。
- **兼容性和稳定性**: 使用明确指定的版本(例如 `3.8.1`)可以确保你利用的是经过验证的版本,而不是不稳定或过时的版本。这也帮助避免了由于使用不同的插件版本而引起的不兼容问题。
- **清晰的项目配置**: 通过明确的配置,其他开发者或构建系统在构建你的项目时不需要做额外的配置调整。项目的构建过程变得更加可预测和稳定。通过添加这些配置,你明确告诉 Maven 如何编译你的 Java 代码。这不仅可以解决特定的警告或错误,还可以确保项目在不同环境和设置下的一致性和稳定性。
2、java文件打包然后在命令行中运行java会找不到主类
原因:
要确保 Java 运行时能找到你的主类,你需要在打包时正确地指定主类。可以通过两种方式做到这一点
解决:
### 1. **指定主类**
要确保 Java 运行时能找到你的主类,你需要在打包时正确地指定主类。可以通过两种方式做到这一点:
#### 在 `pom.xml` 中指定主类
如果你使用 Maven 构建项目,可以在 `pom.xml` 中通过 `maven-jar-plugin` 指定主类:
```xml
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>com.example.MainClass</mainClass> <!-- 替换为你的主类 -->
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
```
- `<mainClass>` 元素指定了你的主类的完全限定名(包括包名)。
#### 手动创建 `MANIFEST.MF` 文件
在构建过程中,或手动创建一个包含以下内容的 `MANIFEST.MF` 文件:
```
Manifest-Version: 1.0
Main-Class: com.example.MainClass
```
然后将此文件包含在你的 JAR 文件中。确保 `com.example.MainClass` 是你的主类的全限定名。
### 2. **打包 JAR 文件**
确保你正确地打包了 JAR 文件并且所有的类文件和资源都包含在内。例如,使用 Maven,可以运行以下命令:
```bash
mvn clean package
```
这个命令会生成一个包含指定主类的可执行 JAR 文件。
### 3. **运行 JAR 文件**
一旦你有了正确的 JAR 文件,可以使用以下命令运行它:
```bash
java -jar your-jar-file.jar
```
确保 `your-jar-file.jar` 是你生成的 JAR 文件的名称。
### 4. **检查包名和类路径**
如果你仍然遇到问题,检查以下几点:
- **主类的包名**: 确保主类的包名在代码和 JAR 文件中是一致的。
- **类路径**: 如果你的应用程序依赖外部库,请确保它们在运行时的类路径中。如果它们没有打包在 JAR 文件中,你可能需要通过 `-classpath` 或 `-cp` 选项指定它们。
例如:
```bash
java -cp your-jar-file.jar:lib/* com.example.MainClass
```
这会在类路径中包括 `your-jar-file.jar` 和 `lib` 目录中的所有 JAR 文件。
通过这些步骤,你应该能够正确地指定和找到主类,并成功运行你的 Java 应用程序。
3、程序找不到数据库驱动和配置实例
问题和解决:
Caused by: org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Failed to determine a suitable driver class
这个错误信息 `Failed to determine a suitable driver class` 表示 Spring Boot 在尝试创建数据源时,无法确定合适的数据库驱动类。这通常是由于以下几个原因之一:
### 1. **缺少数据库驱动依赖**
确保你的 `pom.xml` 中已经包含了相应的数据库驱动程序。例如,如果你使用 MySQL 数据库,应该包含以下依赖:
```xml
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>8.0.32</version> <!-- 使用你需要的版本 -->
</dependency>
```
### 2. **未配置正确的数据库连接属性**
检查 `application.properties` 或 `application.yml` 中的数据库连接配置,确保已提供正确的 JDBC URL、用户名和密码。对于 MySQL,配置应如下所示:
```properties
spring.datasource.url=jdbc:mysql://localhost:3306/yourdatabase
spring.datasource.username=yourusername
spring.datasource.password=yourpassword
```
或在 `application.yml` 中:
```yaml
spring:
datasource:
url: jdbc:mysql://localhost:3306/yourdatabase
username: yourusername
password: yourpassword
```
确保 `jdbc:mysql://` 是你的数据库 URL 的前缀。
### 3. **不正确的驱动类名称**
尽管 Spring Boot 通常会自动检测合适的驱动类,但在某些情况下,你可能需要显式地指定驱动类。你可以在 `application.properties` 或 `application.yml` 中设置:
```properties
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
```
或在 `application.yml` 中:
```yaml
spring:
datasource:
url: jdbc:mysql://localhost:3306/yourdatabase?useSSL=false&serverTimezone=UTC&characterEncoding=utf8
username: yourusername
password: yourpassword
driver-class-name: com.mysql.cj.jdbc.Driver
hikari:
maximum-pool-size: 10
minimum-idle: 5
idle-timeout: 30000
connection-timeout: 30000
max-lifetime: 1800000
```
### 4. **依赖版本问题**
有时,不兼容或过时的库版本也可能导致问题。确保所有依赖项,包括 Spring Boot 和 MySQL 驱动程序,都是兼容的最新版本。
### 5. **Spring Boot Starter 使用**
如果你使用 Spring Boot 的 starter 来简化配置,确保使用的是正确的 starter。例如,使用 `spring-boot-starter-data-jpa` 时,通常会自动包括适当的数据库依赖,但如果缺少 MySQL 依赖,则需要手动添加。
### 6. **多数据源配置**
如果你在项目中配置了多个数据源,确保每个数据源都有正确的配置,并且 Spring 能够明确识别哪个数据源应该使用哪个驱动。
4、springboot和mybatis-plus版本不兼容导致
ddlApplicationRunner'
的 bean 被期望是org.springframework.boot.Runner
类型
问题和解决:
Bean named 'ddlApplicationRunner' is expected to be of type 'org.springframework.boot. Runner' but was actually of type 'org.springframework.beans.factory.support.NullBean'
at org.springframework.beans.factory.support.AbstractBeanFactory.adaptBeanInstance(AbstractBeanFactory.java:410) ~[spring-beans-6.1.3.jar:6.1.3]
Bean named 'ddlApplicationRunner' is expected to be of type 'org.springframework.boot. Runner' but was actually of type 'org.springframework.beans.factory.support.NullBean'
at org.springframework.beans.factory.support.AbstractBeanFactory.adaptBeanInstance(AbstractBeanFactory.java:410) ~[spring-beans-6.1.3.jar:6.1.3]
5、springboot项目启动的解释
问题和解决:
从日志中可以看出,你的 Spring Boot 应用程序启动时发生了一些重要事件。以下是对日志的详细解释:
### 日志解释
1. **启动信息**:
```plaintext
2024-07-24T14:17:51.254+08:00 INFO 20596 --- [ main] o.l.neg_platform.NegPlatformApplication : Starting NegPlatformApplication using Java 17.0.8 with PID 20596 (D:\WorkPace\JavaWorkpace\neg_platform\target\classes started by 86195 in D:\WorkPace\JavaWorkpace\neg_platform)
```
- 应用程序 `NegPlatformApplication` 正在使用 Java 17.0.8 版本启动,进程 ID 是 20596。
- 应用程序的运行目录在 `D:\WorkPace\JavaWorkpace\neg_platform`。
2. **没有设置活动的 Spring Profile**:
```plaintext
2024-07-24T14:17:51.263+08:00 INFO 20596 --- [ main] o.l.neg_platform.NegPlatformApplication : No active profile set, falling back to 1 default profile: "default"
```
- 没有设置活动的 Spring Profile,因此使用了默认的 "default" 配置。
3. **MyBatis Mapper 未找到**:
```plaintext
2024-07-24T14:17:51.892+08:00 WARN 20596 --- [ main] o.m.s.mapper.ClassPathMapperScanner : No MyBatis mapper was found in '[org.louis.neg_platform]' package. Please check your configuration.
```
- 这是一个警告信息,表示在指定的包 `[org.louis.neg_platform]` 中没有找到 MyBatis Mapper 接口。
- 这通常意味着你可能没有正确配置 MyBatis 的扫描路径,或是你的 Mapper 接口没有放置在正确的位置,或是没有添加必要的注解,例如 `@Mapper`。
4. **Tomcat Web 服务器启动**:
```plaintext
2024-07-24T14:17:52.218+08:00 INFO 20596 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat initialized with port 8080 (http)
```
- 嵌入式的 Tomcat Web 服务器初始化在端口 8080 上。
5. **启动 Tomcat 服务**:
```plaintext
2024-07-24T14:17:52.226+08:00 INFO 20596 --- [ main] o.apache.catalina.core.StandardService : Starting service [Tomcat]
2024-07-24T14:17:52.226+08:00 INFO 20596 --- [ main] o.apache.catalina.core.StandardEngine : Starting Servlet engine: [Apache Tomcat/10.1.26]
```
- Tomcat 服务开始启动,使用的 Servlet 引擎版本是 Apache Tomcat 10.1.26。
6. **Spring 上下文初始化**:
```plaintext
2024-07-24T14:17:52.267+08:00 INFO 20596 --- [ main] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext
2024-07-24T14:17:52.268+08:00 INFO 20596 --- [ main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 946 ms
```
- Spring 的嵌入式 WebApplicationContext 初始化完成。
7. **MyBatis-Plus 版本信息**:
```plaintext
_ _ |_ _ _|_. ___ _ | _
| | |\/|_)(_| | |_\ |_)||_|_\
/ |
3.5.7
```
- 这是 MyBatis-Plus 的启动标志,显示使用的版本是 3.5.7。
8. **应用程序启动完成**:
```plaintext
2024-07-24T14:17:52.936+08:00 INFO 20596 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port 8080 (http) with context path '/'
2024-07-24T14:17:52.942+08:00 INFO 20596 --- [ main] o.l.neg_platform.NegPlatformApplication : Started NegPlatformApplication in 2.14 seconds (process running for 2.803)
```
- Tomcat 成功启动并监听端口 8080,应用程序 `NegPlatformApplication` 在大约 2.14 秒内启动完成。
### 需要关注的部分
1. **MyBatis Mapper 未找到**:
- 这是一个需要注意的问题。你需要确保正确配置了 MyBatis Mapper 扫描路径。例如,在 `application.yml` 或 `application.properties` 中设置 `mybatis.mapper-locations`,或者在启动类上使用 `@MapperScan` 注解来指定扫描路径。
```java
@SpringBootApplication
@MapperScan("com.example.mapper")
public class MyApplication {
public static void main(String[] args) {
SpringApplication.run(MyApplication.class, args);
}
}
```
确保这些问题得到解决后,应用程序才能正常运行并正确连接到数据库。
6、jdbc驱动过时
问题:
MySQL JDBC Driver 是 Java 应用程序用来与 MySQL 数据库进行交互的驱动程序。它实现了 JDBC(Java Database Connectivity)API,这是 Java 标准的一部分,用于提供数据库访问的统一接口。以下是 MySQL JDBC Driver 的几个主要作用:
1. **数据库连接**:
JDBC Driver 允许 Java 应用程序建立到 MySQL 数据库的连接。这是数据库操作的第一步。
2. **SQL 语句执行**:
通过 JDBC Driver,应用程序可以执行 SQL 语句,包括查询(SELECT)、更新(UPDATE)、插入(INSERT)和删除(DELETE)操作。
3. **事务管理**:
JDBC Driver 支持事务管理,确保数据的完整性和一致性。它允许应用程序提交或回滚事务。
4. **数据检索和更新**:
JDBC Driver 提供了从数据库检索数据和向数据库发送数据的机制。它可以使用 `ResultSet` 对象来处理查询结果。
5. **预处理语句**:
JDBC Driver 支持预处理语句(PreparedStatement),这可以提高性能并防止 SQL 注入攻击。
6. **批量操作**:
JDBC Driver 允许执行批量操作,这对于大量数据的插入或更新非常有用。
7. **元数据访问**:
应用程序可以使用 JDBC Driver 访问数据库的元数据,例如表结构、列信息等。
8. **连接池支持**:
JDBC Driver 可以与连接池(如 HikariCP、Apache DBCP 或 C3P0)集成,以提高数据库连接的效率和性能。
9. **安全性**:
JDBC Driver 支持加密连接(如 SSL),确保数据传输的安全性。
10. **国际化和本地化**:
JDBC Driver 支持多种字符集和语言,以适应全球化应用程序的需求。
总之,MySQL JDBC Driver 是 Java 应用程序与 MySQL 数据库进行通信的桥梁,提供了执行数据库操作所需的所有功能。
你的 `pom.xml` 中的 `mysql-connector-j` 依赖项已经指定了较新的版本 8.2.0,这是一个较新的 MySQL JDBC 驱动版本。在这个版本中,驱动类名 `com.mysql.jdbc.Driver` 已经被 `com.mysql.cj.jdbc.Driver` 替代。因此,通常不需要手动指定驱动类名,因为驱动会自动注册。
### 需要做的事情:
1. **检查驱动类**:
- 如果你的代码中有类似 `Class.forName("com.mysql.jdbc.Driver")` 的行,你应该将其更新为 `Class.forName("com.mysql.cj.jdbc.Driver")`。但请注意,通常现代驱动不再需要手动加载驱动类,因为驱动会自动注册。
2. **更新 JDBC 连接字符串**:
- 确保你的 JDBC 连接字符串是符合最新标准的。通常连接字符串格式如下:
```properties
jdbc:mysql://hostname:port/dbname?useSSL=false&serverTimezone=UTC
```
- 注意参数的正确性,例如 `useSSL` 和 `serverTimezone`,这些参数可能在不同版本中有变化。
3. **确保配置正确**:
- 确保你没有遗留旧的驱动或配置,尽量清理掉不必要的旧依赖和设置。
### 示例 `pom.xml` 更新:
如果你已经使用了最新版本的驱动,`pom.xml` 文件中的依赖部分不需要更改。你的依赖配置看起来已经是正确的:
```xml
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>8.2.0</version>
<scope>runtime</scope>
</dependency>
```
### 总结:
- 你的 `pom.xml` 中的依赖配置已经是使用最新版本的驱动。
- 检查和更新代码中是否还有手动加载驱动类的旧代码。
- 确保你的 JDBC 连接字符串和其他相关配置是适用于新版驱动的。
通过这些步骤,你可以确保你的项目兼容性和使用的是最新的驱动特性。
7、springboot项目启动时候提示:Java HotSpot(TM) 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended
问题和解决:
大概意思就是jvm的类加载器的执行顺序,有些第三方的包加载顺序并没有添加在bootstarp classloader中,所以提示。
当在IDEA中连接Redis时出现"Java HotSpot™ 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended"错误,通常是因为类加载器(ClassLoader)的共享机制引发的警告。
Java的类加载机制涉及到Bootstrap ClassLoader、Extension ClassLoader和Application ClassLoader。Bootstrap ClassLoader负责加载核心类库,Extension ClassLoader负责加载Java扩展库,而Application ClassLoader负责加载应用程序的类。
当IDEA启动时,IDEA会改变类加载器的加载方式,在应用程序启动时将一些核心类库路径添加到BootStrap ClassLoader的搜索路径中。这样,当应用程序执行时,某些类库会先由BootStrap ClassLoader加载,然后再由Application ClassLoader加载。
然而,由于Redis客户端库通常不是放在BootStrap ClassLoader的搜索路径下的,所以在加载Redis客户端库时,会出现上述警告。
虽然出现警告,但通常不会影响应用程序的正常运行。你可以忽略该警告,或者通过设置VM选项来关闭该警告。
如果你希望关闭警告,可以尝试以下方法:
在IDEA的启动选项中,添加以下JVM参数:
-Dsun.misc.URLClassPath.disableJarChecking=true
在IDEA的启动选项中,添加以下JVM参数:
-XX:-ShareBootClassLoader
8、Druid监控页面无法打开(404)
问题解决:
配置了druid的yml和导入了依赖项,但是项目启动时候访问http://127.0.0.1:8080/druid/api.html
会页面打不开报404,主要原因在于springboot3版本和druid的版本不一致,所以导致了项目启动时候druid初始化,然后就closed了
这样配置就能访问druid的监控页面了