Jackrabbit中的集群(5)



只是为了将Jackrabbit中的每个模块都作一下介绍,所以才放出这么一节来。实际上Jackrabbit对集群的支持并不怎样。

要了解它的集群,你得首先到 /jackrabbit-core/src/main/java/org/apache/jackrabbit/core/cluster 包里面去看一下。

Jackrabbit采用生产消费模式来Handle它的集群设计。它假定它的架构周边有一台中心DB或是中心文件服务器(这应当是一台性能极好的DB,否则性能不好的话整个集群的意义不大。)。

有了这么一台中心DB后,各服务器会将自己的增删改操作告知中心DB. 这一过程可谓生产过程。

那服务器又是如何知道别人的增删改操作呢,jackrabbit在每个服务器上加了个后台线程。定时的去中心DB上看是不是有新的更新(如果自己的版本比最新版本旧,则有更新), 如果有,则将中心DB所有的版本从前到后依次同步一下。

这样还是会有问题,比方说定时同步的时间是30秒,那30秒之内的有服务器增删改了就没办法了么?

实际上,Jackrabbit还有另一个方案,在所有的增删改之前,会去先锁住相关的记录。这时候只有它一个人可以操作数据,它将自己的版本更新至最新版后,进去增删改操作。然后解锁。

以上的定时同步和手动同步过程便是消费过程。




这样,一整套的集群方案便介绍完了。







你可能感兴趣的:(apache,设计模式)