springboot mybatis hikari连接池连接mysql失败现象

本文分析了在SpringBoot 2.4.6、Mybatis 3.5.6和Hikari连接MySQL时,遇到数据库宕机或其他连接问题的现象。静态类型数据源在数据库不可用时,服务启动不报错,访问时才抛异常,恢复后无需重启。动态类型数据源在初始化时若数据库不可用,会导致连接池初始化失败,需重启服务恢复。数据库恢复后,静态类型服务可自动恢复,动态类型则需要重启。建议启动时进行数据库连接检查。
摘要由CSDN通过智能技术生成

springboot hikari连接池连接mysql失败现象

背景

主要分析服务在mysql宕机(或因其他原因连不上)的情况下会有什么表现

框架:springboot 2.4.6 + mybatis 3.5.6 + hikari + mysql

现象

静态类型数据源

  1. 服务启动时,数据库无法访问,启动时服务不会抛出异常,只会在访问数据库时才会抛出异常;数据库恢复后,服务无需重启即可恢复正常

  2. 服务正常运行一段时间后,数据库无法访问,如果涉及到数据库的操作,会抛出异常;数据库恢复后,服务无需重启即可恢复正常

动态类型数据源

通过DatabaseIdProvider区分数据库类型,绑定不同的sql语句时,会发生以下现象

  1. 服务启动时,数据库无法访问,服务主线程能启动,但是数据库连接池会初始化失败,报错如下
2021-04-29 17:08:53.404 [main] ERROR com.zaxxer.hikari.pool.HikariPool - DatebookHikariCP - Exception during pool initialization.
com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中使用MyBatis进行数据库连接配置,可以通过以下步骤进行: 1. 首先,在`pom.xml`文件中添加MyBatis和数据库驱动的依赖: ```xml <dependencies> <!-- MyBatis --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> <!-- 数据库驱动 --> <dependency> <groupId>com.mysql.cj</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> </dependencies> ``` 2. 在`application.properties`或`application.yml`配置文件中添加数据库连接相关配置,例如: ```properties # 数据库连接配置 spring.datasource.url=jdbc:mysql://localhost:3306/mydatabase?useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver # MyBatis配置 mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.model ``` 3. 创建一个数据源配置类,用于配置数据库连接MyBatis的相关配置,例如: ```java @Configuration @MapperScan("com.example.mapper") public class DataSourceConfig { @Value("${spring.datasource.url}") private String url; @Value("${spring.datasource.username}") private String username; @Value("${spring.datasource.password}") private String password; @Value("${spring.datasource.driver-class-name}") private String driverClassName; @Bean public DataSource dataSource() { HikariConfig config = new HikariConfig(); config.setJdbcUrl(url); config.setUsername(username); config.setPassword(password); config.setDriverClassName(driverClassName); return new HikariDataSource(config); } @Bean public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception { SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(dataSource); return factoryBean.getObject(); } @Bean public SqlSessionTemplate sqlSessionTemplate(SqlSessionFactory sqlSessionFactory) { return new SqlSessionTemplate(sqlSessionFactory); } } ``` 4. 创建Mapper接口和对应的Mapper XML文件,用于定义数据库操作的SQL语句。 至此,你已经完成了Spring Boot中MyBatis的数据库连接配置。你可以通过注入Mapper接口来使用MyBatis进行数据库操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值