我在公司负责的一个小项目经常性的报下面的错误,是在Window下Tomcat发布的网站

异常:

A web application 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.
Web应用程序停止时未能取消注册,为了防止内存泄漏,JDBC驱动程序已被强制取消注册
在服务器保持运行的状态中,redeploy(重新部署)这个项目, 就出现该异常!

解决办法:

将整个项目stop之后再redeploy,就不会报该异常!
也可以参照下面的理解一下

从版本6.0.24开始,Tomcat提供了一个内存泄漏检测功能,当webapp的/ WEB-INF / lib中有一个兼容JDBC 4.0的驱动程序,它会在webapp启动时auto-register自己使用的ServiceLoaderAPI,但在webapp关闭期间没有自动注销。这个消息纯属非正式的,Tomcat已经相应地采取了内存泄漏预防行动。
可以采取以下措施:
忽略这些警告。 Tomcat正在做正确的工作。 实际的bug是在别人的代码中(所讨论的JDBC驱动程序),而不是在你的代码中。 Tomcat在正常工作,并等待JDBC驱动程序供应商解决问题,以便升级驱动程序。 另一方面,您不应该在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池。