java - 来自 servlet java.lang.RuntimeException : Driver org. hsqldb.jdbc.JDBCDriver 的未捕获异常声称不接受 jdbcUrl、jdbc:mysql:///iworks_db

标签 java maven google-app-engine google-cloud-sql

我正在开发一个 Java Google App Engine 应用程序,当我部署我的应用程序并在我的浏览器上打开它时,出现了上述错误。 iworks_db 是我的数据库的名称,由于某种原因我的应用程序无法连接到它。我正在使用此处找到的指南:https://cloud.google.com/sql/docs/mysql/connect-app-engine .

我的 createConnectionPool 方法:

private DataSource createConnectionPool() {
    HikariConfig config = new HikariConfig();

    config.setJdbcUrl(String.format("jdbc:mysql:///%s", DB_NAME));
    config.setUsername(DB_USER); 
    config.setPassword(DB_PASS); 
    config.setDriverClassName("org.hsqldb.jdbc.JDBCDriver");// This line does NOT exist on the guide
                                                            // I added it because I was getting "failed 
                                                            // to get driver instance" error

    config.addDataSourceProperty("socketFactory", "com.google.cloud.sql.mysql.SocketFactory");
    config.addDataSourceProperty("cloudSqlInstance", CLOUD_SQL_CONNECTION_NAME);
    config.addDataSourceProperty("useSSL", "false");

    config.setMaximumPoolSize(5);

    config.setMinimumIdle(5);

    config.setConnectionTimeout(10000); // 10 seconds

    config.setIdleTimeout(600000); // 10 minutes

    config.setMaxLifetime(1800000); // 30 minutes

    DataSource pool = new HikariDataSource(config);

    return pool;
  }

我的 pom.xml 文件中的依赖项:

    <!-- Compile/runtime dependencies -->
    <dependency>
      <groupId>com.google.appengine</groupId>
      <artifactId>appengine-api-1.0-sdk</artifactId>
      <version>1.9.59</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
      <type>jar</type>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <dependency>
        <groupId>com.zaxxer</groupId>
        <artifactId>HikariCP</artifactId>
        <version>3.3.1</version>
    </dependency>
    <dependency>
        <groupId>org.hsqldb</groupId>
        <artifactId>hsqldb</artifactId>
        <version>2.3.2</version>
    </dependency>

如有任何帮助,我们将不胜感激!

最佳答案

您的 URL 是一个 mysql url,而您的驱动程序是 HyperSQL 数据库 (hsqldb)。这就是您获得关于 Not Acceptable jdbcUrl 的异常的原因。

您的数据库是 Google Cloud mysql,我相信是这种情况,因为您的其余代码使用 mysql 工厂 (com.google.cloud.sql.mysql.SocketFactory),然后将驱动程序类名称更改为以下内容:

 config.setDriverClassName("com.mysql.jdbc.GoogleDriver");

同时将 hsldb maven 依赖替换为

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.18</version>
</dependency>
<dependency>
    <groupId>com.google.cloud.sql</groupId>
    <artifactId>mysql-socket-factory-connector-j-8</artifactId>
    <version>1.0.14</version>
 </dependency>

com.google.cloud.sql.mysql.SocketFactorymysql-socket-factory-connector-j-8 maven Artifact 中提供。

更新:

您也可以尝试完全不使用 DriverClassName。

尝试添加上述两个依赖项并删除 setDriverClassName 行。

关于java - 来自 servlet java.lang.RuntimeException : Driver org. hsqldb.jdbc.JDBCDriver 的未捕获异常声称不接受 jdbcUrl、jdbc:mysql:///iworks_db,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58715635/

相关文章:

java - Java 中的工作线程

java - 将 SVG 文档嵌入到 SVG 文档中,但保持可访问性

java - pom.xml 中的错误

java - Google Apps Marketplace JAR 和 GAE

python - 如何让 Google App Engine 有一个从数据库下载内容的下载链接?

java - Java中的rfind(来自python)相当于什么?

java - 如何为 'wide and deep' 模型创建一个 tensorflow 服务客户端?

android - 无法使用gradle build dystem将生成的.aar文件上传到android studio中的本地Maven存储库

java - 找不到符号 - Spring Boot Maven 同级作为依赖项

java - 用 Java 编写的 Google Appengine 应用程序可以访问 Python+Numpy+Scipy?