java.net.ConnectException : Connection refused (Connection refused)

标签 java amazon-web-services jdbc amazon-rds

我有一个AWS Elastic Beanstalk实例 Tomcat运行已安装的 Java RESTful 服务。

enter image description here

然后我还有一个MySQL数据库实例设置于 AWS-RDS .

enter image description here

我有以下 Activity 安全组,允许所有入站和出站流量。

enter image description here

我能够使用 MySQL Workbench 连接到数据库:

enter image description here

这表明数据库没问题。所以我认为问题出在我的 Java 代码上。

阅读后this ,我在 Hibernate 配置中设置了以下数据源(注释编码适用于 OpenShift 服务器)。

    @Bean
    public DataSource dataSource() {
        // Openshift
//      String host = System.getenv("OPENSHIFT_MYSQL_DB_HOST");
//      String port = System.getenv("OPENSHIFT_MYSQL_DB_PORT");
//      String username = System.getenv("OPENSHIFT_MYSQL_DB_USERNAME");
//      String password = System.getenv("OPENSHIFT_MYSQL_DB_PASSWORD");

        // AWS
        String host = System.getenv("RDS_HOSTNAME");
        String port = System.getenv("RDS_PORT");
        String username = System.getenv("RDS_USERNAME");
        String password = System.getenv("RDS_PASSWORD");
        String dbname = System.getenv("RDS_DB_NAME");

        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName(environment.getRequiredProperty("jdbc.driverClassName")); // jdbc.driverClassName=com.mysql.jdbc.Driver
        if (host == null) {
            dataSource.setUrl(environment.getRequiredProperty("jdbc.url")); 
            dataSource.setUsername(environment.getRequiredProperty("jdbc.username"));
            dataSource.setPassword(environment.getRequiredProperty("jdbc.password"));
        } else {
            //dataSource.setUrl("jdbc:mysql://" + host + ":" + port + "/");
            // Openshift
            //dataSource.setUrl("jdbc:mysql://" + host + ":" + port + "/" + environment.getRequiredProperty("jdbc.dbname"));
            // AWS
            dataSource.setUrl("jdbc:mysql://" + host + ":" + port + "/" + dbname);
            dataSource.setUsername(username);
            dataSource.setPassword(password);
            System.out.println("jdbc:mysql://" + host + ":" + port + "/" + dbname+", username: "+username+", password: "+password);
        }

        return dataSource;
    }

但是,当我尝试访问 RESTful 服务时,我得到以下信息:

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.transaction.CannotCreateTransactionException: Could not open JPA EntityManager for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:982)
org.springframework.transaction.CannotCreateTransactionException: Could not open JPA EntityManager for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection
    org.springframework.orm.jpa.JpaTransactionManager.doBegin(JpaTransactionManager.java:431)
org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection
com.mysql.jdbc.exceptions.jdbc4.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.
java.net.ConnectException: Connection refused (Connection refused)

最佳答案

解决方案:

需要使用System.getProperty而不是System.getenv

    String host = System.getProperty("RDS_HOSTNAME");
    String port = System.getProperty("RDS_PORT");
    String username = System.getProperty("RDS_USERNAME");
    String password = System.getProperty("RDS_PASSWORD");
    String dbname = System.getProperty("RDS_DB_NAME");

Java 服务现在连接到数据库。

关于java.net.ConnectException : Connection refused (Connection refused),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42384751/

相关文章:

java - 我们可以更改 JVM 线程调度程序吗?

java - 无法从类 io.netty.channel.sctp.nio.NioSctpChannel 创建 channel

java - 将 flash 文件合并为 Web 应用程序中的 url 的最佳方法是什么?

java - 如何正确关闭资源

java - 在 JDBC 到 mysql 连接中指定 TCP 协议(protocol)

amazon-web-services - AWS Kinesis Firehose - 按纪元以外的时间戳进行动态分区

amazon-web-services - 自动缩放组设置为 0 个实例时的 AWS Codedeploy

amazon-web-services - Amazon Web Services - 在 CloudFormation 中用自己的名称标记 S3 存储桶

java - HSQLDB 神秘异常消息 : "feature not supported"

java - Hibernate 错误 SQLGrammarException (MySQL)