【问题标题】:Kafka JDBC sink connector - USE statement is not supported to switch between databasesKafka JDBC sink 连接器 - 不支持 USE 语句在数据库之间切换
【发布时间】:2022-01-27 03:50:00
【问题描述】:

我正在使用 Kafka JDBC 接收器连接器将数据接收到 Azure SQL 服务器。我已经用一个数据库测试了连接器,它工作正常,但是当我添加更多数据库时,我开始看到以下错误:

不支持使用USE语句在数据库之间切换。使用新连接连接到不同的数据库。

配置:

    tasks.max: 1
    topics: topic_name
    connection.url: jdbc:sqlserver://server:port;database=dbname;user=dbuser
    connection.user: dbuser
    connection.password: dbpass
    transforms: unwrap
    transforms.unwrap.type: io.debezium.transforms.ExtractNewRecordState
    transforms.unwrap.drop.tombstones: false
    auto.create: true
    value.converter: org.apache.kafka.connect.json.JsonConverter
    value.converter.schemas.enable: true
    insert.mode: upsert
    delete.enabled: true
    pk.mode: record_key

堆栈:

2020-12-10 11:56:36,990 ERROR WorkerSinkTask{id=NAME-sqlserver-jdbc-sink-0} Task threw an uncaught and unrecoverable exception. Task is being killed and will not recover until manually restarted. Error: java.sql.SQLException: com.microsoft.sqlserver.jdbc.SQLServerException: USE statement is not supported to switch between databases. Use a new connection to connect to a different database.
 (org.apache.kafka.connect.runtime.WorkerSinkTask) [task-thread-NAME-sqlserver-jdbc-sink-0]
org.apache.kafka.connect.errors.ConnectException: java.sql.SQLException: com.microsoft.sqlserver.jdbc.SQLServerException: USE statement is not supported to switch between databases. Use a new connection to connect to a different database.

        at io.confluent.connect.jdbc.sink.JdbcSinkTask.put(JdbcSinkTask.java:87)
        at org.apache.kafka.connect.runtime.WorkerSinkTask.deliverMessages(WorkerSinkTask.java:560)
        at org.apache.kafka.connect.runtime.WorkerSinkTask.poll(WorkerSinkTask.java:323)
        at org.apache.kafka.connect.runtime.WorkerSinkTask.iteration(WorkerSinkTask.java:226)
        at org.apache.kafka.connect.runtime.WorkerSinkTask.execute(WorkerSinkTask.java:198)
        at org.apache.kafka.connect.runtime.WorkerTask.doRun(WorkerTask.java:185)
        at org.apache.kafka.connect.runtime.WorkerTask.run(WorkerTask.java:235)
        at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
        at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
        at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
        at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
        at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: java.sql.SQLException: com.microsoft.sqlserver.jdbc.SQLServerException: USE statement is not supported to switch between databases. Use a new connection to connect to a different database.

【问题讨论】:

  • 不清楚您所说的“添加更多数据库”是什么意思。您是在连接器配置中执行此操作的吗?
  • 谢谢,@OneCricketeer 一开始我认为问题是由于数据库服务器中有多个数据库,但结果发现主题名称中有 prefix.dbo.table_name。而不仅仅是 table_name。我已经在我的答案中发布了详细信息。
  • 我要说的是——在数据库服务器中有多个模式是标准用例,所以这不是问题

标签: sql-server jdbc apache-kafka


【解决方案1】:

我已经确定了问题,一开始我认为问题是由于数据库服务器中有多个数据库,但结果发现主题名称中有prefix.dbo.table_name。而不仅仅是table_name。 因此,连接器将prefix.dbo 检测为另一个数据库。

解决方法是使用transform dropPrefix。

例如,要将主题hello.dbo.table1hello.dbo.table2table1table2 的数据保存到数据库中,请使用以下配置:

    tasks.max: 1
    topics: hello.dbo.table1, hello.dbo.table2
    connection.url: jdbc:sqlserver://server:port;database=dbname;user=dbuser
    connection.user: dbuser
    connection.password: dbpass
    transforms: dropPrefix,unwrap
    transforms.dropPrefix.type: org.apache.kafka.connect.transforms.RegexRouter
    transforms.dropPrefix.regex: hello\.dbo\.(.*)
    transforms.dropPrefix.replacement: $1
    transforms.unwrap.type: io.debezium.transforms.ExtractNewRecordState
    transforms.unwrap.drop.tombstones: false
    auto.create: true
    value.converter: org.apache.kafka.connect.json.JsonConverter
    value.converter.schemas.enable: true
    insert.mode: upsert
    delete.enabled: true
    pk.mode: record_key

【讨论】:

    【解决方案2】:

    如果它不能作为单个连接器工作,那么您需要为每个数据库创建一个连接器。

    【讨论】:

    • 每个数据库一个连接器。该示例只是将数据从主题下沉到单个数据库。
    • 这与您在问题中所说的相矛盾:“当我添加更多数据库时”。请澄清,并可能在您的问题中包含引发您看到的错误的 actual Sink 连接器配置。
    • 抱歉不清楚。我的意思是向数据库服务器添加更多数据库,而不是在连接器中。我已经确定了这个问题,它与具有prefix.dbo.tablename 的主题名称有关,连接器将其视为另一个数据库。 table.name.format 工作正常,但是当我只有一个主题时。这里提出了一个问题:github.com/confluentinc/kafka-connect-jdbc/issues/731 支持表前缀,这将是理想的,但看起来它仍然是开放的。
    猜你喜欢
    • 2012-12-07
    • 1970-01-01
    • 1970-01-01
    • 2020-04-04
    • 2020-07-31
    • 2019-06-22
    • 2019-09-18
    • 2019-06-04
    • 2019-06-15
    相关资源
    最近更新 更多