首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >配置MyBatis以使用轻量级MySQL ping /* ping */

配置MyBatis以使用轻量级MySQL ping /* ping */
EN

Stack Overflow用户
提问于 2015-05-11 06:27:26
回答 1查看 1.7K关注 0票数 1

使用JDBC MySQL驱动程序(v5.1.3和更高版本),可以使用/* ping */前缀来发出“轻量级”ping,而不是提供的SQL语句。

例如:/* ping */ SELECT 1

我正在尝试配置myBatis来使用它,但是它不起作用。我可以通过使用xRebel (分析工具)或用非常慢的语句交换SELECT 1来确认原始SQL正在运行,而不是轻量级的ping。

有人知道为什么,或者怎么解决这个问题吗?

从我的myBatisMapperConfig.xml拷贝

代码语言:javascript
复制
<environments default="dev">
    <environment id="dev">
        <transactionManager type="JDBC" />
        <dataSource type="POOLED">
            <property name="driver" value="com.mysql.jdbc.Driver" />
            <property name="url" value="${db.dev.url}" />
            <property name="username" value="${db.dev.username}" />
            <property name="password" value="${db.dev.password}" />
            <property name="poolPingQuery" value="/* ping */ SELECT 1" />
            <property name="poolPingEnabled" value="true" />
            <property name="poolMaximumActiveConnections" value="50" />
            <property name="poolMaximumIdleConnections" value="5" />
            <property name="poolMaximumCheckoutTime" value="10000" />
        </dataSource>
    </environment>

解释轻量级ping的参考资料:

在myBatis中解释连接的引用(搜索"poolPingQuery"):

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-07 14:52:17

您可能已经解决了这个问题,但也需要设置poolPingConnectionsNotUsedFor。默认值为0,即使使用poolPingEnabled,它也不会在没有时间的情况下进行ping (在millis中)。

您所链接的引用提到了它,但并不明显的是,默认值0意味着它不会执行pings :/

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30160871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档