解决Druid动态数据源配置重复刷错误⽇志的问题Druid动态数据源配置主要是继承AbstractRoutingDataSource再通过AOP来实现动态数据源切换.
下⾯给⼤家介绍Druid动态配置数据源重复刷错误⽇志问题,具体内容如下所⽰:
问题描述
功能需求:
使⽤druid数据库连接池实现动态的配置数据源功能:IP、端⼝、⽤户名、密码都是⽤户页⾯⼿动输⼊,可以测试连接,保存数据源。
问题说明:
既然是⽤户⾃⼰配置的数据源,就⽆法避免输⼊错误,连接失败等情况。
预期情况:⽤户输⼊的配置错误,测试连接时,会返回连接失败的信息。
实际情况:数据源测试连接,连接失败后:
后台⼀直打印错误信息,⼀直⾃动重连
⽅法被阻塞⽆返回信息,导致前端页⾯⼀直处于等待状态
【错误信息】:
com.alibaba.druid.pool.DruidDataSource-create connection SQLException, url:xxx, errorCode 0, state 08S01
The last packet sent successfully to the server was 0 milliseconds ago.
The driver has not received any packets from the server.
【原始代码】:
public static void getDataSource(DataConfig dataConfig) throws Exception{
try {
Properties properties = new Properties();
properties.setProperty("driverClassName",DriverClassName());
properties.setProperty("url",Url());
properties.setProperty("username",UserName());
properties.setProperty("password",PassWord());
DataSource ds = ateDataSource(properties);
} catch (Exception e) {
e.printStackTrace();
}
}
解决办法
【参数说明】
参数解释
connectionErrorRetryAttempts连接出错后再尝试连接次数
breakAfterAcquireFailure数据库服务宕机⾃动重连机制
maxWait超时等待时间
【修改后的代码】
public static void getDataSource(DataConfig dataConfig) throws Exception{
try {
Properties properties = new Properties();
properties.setProperty("driverClassName",DriverClassName());
properties.setProperty("url",Url());
properties.setProperty("username",UserName());
properties.setProperty("password",PassWord());
properties.setProperty("maxWait","500");//如果失败,当前的请求可以返回
DruidDataSource druidDataSource = (ateDataSource(properties);
druidDataSource.setConnectionErrorRetryAttempts(0);// 失败后重连的次数
druidDataSource.setBreakAfterAcquireFailure(true);//请求失败之后中断
druid连接池配置详解DataSource ds = druidDataSource;//如果有需要使⽤javax.sql.DataSource的话
} catch (Exception e) {
e.printStackTrace();
}
}
踩坑总结
不要在properties中配置connectionErrorRetryAttempts和breakAfterAcquireFailure,没有效果
连接失败的具体错误信息,catch不到,源码中已经catch了异常信息,做了相关处理
到此这篇关于解决Druid动态数据源配置重复刷错误⽇志的问题的⽂章就介绍到这了,更多相关Druid动态数据源配置内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论