Db4o客户端似乎没有从其他客户端获取提交事件

时间:2012-07-13 16:23:07

标签: java db4o

我有一个带有两个客户端的db4o服务器的系统。一个客户端在进程中托管,另一个是托管多个需要查询数据库的servlet的Web服务器。

在Web服务器的连接代码中,我已经注册了commit事件,并根据http://community.versant.com/documentation/reference/db4o-8.0/java/reference/Content/advanced_topics/callbacks/possible_usecases/committed_event_example.htm上的db4o文档的建议使用它来刷新对象:

    client = Db4oClientServer.openClient (context.getBean ("db4oClientConfiguration", ClientConfiguration.class),
        arg0.getServletContext ().getInitParameter ("databasehost"),
        Integer.parseInt (arg0.getServletContext ().getInitParameter ("databaseport")),
        arg0.getServletContext ().getInitParameter ("databaseuser"),
        arg0.getServletContext ().getInitParameter ("databasepassword"));

    System.out.println ("DB4O connection established");

    EventRegistry events = EventRegistryFactory.forObjectContainer (client);
    events.committed ().addListener (new EventListener4<CommitEventArgs> () {
        public void onEvent (Event4<CommitEventArgs> commitEvent, CommitEventArgs commitEventArgs)
        {
            for (Iterator4<?> it = commitEventArgs.updated ().iterator (); it.moveNext ();)
            {
                LazyObjectReference reference = (LazyObjectReference) it.current ();
                System.out.println ("Updated object: " + reference.getClass () + ":" + reference.getInternalID ());
                //if (trackedClasses.contains (reference.getClass ()))
                {
                    Object obj = reference.getObject ();
                    commitEventArgs.objectContainer ().ext ().refresh (obj, 1);
                    System.out.println ("  => updated (" + obj + ")");
                }
            }
        }
    });

在进程内客户端中,然后执行以下代码:

    try {
        PlayerCharacter pc = new PlayerCharacter (player, name);
        pc.setBio(bio);
        pc.setArchetype(archetype);
        player.getCharacters ().add (pc);
        database.store (pc);
        database.store (player.getCharacters ());
        database.store (player);
        database.commit ();
        con.sendEvent (id, "CHARACTER_CREATED".getBytes (Constants.CHARSET));
    }
    catch (Exception e) 
    {
        con.sendEvent (id, EventNames.ERROR, e.toString ());
    }

'CHARACTER_CREATED'事件成功发送,因此我知道提交不会引发异常,但是其他客户端上没有显示任何内容。它继续使用旧版本的对象,而我期望的“更新对象”消息不会显示在服务器控制台上。

任何想法我做错了什么?

1 个答案:

答案 0 :(得分:1)

当提交来自其他TCP客户端时,显然.committed()事件仅在客户端上触发。

因此,您需要将内部.openClient()/ .openSession()客户端转换为完整的TCP客户端以查看事件。

.openClient()/ .openSession()对象容器的重量更轻,并绕过与网络通信相关的所有代码。显然也是整个网络的事件分发。