Извлечение данных из hsqldb sqoop о рабочих местах - PullRequest
0 голосов
/ 08 сентября 2018

Мне нужно получить данные о заданиях sqoop из базы данных sqoop hsql. Поэтому я скачал последнюю версию коннектора hsqldb и подключился к базе данных sqoop:

public void extract() {
        try {
            conn = DriverManager.getConnection(connectionString, username, password);
            conn.setTransactionIsolation(2);
            conn.setAutoCommit(false);


           //.....
        } catch (SQLException e) {
           //...
        }
    }

Соединение с локальным sqoop hsqldb успешно, но оно перезаписывает metastore.db.properties и metastore.db.script.

Таким образом, после этого соединения sqoop выдает ошибку, когда пытается подключиться к локальной базе данных. Например, когда я хочу перечислить задания с sqoop, как: sqoop job --list я получаю это исключение:

2018-09-08 16:47:09,416 ERROR [main] tool.JobTool (JobTool.java:run(313)) - I/O error performing job operation: java.io.IOException: Exception creating SQL connection
    at org.apache.sqoop.metastore.GenericJobStorage.init(GenericJobStorage.java:241)
    at org.apache.sqoop.metastore.GenericJobStorage.open(GenericJobStorage.java:176)
    at org.apache.sqoop.tool.JobTool.run(JobTool.java:294)
    at org.apache.sqoop.Sqoop.run(Sqoop.java:146)
    at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:76)
    at org.apache.sqoop.Sqoop.runSqoop(Sqoop.java:182)
    at org.apache.sqoop.Sqoop.runTool(Sqoop.java:233)
    at org.apache.sqoop.Sqoop.runTool(Sqoop.java:242)
    at org.apache.sqoop.Sqoop.main(Sqoop.java:251)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.intellij.rt.execution.CommandLineWrapper.main(CommandLineWrapper.java:67)
Caused by: java.sql.SQLException: error in script file line: 1 Unexpected token UNIQUE, requires COLLATION in statement [SET DATABASE UNIQUE]
    at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
    at org.hsqldb.jdbc.jdbcConnection.<init>(Unknown Source)
    at org.hsqldb.jdbcDriver.getConnection(Unknown Source)
    at org.hsqldb.jdbcDriver.connect(Unknown Source)
    at java.sql.DriverManager.getConnection(DriverManager.java:664)
    at java.sql.DriverManager.getConnection(DriverManager.java:247)
    at org.apache.sqoop.manager.SqlManager.makeConnection(SqlManager.java:903)
    at org.apache.sqoop.manager.GenericJdbcManager.getConnection(GenericJdbcManager.java:59)
    at org.apache.sqoop.metastore.GenericJobStorage.init(GenericJobStorage.java:196)
    ... 13 more

Может кто-нибудь сказать мне, как подключиться к sqoop local hsqldb, не переписывая эти файлы, чтобы sqoop мог работать?

...