
主要是 mybatis 多数据源(配置了两个数据库,oracle 和 sql server,但是只使用了一个) + druid 。
测试了在 win 和 linux 分别部署,结果是一样的,第二天的第一次请求特别慢,达到 1-2 分钟。
我在请求 pending 的时候取了 thread dump,不太会看。。。
thread dump: https://note.ms/evah
1 watzds 2020-04-26 09:06:30 +08:00 via Android 可能数据库连接闲置后断开了,第一次要重连 |
2 watzds 2020-04-26 09:07:22 +08:00 via Android 不过一两分钟也太慢了 |
4 securityCoding 2020-04-26 10:15:33 +08:00 开启 selelct 1 连接探测 |
5 mazyi PRO 看日志慢在哪里啊,dump 没用 |
6 xiaoxinshiwo 2020-04-26 11:07:36 +08:00 mybatis 设置 dialect 属性 |
8 BaiMax OP @securityCoding 项目集成了 springboot admin,日志里可以看到每几秒都有 select 'hello' from dual, 这个是不是同样的效果? |
9 BaiMax OP 我贴一下配置文件 https://note.ms/ateu |
10 otakustay 2020-04-26 11:44:35 +08:00 简单点,端到端,写个脚本每 1 分钟去 curl 一下首页就好了 |
11 fewok 2020-04-26 11:50:04 +08:00 换个角度,会不会是数据库的问题? |
12 BaiMax OP @xiaoxinshiwo 那多数据源应该怎么设置? |
13 xiaoxinshiwo 2020-04-26 11:56:15 +08:00 @BaiMax #12 多数据源一样设置啊,只不过有个数据源设置为主数据源 |
14 fmumu 2020-04-26 11:57:28 +08:00 via Android 多次 dump 看看线程在干嘛 |
15 yukiloh 2020-04-26 12:17:01 +08:00 via Android 我遇到的情况是,数据库是 maria5.x,最后推断是 maria 的配置的存活时间< springboot 配置的时间(两者才用的时间制式不一样),导致假死(可能,因为最后都没搞定,换了高版本解决) |
16 tab16360 2020-04-26 12:46:08 +08:00 via Android https://x1024.com/index.php/archives/14/ 看看这个是不是能解决 |
17 gengz 2020-04-26 12:51:51 +08:00 druid: # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 timeBetweenEvictionRunsMillis: 60000 # 配置一个连接在池中最小生存的时间,单位是毫秒 minEvictableIdleTimeMillis: 30000 validationQuery: select 'x' testWhileIdle: true testOnBorrow: false testOnReturn: false druid 的配置, 你参考下 |
18 senninha 2020-04-26 12:58:59 +08:00 录个 JFR 分析一下啊 |
19 temp178 2020-04-26 13:02:46 +08:00 可能是数据库连接池里都超时了,然后请求的时候拿出连接来,一个个都超时了,比较慢,参考#17 |
20 hengyunabc 2020-04-26 13:02:47 +08:00 |
21 BaiMax OP 上次的 dump 好像没什么内容,更新了一下正文的 Thread dump.. |