如何使用MongoMK在JackRabbit Oak中创建存储库实例

时间:2014-10-09 19:06:30

标签: mongodb jackrabbit

我正在尝试使用"创建一个Oak的JCR存储库来存储内容。 MongoDB上的Apache Oak"。

(我绝对不知道) 这就是我们正在做的事情。

MongoClient connection = new MongoClient("127.0.0.1", 27017);
                    DB db = connection.getDB("test");
                    MongoMK.Builder m = new MongoMK.Builder();
                    MongoMK kernel = m.setMongoDB(db).open();
                    Repository repo = new Jcr().createRepository();
                    session = repo.login(); // Error javax.jcr.NoSuchWorkspaceException

试图链接"存储库"到" MongoMK" - 这似乎是一场噩梦。

我尝试过做

 Repository repo = new Jcr(kernel).createRepository(); //Error

我找到了类似的东西@ [How to create repository instance in JackRabbit Oak using MicroKernel,但也没有帮助。

我的问题是,无论如何都要连接MongMK - Repository ??

P.S - 尝试使用" NodeStore"。

1 个答案:

答案 0 :(得分:2)

是的,这没有很好的记录。以下应该有效:

import javax.jcr.Node;
import javax.jcr.Repository;
import javax.jcr.Session;
import org.apache.jackrabbit.oak.Oak;
import org.apache.jackrabbit.oak.plugins.document.DocumentMK;
import org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore;
import org.apache.jackrabbit.oak.spi.security.OpenSecurityProvider;
import com.mongodb.DB;
import com.mongodb.MongoClient;

public class Test {
    public static void main(String... args) throws Exception {
        DB db = new MongoClient("127.0.0.1", 27017).getDB("test2");
        DocumentNodeStore ns = new DocumentMK.Builder().
                setMongoDB(db).getNodeStore();
        Repository repo = new Jcr(new Oak(ns))
                .with(new OpenSecurityProvider())
                .createRepository();
        Session session = repo.login();
        Node root = session.getRootNode();
        if (root.hasNode("hello")) {
            Node hello = root.getNode("hello");
            long count = hello.getProperty("count").getLong();
            hello.setProperty("count", count + 1);
            System.out.println("found the hello node, count = " + count);
        } else {
            System.out.println("creating the hello node");
            root.addNode("hello").setProperty("count", 1);
        }
        session.save();
        session.logout();
        ns.dispose();
    }
}

现在也是documented