无法从Apache Camel MongoDb组件检索多个对象

时间:2018-11-25 12:52:50

标签: mongodb apache-camel

我有以下代码摘录:

@Component
public class RetrievalAllFromDbRoute extends RouteBuilder{
    public void configure() throws Exception {
        this.from("direct:allObjects").routeId("retrieveAllObjectsFromDB")
                .setHeader("CamelMongoDbBatchSize", constant(50))
                .process(new Processor() {
                    public void process(Exchange exchange) throws Exception {
                        DBObject fieldFilter = BasicDBObjectBuilder.start().add("_id", 1).get();
                        exchange.getMessage().setHeader(MongoDbConstants.FIELDS_FILTER, fieldFilter);
                    }
                })
                .to("mongodb:mongoClient?database="+mongoDbName +"&collection=myObjectCollection&operation=findAll&outputType=DBCursor")
                .split(body())
                .streaming()
                .process(new Processor() {
                    public void process(Exchange exchange) throws Exception {
                        JsonNode idNode = UtilMethods.convertStringToJson(exchange.getMessage().getBody().toString());
                        exchange.getMessage().setBody(idNode.get("_id").asText());
                        System.out.println("\n Extracted id["+exchange.getMessage().getBody().toString()+"] from db \n");
                    }
                });
    }
}

但是我只得到一个输出。 在第一个进程中设置一个断点并查询db会发现数据库中有300多个对象,所以我不明白为什么我只得到1个对象。

编辑
我的Maven POM依赖项:

<dependency>
    <groupId>org.apache.camel</groupId>
    <artifactId>camel-mongodb</artifactId>
    <version>2.22.0</version>
</dependency>

使用MongoDB 3.6数据库

0 个答案:

没有答案