Tomcat/Hibernate与MySql的连接失败,出现“通信链接失败”和“权限被拒绝”

问题描述:

我正在尝试使用Hibernate从tomcat webapp连接到本地主机上的MySql(= MariaDB)不断收到通信链路故障(下面附有完整的异常追踪)。Tomcat/Hibernate与MySql的连接失败,出现“通信链接失败”和“权限被拒绝”

我在另一台机器上有另一个数据库副本(可以称之为B),也可以使用第三台计算机进行开发(让我们称之为C)。

1)我没有问题从C连接到任何一个DB(A & B)。 2)在“A”上我没有任何问题连接到本地数据库(运行'mysql -u'命令)。我也没有问题做端口3306上的telnet到A或B,所以我假设两个DB都已启动并正在运行并可用于连接。

唯一的问题是,当我试图从生产tomcat(运行于A)连接到A或B数据库。我得到的错误:

com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure 

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 

从这个错误的类似案件,我看到大部分的错误是由于无效的用户名/密码凭证或非法的IP地址。我也尝试将ip更改为localhost,127.0.0.1和10.90.41.155(这是本机的实际ip)。没有什么帮助,也请记住,连接仅从A.具体tomcat安装失败

我也试过如下: 1)增加“-Djava.net.preferIPv4Stack = true”将卡特琳娜启动 2)试图连接到非法地址/端口 - 这改变了(如预期的)从“拒绝权限”到“无路由到主机”的最终错误。 3)添加以下内容到我的连接字符串中:“autoReconnect = true & useUnicode = true & createDatabaseIfNotExist = true & characterEncoding = utf-8” - 导致相同的错误(“尝试重新连接3次。放弃”+“权限被拒绝(连接失败)“ 4)试了两个数据库网址。为本地数据库尝试localhost,127.0.0.1和实际的IP。尝试既没有:附加的连接字符串

在 “3306” 是hibernate.cfg文件+全服务器跟踪异常的:

<?xml version="1.0" encoding="utf-8"?> 
<!DOCTYPE hibernate-configuration SYSTEM 
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> 

<hibernate-configuration> 
    <session-factory> 
    <property name="hibernate.dialect"> 
     org.hibernate.dialect.MySQLDialect 
    </property> 
    <property name="hibernate.connection.driver_class"> 
     com.mysql.jdbc.Driver 
    </property> 

    <!-- Assume test is the database name --> 
    <property name="hibernate.connection.url"> 
     jdbc:mysql://10.90.41.151/boonder 
    </property> 
    <property name="hibernate.connection.username"> 
     root 
    </property> 
    <property name="hibernate.connection.password"> 
    XXXXXXXXXX 
    </property> 

    <!-- List of XML mapping files  --> 
    <mapping resource="User.hbm.xml"/> 
    <mapping resource="Issue.hbm.xml"/> 
    <mapping resource="TraderIssue.hbm.xml"/> 

</session-factory> 
</hibernate-configuration> 

的例外是:

 type Exception report 

     message Handler dispatch failed; nested exception is java.lang.ExceptionInInitializerError 

     description The server encountered an internal error that prevented it from fulfilling this request. 

     exception 

     org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.ExceptionInInitializerError 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:982) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     java.lang.ExceptionInInitializerError 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:54) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:180) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:440) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment] 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:271) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:233) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 
      org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:51) 
      org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:94) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:242) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.handleTypes(MetadataBuildingProcess.java:352) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:111) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.build(MetadataBuildingProcess.java:83) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:418) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:87) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:691) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:726) 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:48) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:180) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:440) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     org.hibernate.exception.JDBCConnectionException: Error calling Driver#connect 
      org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:115) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator$1$1.convert(BasicConnectionCreator.java:101) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator.convertSqlException(BasicConnectionCreator.java:123) 
      org.hibernate.engine.jdbc.connections.internal.DriverConnectionCreator.makeConnection(DriverConnectionCreator.java:41) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator.createConnection(BasicConnectionCreator.java:58) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.addConnections(PooledConnections.java:123) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:42) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:20) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections$Builder.build(PooledConnections.java:161) 
    ... 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:691) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:726) 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:48) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:180) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:440) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure 

     The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 
      com.mysql.cj.jdbc.exceptions.SQLError.createCommunicationsException(SQLError.java:166) 
      com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:58) 
      com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:853) 
      com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:440) 
      com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241) 
      com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:221) 
      org.hibernate.engine.jdbc.connections.internal.DriverConnectionCreator.makeConnection(DriverConnectionCreator.java:38) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator.createConnection(BasicConnectionCreator.java:58) 

    ... 

    org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.handleTypes(MetadataBuildingProcess.java:352) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:111) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.build(MetadataBuildingProcess.java:83) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:418) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:87) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:691) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:726) 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:48) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:180) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:440) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     com.mysql.cj.core.exceptions.CJCommunicationsException: Communications link failure 

     The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 
      sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
      sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
      sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
      java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
      com.mysql.cj.core.exceptions.ExceptionFactory.createException(ExceptionFactory.java:54) 
      com.mysql.cj.core.exceptions.ExceptionFactory.createException(ExceptionFactory.java:93) 
      com.mysql.cj.core.exceptions.ExceptionFactory.createException(ExceptionFactory.java:133) 
      com.mysql.cj.core.exceptions.ExceptionFactory.createCommunicationsException(ExceptionFactory.java:149) 
      com.mysql.cj.mysqla.io.MysqlaSocketConnection.connect(MysqlaSocketConnection.java:83) 
      com.mysql.cj.mysqla.MysqlaSession.connect(MysqlaSession.java:204) 
      com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:975) 
      com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:843) 
      com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:440) 
      com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241) 
      com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:221) 
      org.hibernate.engine.jdbc.connections.internal.DriverConnectionCreator.makeConnection(DriverConnectionCreator.java:38) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator.createConnection(BasicConnectionCreator.java:58) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.addConnections(PooledConnections.java:123) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:42) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:20) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections$Builder.build(PooledConnections.java:161) 
      org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.buildPool(DriverManagerConnectionProviderImpl.java:109) 
      org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.configure(DriverManagerConnectionProviderImpl.java:72) 
      org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:94) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:242) 
    org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:51) 
      org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:94) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:242) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.handleTypes(MetadataBuildingProcess.java:352) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:111) 
      org.hibernate.boot.model.process.spi.MetadataBuildingProcess.build(MetadataBuildingProcess.java:83) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:418) 
      org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:87) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:691) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:726) 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:48) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:180) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:440) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     root cause 

     java.net.SocketException: Permission denied (connect failed) 
      java.net.PlainSocketImpl.socketConnect(Native Method) 
      java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) 
      java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) 
      java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) 
      java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) 
      java.net.Socket.connect(Socket.java:589) 
      com.mysql.cj.core.io.StandardSocketFactory.connect(StandardSocketFactory.java:202) 
      com.mysql.cj.mysqla.io.MysqlaSocketConnection.connect(MysqlaSocketConnection.java:57) 
      com.mysql.cj.mysqla.MysqlaSession.connect(MysqlaSession.java:204) 
      com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:975) 
      com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:843) 
      com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:440) 
      com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241) 
      com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:221) 
      org.hibernate.engine.jdbc.connections.internal.DriverConnectionCreator.makeConnection(DriverConnectionCreator.java:38) 
      org.hibernate.engine.jdbc.connections.internal.BasicConnectionCreator.createConnection(BasicConnectionCreator.java:58) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.addConnections(PooledConnections.java:123) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:42) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections.<init>(PooledConnections.java:20) 
      org.hibernate.engine.jdbc.connections.internal.PooledConnections$Builder.build(PooledConnections.java:161) 
      org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.buildPool(DriverManagerConnectionProviderImpl.java:109) 
      org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.configure(DriverManagerConnectionProviderImpl.java:72) 
      org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:94) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:242) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 
      org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.buildJdbcConnectionAccess(JdbcEnvironmentInitiator.java:145) 
      org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:66) 
      org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:35) 
      org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.initiateService(StandardServiceRegistryImpl.java:88) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:259) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:233) 
      org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) 

... 
    org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:87) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:691) 
      org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:726) 
      com.aldondy.boonder.bl.DataSingleton.<init>(DataSingleton.java:48) 
      com.aldondy.boonder.bl.DataSingleton.instance(DataSingleton.java:74) 
      com.aldondy.boonder.web.controllers.LoginCtrl.loginInner(LoginCtrl.java:62) 
      com.aldondy.boonder.web.controllers.LoginCtrl.login(LoginCtrl.java:41) 
      sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
      sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
      sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
      java.lang.reflect.Method.invoke(Method.java:498) 
      org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:428) 
      org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) 
      org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) 
      org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
      org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:650) 
      org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
      javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
      com.aldondy.boonder.web.controllers.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:27) 
      org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
     note The full stack trace of the root cause is available in the Apache Tomcat/7.0.76 logs. 
+0

也有同样的问题,在centos 7.4.1708和tmocat 7.0.76 – jbu

我也只是跟踪了这个问题。我的症状与您的症状完全相同,我甚至尝试了您尝试的确切事物。总之,我的问题只发生,因为我在SELinux上使用了centos上的tomcat。

一些人帮我诊断使用下面的命令来看待安全事件,为什么一些动作没有permittted:

sudo ausearch -m avc 
sudo grep "tcp_socket" /var/log/audit/audit.log | audit2why // translates log into some human readable reasons why the audit record was generated 

我见过这样的条目:

type=AVC msg=audit(1507861264.561:64750): avc: denied { name_connect } for pid=1326 comm="java" dest=3306 scontext=system_u:system_r:tomcat_t:s0 tcontext=system_u:object_r:mysqld_port_t:s0 tclass=tcp_socket

Was caused by: Missing type enforcement (TE) allow rule.

You can use audit2allow to generate a loadable module to allow this access.

然后发现这篇文章关于tomcat和SELinux https://noobient.com/post/165972214381/selinux-woes-with-tomcat-on-centos-74

您可以运行以下命令来查看tomcat是否在tomcat_t security contex中运行吨。

$ps auxZ | grep tomcat 

对于真正确定我的错误是SELinux的,我禁用了SELinux

$ sestatus // shows: SELinux status:     enabled 
$ sudo vim /etc/selinux/config // set "SELINUX=disabled" 
$ sudo shutdown -r now 
$ sestatus // shows: SELinux status:     disabled 

重新启动我的机器,看到tomcat的是现在正在出站连接的目的。

太棒了,现在我至少知道为什么会发生这种情况。当然,如果你需要SELinux,禁用它并不是一个解决方案。另一个可能不是解决方案的解决方法是在不通过yum的情况下安装tomcat。 Yum将使用安全上下文来安装tomcat。

我认为现在的行动过程是修改安全上下文或管理tomcat的规则集,以允许它进行传出连接。

+0

谢谢jbu!这对我来说非常合适。这么长时间的这样的解脱......我按照你的建议关闭了SELinux,现在SQL工作正常。现在,我将开始挖掘SELinux配置,了解如何在不完全禁用它的情况下获得连接。如果您有任何更多提示或找到相关内容 - 请分享所需的额外步骤。 – Yoshi67

+0

你可以帮助我,并将我的答案标记为正确 – jbu

+0

哎呀对不起 - 我只是做了... – Yoshi67