mysql5以后,如果连接长时间不活动 (34,247,052 ms≈ 9.5 小时),mysql数据库会断开连接,这会导致异常:MySQLNonTransientConnectionException: No operations allowed after connection closed,以下选项将会告诉连接池,主动检查连接可用性,避免这个异常发生。
validationQuery:检查连接可用性的语句,一般来说mysql设置成SELECT 1, oracle设置成select 1 from dual, sql server设置成SELECT 1 ,在检查连接可用性时,连接池会执行这些语句,如果返回结果不为空,则说明连接可用。
validationQueryTimeout:执行连接检查语句时的超时时间。
上面两个选项告诉连接池如何检查连接有效性,下面几个选项告诉连接池在何时检查连接有效性
因为项目需求,不能在程序中使用数据库明文密码
所以采用数据库连接池的方式访问数据库,数据库信息配置到Tomcat里
JDK1.8
apache-tomcat-7.0.76
Springboot 2.1.5.RELEASE
(环境是版本比较老,需求所致)
先把mysql-connector-java-8.0.16.jar 导入Tomcat 的lib里
1.1 content.xml配置
Context标签下添加:
<Resource auth="Container" driverClassName="com.mysql.jdbc.Driver" maxActive="100" maxIdle="10" maxWait="10000" name="jdbc/ZMKTDS" password="XXX" type="javax.sql.DataSource" url="XXX" username="XXX" />
url、username 、password 自己不全即可
1.2 web.xml配置
web-app标签下添加
<resource-ref> <description>mysqlpool</description> <res-ref-name>jdbc/ZMKTDS</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> </resource-ref>
上述配置只需改用户名密码
1.3 测试连接池配置是否成功
在tomcat/webapp/example下放一个test.jsp,
然后启动Tomcat,访问localhost:8080/example/test.jsp
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <sql:query var="rs" dataSource="jdbc/ZMKTDS"> select id,你的字段 from 你的表 </sql:query> <html> <head> <title>DB Test</title> </head> <body> <h2>Results</h2> <c:forEach var="row" items="${rs.rows}"> Foo ${row.id}<br/> Bar ${row.你的字段名}<br/> </c:forEach> </body> </html>
因为我们用SpringBoot框架,就不用自己写工具连Tomcat连接池了
2.1 整合JNDI
2.2 创建DataSourceConfig
package cn.pconline.config; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.jndi.JndiLocatorSupport; import org.springframework.jndi.JndiObjectFactoryBean; import javax.naming.NamingException; import javax.sql.DataSource; @Configuration @EnableConfigurationProperties public class DataSourceConfig { @Value("${spring.datasource.jndi-name}") private String jndiName; @Bean("dataSource") @Primary public DataSource primaryDataSource() throws NamingException { JndiObjectFactoryBean bean = new JndiObjectFactoryBean(); bean.setJndiName(JndiLocatorSupport.CONTAINER_PREFIX + jndiName); bean.setProxyInterface(DataSource.class); bean.setLookupOnStartup(false); bean.afterPropertiesSet(); return (DataSource) bean.getObject(); } }
这样Spring项目就可以通过Tomcat连接池访问了
到此这篇关于SpringBoot整合Tomcat连接池的使用的文章就介绍到这了,更多相关SpringBoot Tomcat连接池内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:本站发布的内容(图片、视频和文字)以原创、来自本网站内容采集于网络互联网转载等其它媒体和分享为主,内容观点不代表本网站立场,如侵犯了原作者的版权,请告知一经查实,将立刻删除涉嫌侵权内容,联系我们QQ:712375056,同时欢迎投稿传递力量。
Copyright © 2009-2022 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 特网科技 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 百度云 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站