顶点 JDBC NoSuchMethodError 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
Vertx JDBC NoSuchMethodError 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
我正在尝试将 vertx JDBC 与 MS SQL 服务器一起使用。
我得到以下堆栈跟踪:
Exception in thread "vertx-jdbc-service-get-connection-thread" Exception in thread "vertx-jdbc-service-get-connection-thread" java.lang.NoSuchMethodError: 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
at io.agroal.pool.ConnectionPool.wrapperFromTransaction(ConnectionPool.java:162)
at io.agroal.pool.ConnectionPool.getConnection(ConnectionPool.java:129)
at io.agroal.pool.DataSource.getConnection(DataSource.java:61)
at io.vertx.ext.jdbc.impl.JDBCClientImpl.lambda$null(JDBCClientImpl.java:232)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
at java.base/java.lang.Thread.run(Thread.java:831)
java.lang.NoSuchMethodError: 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
at io.agroal.pool.ConnectionPool.wrapperFromTransaction(ConnectionPool.java:162)
at io.agroal.pool.ConnectionPool.getConnection(ConnectionPool.java:129)
at io.agroal.pool.DataSource.getConnection(DataSource.java:61)
at io.vertx.ext.jdbc.impl.JDBCClientImpl.lambda$null(JDBCClientImpl.java:232)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
at java.base/java.lang.Thread.run(Thread.java:831)
我的一部分 build.gradle
:
implementation platform("io.vertx:vertx-stack-depchain:4.2.1")
implementation "io.vertx:vertx-core"
implementation 'io.vertx:vertx-jdbc-client:4.2.1'
implementation "io.vertx:vertx-lang-groovy"
implementation 'io.agroal:agroal-api:1.13'
implementation 'io.agroal:agroal-pool:1.13'
implementation "com.microsoft.sqlserver:mssql-jdbc:9.4.0.jre16"
我试过选择其他版本,但总是出现同样的错误。我尝试寻找库函数,但我无法使用 getConnection()
方法找到 TransactionIntegration
的 any version。
我的代码:
import io.vertx.core.AbstractVerticle;
import io.vertx.core.*;
import io.vertx.jdbcclient.JDBCConnectOptions;
import io.vertx.jdbcclient.JDBCPool;
import io.vertx.sqlclient.*;
public class MainVerticle extends AbstractVerticle {
@Override
public void start(Promise<Void> startPromise) throws Exception {
JDBCPool pool = JDBCPool.pool(
vertx,
new JDBCConnectOptions()
.setJdbcUrl("jdbc:sqlserver://some_ip;databaseName=mydatabase")
.setUser("user")
.setPassword("password"),
new PoolOptions().setMaxSize(16)
);
pool
.query("SELECT * FROM test")
.execute()
.onFailure(e -> {
e.printStackTrace();
})
}
}
当前的 4.2.1 版本似乎依赖于 agroal 1.12。
鉴于你得到的是 NoSuchMethodError
我认为这可能与编译的 jar 是针对 1.12 的事实有关,但你 运行 针对的是旧版本,也许1.0 或 1.1。查看 github 您可以找到与这些版本匹配的跟踪。
尝试升级到 1.12,应该可以解决您的错误。
显然,gradle 只是被窃听了。
我按照 Paulo Lopes 的建议将 agroal 版本更改为 1.12。但是,这并没有解决问题。
我不知道究竟是什么解决了它,但我将准确列出我所做的事情:
- 删除两个农业依赖项
- 插入农业-api
- 去除农业-api
- 插入农业-api
- 正在插入 agroal-pool
我没有检查,是否需要使用agroal 1.12,或者具体是什么步骤解决的。而且我不打算尝试,我很高兴,它终于成功了。
我正在尝试将 vertx JDBC 与 MS SQL 服务器一起使用。
我得到以下堆栈跟踪:
Exception in thread "vertx-jdbc-service-get-connection-thread" Exception in thread "vertx-jdbc-service-get-connection-thread" java.lang.NoSuchMethodError: 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
at io.agroal.pool.ConnectionPool.wrapperFromTransaction(ConnectionPool.java:162)
at io.agroal.pool.ConnectionPool.getConnection(ConnectionPool.java:129)
at io.agroal.pool.DataSource.getConnection(DataSource.java:61)
at io.vertx.ext.jdbc.impl.JDBCClientImpl.lambda$null(JDBCClientImpl.java:232)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
at java.base/java.lang.Thread.run(Thread.java:831)
java.lang.NoSuchMethodError: 'java.sql.Connection io.agroal.api.transaction.TransactionIntegration.getConnection()'
at io.agroal.pool.ConnectionPool.wrapperFromTransaction(ConnectionPool.java:162)
at io.agroal.pool.ConnectionPool.getConnection(ConnectionPool.java:129)
at io.agroal.pool.DataSource.getConnection(DataSource.java:61)
at io.vertx.ext.jdbc.impl.JDBCClientImpl.lambda$null(JDBCClientImpl.java:232)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
at java.base/java.lang.Thread.run(Thread.java:831)
我的一部分 build.gradle
:
implementation platform("io.vertx:vertx-stack-depchain:4.2.1")
implementation "io.vertx:vertx-core"
implementation 'io.vertx:vertx-jdbc-client:4.2.1'
implementation "io.vertx:vertx-lang-groovy"
implementation 'io.agroal:agroal-api:1.13'
implementation 'io.agroal:agroal-pool:1.13'
implementation "com.microsoft.sqlserver:mssql-jdbc:9.4.0.jre16"
我试过选择其他版本,但总是出现同样的错误。我尝试寻找库函数,但我无法使用 getConnection()
方法找到 TransactionIntegration
的 any version。
我的代码:
import io.vertx.core.AbstractVerticle;
import io.vertx.core.*;
import io.vertx.jdbcclient.JDBCConnectOptions;
import io.vertx.jdbcclient.JDBCPool;
import io.vertx.sqlclient.*;
public class MainVerticle extends AbstractVerticle {
@Override
public void start(Promise<Void> startPromise) throws Exception {
JDBCPool pool = JDBCPool.pool(
vertx,
new JDBCConnectOptions()
.setJdbcUrl("jdbc:sqlserver://some_ip;databaseName=mydatabase")
.setUser("user")
.setPassword("password"),
new PoolOptions().setMaxSize(16)
);
pool
.query("SELECT * FROM test")
.execute()
.onFailure(e -> {
e.printStackTrace();
})
}
}
当前的 4.2.1 版本似乎依赖于 agroal 1.12。
鉴于你得到的是 NoSuchMethodError
我认为这可能与编译的 jar 是针对 1.12 的事实有关,但你 运行 针对的是旧版本,也许1.0 或 1.1。查看 github 您可以找到与这些版本匹配的跟踪。
尝试升级到 1.12,应该可以解决您的错误。
显然,gradle 只是被窃听了。
我按照 Paulo Lopes 的建议将 agroal 版本更改为 1.12。但是,这并没有解决问题。
我不知道究竟是什么解决了它,但我将准确列出我所做的事情:
- 删除两个农业依赖项
- 插入农业-api
- 去除农业-api
- 插入农业-api
- 正在插入 agroal-pool
我没有检查,是否需要使用agroal 1.12,或者具体是什么步骤解决的。而且我不打算尝试,我很高兴,它终于成功了。