1

场景:我已经坚持了很长时间,我认为解决方案可能很容易,但我看不到它,这就是场景:

cURL POST to http://localhost:8080/my_imports (raw JSON data on body)
 ->
   MyImportsCustomHandler (extends ThreadedHttpRequestHandler [Validations]
    ->
      MyObjectProcessor (extends Processor) [JSON deserialize and data massage]
       ->
         MyFirstDocumentProcessor (extends DocumentProcessor) [Set some fields and save]

问题是执行永远不会到达MyFirstDocumentProcessor,可能是因为请求不是从document_api端点开始的(故意)。没有抛出错误,只是处理路线永远不会到达文档处理器链,我认为应该是因为MyObjectProcessor我正在做:

DocumentType type = 
localDocHandler.getDocumentTypeManager().getDocumentType("my_doc");
DocumentId id = new DocumentId("id:default:my_doc::2");
Document document = new Document(type, id);
DocumentPut docPut = new DocumentPut(document);

Processing proc = com.yahoo.docproc.Processing.of(docPut);

我从这里得到了这个想法:https ://github.com/vespa-engine/vespa/blob/master/docproc/src/test/java/com/yahoo/docproc/util/SplitterJoinerTestCase.java 但在那个测试中我看到了这条线splitter.process(p);,我无法找到在处理器内工作的合适替代品,在这种情况下,我只有Request,ExecutionDocumentProcessingHandler

我希望精通 Vespa con 的人对此有所了解,这只是我无法桥接的处理链上的最后一跳:|

4

1 回答 1

0

要从 Java 代码编写文档,您需要使用文档访问 API: http ://docs.vespa.ai/documentation/document-api-guide.html#document-access

一个可行的解决方案在https://github.com/vespa-engine/sample-apps/pull/44

于 2018-05-23T08:45:03.923 回答