CORB: неопределенная внешняя переменная fn:QName("","URI")

Я новичок в CORB, пытаюсь удалить документы с помощью кода Java, но получаю com.marklogic.xcc.exceptions.XQueryException: XDMP-EXTVAR: (err:XPDY0002) declare variable $URI as xs:string* external; -- Undefined external variable fn:QName("","URI")исключение.

Я использую CORB 2.5.0как зависимость от maven в моем проекте Java.

URIS_MODULE — это get-uri.xql.

      xquery version "1.0-ml";
let $uris := cts:uris()
return (count($uris), $uris)

ПРОЦЕСС-МОДУЛЬ — это transform-docs.xqy

      xquery version "1.0-ml";
declare variable $URI as xs:string* external;
xdmp:document-delete($URI)

вот код Java для выполнения модуля,

          Properties properties = new Properties();
    properties.setProperty(Options.XCC_CONNECTION_URI, "xcc://admin:admin-password@localhost:8061/test");
    properties.setProperty(Options.THREAD_COUNT, Integer.toString(8));
    properties.setProperty(Options.PROCESS_MODULE, "src/test/resources/transform-docs.xqy.xqy|ADHOC");
    properties.setProperty(Options.URIS_MODULE, "src/test/resources/get-uri.xqy|ADHOC");
    properties.setProperty(Options.MODULES_DATABASE, "8061-test-modules");

    Manager executor = new Manager();
    executor.init(properties);
    executor.run();

После выполнения приведенного выше кода я получаю это предупреждение, и код выполняется навсегда,

          Warning at char 9 in xsl:with-param/@select on line 106 column 123 of jobStatsToJson.xsl:
  FODC0002: I/O error reported by XML parser processing
  jar:file:/C:/Users/Shivling%20Bhandare/.m2/repository/com/marklogic/marklogic-corb/2.5.0/marklogic-corb-2.5.0.jar!/: no entry name specified
Warning at char 9 in xsl:with-param/@select on line 107 column 118 of jobStatsToJson.xsl:
  FODC0002: Document has been marked not available:
  jar:file:/C:/Users/Shivling%20Bhandare/.m2/repository/com/marklogic/marklogic-corb/2.5.0/marklogic-corb-2.5.0.jar!/jobStatsToJson.xsl

Обновить . Эта ошибка возникла при изменении версии CoRB, но теперь я получаю это исключение,

Последний код

              Properties properties = new Properties();
        properties.put(Options.PROCESS_MODULE, "src/test/resources/transform-docs.xqy");
        properties.put(Options.URIS_MODULE, "src/test/resources/get-uris.xqy");
        properties.put(Options.THREAD_COUNT, "20");
        properties.put(Options.MODULE_ROOT, "/");
        properties.put(Options.MODULES_DATABASE, "8067-TCOMP-modules");
        properties.put(Options.INSTALL, "1");
        properties.put(Options.XCC_DBNAME, "TCOMP");
        properties.put(Options.XCC_PORT, "8067");
        properties.put(Options.XCC_HOSTNAME, "localhost");
        properties.put(Options.XCC_USERNAME, "admin");
        properties.put(Options.XCC_PASSWORD, "admin");

        Manager manager = new Manager();
        manager.init(properties);
        manager.run();

Упомянутая выше ошибка исчезла, изменив версию CoRB, но теперь я получаю

      WARNING: Connection error count for ContentSource user=admin, cb=TCOMP [provider: address=localhost/127.0.0.1:8067, pool=1/64] is 1. Max limit is 3.
Sep 08, 2021 12:09:26 PM com.marklogic.developer.corb.DefaultContentSourcePool$SessionInvocationHandler invoke
WARNING: Submit request failed 1 times with ServerResponseException. Max Limit is 3. Retrying..
Sep 08, 2021 12:09:26 PM com.marklogic.developer.corb.DefaultContentSourcePool get
WARNING: Connection failed for ContentSource user=admin, cb=TCOMP [provider: address=localhost/127.0.0.1:8067, pool=1/64]. Waiting for 60 seconds before retry attempt 2

Любая помощь приветствуется.

2 ответа

Если вы хотите запустить задание CoRB, вам нужно использовать Managerучебный класс.

Обратитесь к этому интеграционному тесту для примера:https://github.com/marklogic-community/corb2/blob/master/src/test/java/com/marklogic/developer/corb/ManagerIT.java#L100

The ModuleExecutorclass используется для выполнения одного основного модуля.

И CoRB Manager, и ModuleExecutor настроены аналогичным образом с одинаковыми свойствами, поэтому ModuleExecutor пытался выполнить настроенный вами PROCESS-MODULE, и, поскольку для вашей внешней переменной $URIS нет значения по умолчанию, он выдает ошибку.

Спасибо, Мэдс Хансен. Если без вашего участия решить эту проблему было невозможно,

Полное решение,

Используемые версии Corb

              <dependency>
            <groupId>com.marklogic</groupId>
            <artifactId>marklogic-corb</artifactId>
            <version>2.4.0</version>
        </dependency>

Используется версия XCC

              <dependency>
            <groupId>com.marklogic</groupId>
            <artifactId>marklogic-xcc</artifactId>
            <version>10.0.6</version>
        </dependency>

Свойства и конфигурация менеджера

              Properties properties = new Properties();
        properties.put(Options.PROCESS_MODULE, "src/test/resources/transform-docs.xqy|ADHOC");
        properties.put(Options.URIS_MODULE, "src/test/resources/get-uris.xqy|ADHOC");
        properties.put(Options.THREAD_COUNT, "20");
        properties.put(Options.MODULE_ROOT, "/");
        properties.put(Options.MODULES_DATABASE, "8067-test-modules");
        properties.put(Options.INSTALL, "1");
        properties.put(Options.XCC_DBNAME, "test");
        properties.put(Options.XCC_PORT, "8067");
        properties.put(Options.XCC_HOSTNAME, "localhost");
        properties.put(Options.XCC_USERNAME, "admin");
        properties.put(Options.XCC_PASSWORD, "admin");

        Manager manager = new Manager();
        manager.init(properties);
        manager.run();
Другие вопросы по тегам