the JDBC Driver has been forcibly unregistered;tomcat总是memory leak问题 ,为了防止内存泄漏,jdbc驱动程序已强制取消注册
项目启动报错:
严重: The web application [/codeMarket] registered the JBDC driver [com.mysql.jdbc.Driver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
2012-2-9 17:43:12 org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc
严重: The web application [/codeMarket] registered the JBDC driver [oracle.jdbc.OracleDriver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
烦死人了,一开始以为是c3p0的问题,可是换了druid还是不行,后来就直接把报错信息贴网上搜索,发现是web应用程序注册了JBDC驱动程序。oracle.jdbc.driver.OracleDriver但是,当web应用程序停止时,未能注销它。为了防止内存泄漏,JDBC驱动程序被迫取消注册。这样就会导致无法获取数据库连接,
从版本6.0.24开始,Tomcat提供了一个内存泄漏检测功能,当webapp的/ WEB-INF / lib
中有一个兼容JDBC 4.0的驱动程序,它会在webapp启动时auto-register自己使用的ServiceLoader
API,但在webapp关闭期间没有自动注销。这个消息纯属非正式的,Tomcat已经相应地采取了内存泄漏预防行动。
可以采取以下措施:
忽略这些警告。 Tomcat正在做正确的工作。 实际的bug是在别人的代码中(所讨论的JDBC驱动程序),而不是在你的代码中。 Tomcat在正常工作,并等待JDBC驱动程序供应商解决问题,以便升级驱动程序
<!– Prevent memory leaks due to use of particular java/javax APIs–>
<!– <Listener className=”org.apache.catalina.core.JreMemoryLeakPreventionListener”/>;–>
另一方面,您不应该在webapp的/ WEB-INF / lib
中放置JDBC驱动程序,而只能在服务器的/ lib
中放置JDBC驱动程序。 如果你仍然保存在webapp的/ WEB-INF / lib
中,那么你应该使用ServletContextListener
手动注册和注销它。
降级到Tomcat 6.0.23或更低版本,这样你就不会被那些警告所困扰。但它会悄悄地泄漏内存。这些内存泄漏是Tomcat的OutOfMemoryError
问题背后的主要原因之一。
将JDBC驱动程序移动到Tomcat/lib
文件夹,并有一个连接池数据源来管理驱动程序。请注意,Tomcat的内置DBCP在关闭时不会正确注销驱动程序。另请参阅作为WONTFIX关闭的bug DBCP-322。您可以将DBCP替换为另一个更好的DBCP连接池。例如HikariCP,BoneCP,或Tomcat JDBC池。
解决方式比较粗暴,不知道会不会有其他的问题....
补充:
[tomcat启动报错]registered the JDBC driver [com.alibaba.druid.proxy.DruidDriver] but failed to unregister it when the web application was stopped
一个tomcat ,一个工程配置了多数据源,数据源id不能重复
另外:1.有的说 继承org.apache.commons.dbcp.BasicDataSource 重写close() ;然后用 BasicDataSourceExt 替换spring配置文件中的数据源bean的class
2.数据库表在mybatis表,与实体类的对应字段没有影射对,也是一个原因
3.本人终极原因,引入的第三方jar包,里面重写了jdbc加载驱动的类,Driver,并且全路径跟我的mysql-connect-java.jar包的Driver一样,项目启动之后,加载引入的第三方jar包Driver.class;导致我的数据库连接不上,解决方法百度搜索 “”Java相同全限定名的类加载顺序” 我修改jar包的名字, 保证先加载自己要用的的jar包的class先被加载
the JDBC Driver has been forcibly unregistered;tomcat总是memory leak问题 ,为了防止内存泄漏,jdbc驱动程序已强制取消注册相关推荐
- tomcat 启动时报错:To prevent a memory leak, the JDBC Driver has been forcibly unregistered
在启动tomcat时,报错: 五月 04, 2017 10:56:15 上午 org.apache.coyote.AbstractProtocol start 信息: Starting Protoco ...
- 【tomcat启动报错】To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
我在写一个服务管理系统的时候出现了tomcat启动报错的问题 Maven配置的tomcat插件 <plugin><groupId>org.apache.tomcat.maven ...
- 一次bug调试经验----To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
5-Feb-2019 11:03:11.635 严重 [RMI TCP Connection(2)-127.0.0.1] org.apache.catalina.core.StandardContex ...
- idea启动项目报错 --To prevent a memory leak, the JDBC Driver has been forcibly unregistered
网上说的种种方法我都试过,我感觉新项目没有不要改代码. 解决了一早上种种方法都排除用过,最后我下载了一个7.5的tomcat解决问题之前用的是8.5. 注意:换tomcat7.5之前我本身项目内部所有 ...
- Web应用程序停止时无法注销它。 为防止内存泄漏,JDBC驱动程序已被强制取消注册。
异常描述详情: 29-Mar-2022 12:32:27.230 警告 [localhost-startStop-2] org.apache.catalina.loader.WebappClassLo ...
- tomcat 启动报错 registered the JDBC driver [com.mysql.jdbc.Driver] but failed to unregister
在帮朋友改bug时出现下面错误: org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesJdbc The web applic ...
- tomcat 启动异常 The web application [ROOT] registered the JDBC driver [xxx] but failed to unregister it
tomcat启动的时候出现如下异常: 22-Feb-2021 20:25:30.697 严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina ...
- 严重: The web application [/] registered the JDBC driver [xxx.xxx.xxx] but failed to unregister ...
问题描述: Tomcat 服务器启动报异常提示数据库驱动不能被注册,当应用被停止时.为了防止内存泄漏,已强制注销JDBC驱动程序.折腾了2小时最后LZ定位问题是出于开发环境与服务器环境JDK版本不一致 ...
- tomcat启动报错,找不到相应的 queue,从而引发内存泄漏
tomcat启动报错,无法创建 bean listenerStatusChangeDealHandler, no queue 'STOCK.NOTIFY_CHANGE.INTER.CACHE.QUEU ...
- tomcat启动报错,找不到对应的 queue,从而引发内存泄漏
tomcat启动报错,无法创建 bean listenerStatusChangeDealHandler, no queue 'STOCK.NOTIFY_CHANGE.INTER.CACHE.QUEU ...
最新文章
- java的listroots_list(), listFiles(), listRoots() in Java
- pandas重命名列名称、数据列名称重命名(Rename Column Names): rename、set_axis、df.columns
- 使用bash工具创建ssh key
- MATLAB快速拟合二组数据
- VUE3路由Router导航、模式
- python 获取pv_Python爬虫入门教程 40-100 博客园Python相关40W博客抓取 scrapy
- 怎么更好掌握Web前端技术?JS的跨域是怎么回事?
- CICD详解(十六)——Sonar报错:java.lang.IllegalStateException: Webapp did not start解决
- kali 32位 更换 xfce4 桌面
- html5实现直接下载文件
- c语言for循环延时函数作用,C语言循环语句实现单片机延时函数.pdf
- 如何简单抓取拼多多买家订单列表
- linux grub命令启动u盘启动,u盘启动出现grub应该怎么处理
- java日文_怎么用java编写个应用程序,让其输出日文表
- 稻盛和夫:人为什么要努力工作?
- UMLChina建模竞赛第3赛季第7轮:假烟假酒假朋友,假情假意假温柔
- python引入视频_django 实现简单的插入视频
- 加载大图片,内存溢出问题
- 运维 ---linux基础
- 天堂2服务器维护,天堂II-官方网站-腾讯游戏