[Hazelcast系列 六] 分布式MultiMap

hazelcast IMDG

Hazelcast中的MultiMap 是一個(gè)key可以有多個(gè)值的特殊map。和其他數(shù)據(jù)結(jié)構(gòu)一樣募胃,MultiMap 也是分布式和線程安全的。MultiMap 不是 java.util.Map 的分布式實(shí)現(xiàn)末誓,MultiMap支持Map的多數(shù)功能拷恨,但是不支持索引,謂詞和加載/存儲(chǔ)。MultiMap 的數(shù)據(jù)最終也會(huì)均勻分布于集群所有節(jié)點(diǎn)蟀俊,新節(jié)點(diǎn)加入時(shí)的處理邏輯和map一樣钦铺。

1. 基本操作

創(chuàng)建MultiMap 并存儲(chǔ)數(shù)據(jù):

HazelcastInstance instance = Hazelcast.newHazelcastInstance();
MultiMap<String, Integer> multiMap = instance.getMultiMap("data");
multiMap.put("even", 2);
multiMap.put("even", 4);
multiMap.put("odd", 5);

遍歷元素:

HazelcastInstance instance = Hazelcast.newHazelcastInstance();
MultiMap<String, Integer> multiMap = instance.getMultiMap("data");
multiMap.put("even", 2);
multiMap.put("even", 4);
multiMap.put("odd", 5);

multiMap.keySet().forEach(s -> System.out.println(String.format("key = %s,value = %s", s, multiMap.get(s).toString())));

輸出如下:

key = even,value = [4, 2]
key = odd,value = [5]

MultiMap 支持通過(guò) EntryListener 監(jiān)聽(tīng)數(shù)據(jù)變化。

2. 配置

在使用MultiMap時(shí)肢预,可以通過(guò) valueCollectionType 配置值的集合類(lèi)型是SetList矛洞。如果選擇Set 重復(fù)值和空置是不允許的而且順序是無(wú)關(guān)緊要的。如果選擇使用List 排序是相關(guān)的而且可以允許存儲(chǔ)重復(fù)的值烫映。通過(guò)statisticsEnabled 配置可以開(kāi)啟對(duì)MultiMap的統(tǒng)計(jì)缚甩,使用 getLocalMultiMapStats() 方法獲取統(tǒng)計(jì)信息。

目前窑邦,MultiMap不支持?jǐn)?shù)據(jù)驅(qū)逐擅威。

下面是MultiMap的配置樣例。

聲明式配置:

<hazelcast>
    ...
    <multimap name="default">
        <backup-count>0</backup-count>
        <async-backup-count>1</async-backup-count>
        <value-collection-type>SET</value-collection-type>
        <entry-listeners>
            <entry-listener include-value="false" local="false" >com.hazelcast.examples.EntryListener</entry-listener>
        </entry-listeners>
        <split-brain-protection-ref>split-brain-protection-name</split-brain-protection-ref>
    </multimap>
    ...
</hazelcast>

代碼配置:

MultiMapConfig mmConfig = new MultiMapConfig();
mmConfig.setName( "default" )
        .setBackupCount( 0 ).setAsyncBackupCount( 1 )
        .setValueCollectionType( "SET" )
        .setSplitBrainProtectionName( "splitbrainprotectionname" );

配置參數(shù)及其含義:

  • backup-count: 同步備份數(shù)冈钦。
  • async-backup-count: 異步備份數(shù)郊丛。
  • statistics-enabled: 是否開(kāi)啟統(tǒng)計(jì)。
  • value-collection-type: 存儲(chǔ)值的集合類(lèi)型 SETLIST瞧筛。
  • entry-listeners: 監(jiān)聽(tīng)器.
  • split-brain-protection-ref: 腦裂保護(hù)厉熟。

3. 腦裂保護(hù)

MultiMap 和 TransactionalMultiMap 支持配置在應(yīng)用操作前檢查集群可用節(jié)點(diǎn)數(shù)。在網(wǎng)絡(luò)分區(qū)的情況下较幌,該配置可以避免操作在所有集群(一個(gè)集群分為多個(gè))都執(zhí)行成功揍瑟。

下面是支持腦裂保護(hù)的方法。

MultiMap:

  • WRITE, READ_WRITE:
    • clear
    • forceUnlock
    • lock
    • put
    • remove
    • tryLock
    • unlock
  • READ, READ_WRITE:
    • containsEntry
    • containsKey
    • containsValue
    • entrySet
    • get
    • isLocked
    • keySet
    • localKeySet
    • size
    • valueCount
    • values

TransactionalMultiMap:

  • WRITE, READ_WRITE:
    • put
    • remove
  • READ, READ_WRITE:
    • size
    • get
    • valueCount

配置腦裂保護(hù)

通過(guò)setSplitBrainProtectionName()方法或者 split-brain-protection-ref元素配置腦裂保護(hù)乍炉。下面是一個(gè)聲明式配置樣例:

<hazelcast>
    ...
    <multimap name="default">
        <split-brain-protection-ref>splitbrainprotection-name</split-brain-protection-ref>
    </multimap>
    ...
</hazelcast>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末绢片,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子岛琼,更是在濱河造成了極大的恐慌底循,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件槐瑞,死亡現(xiàn)場(chǎng)離奇詭異熙涤,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)困檩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)祠挫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人悼沿,你說(shuō)我怎么就攤上這事等舔。” “怎么了显沈?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵软瞎,是天一觀的道長(zhǎng)逢唤。 經(jīng)常有香客問(wèn)我,道長(zhǎng)涤浇,這世上最難降的妖魔是什么鳖藕? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮只锭,結(jié)果婚禮上著恩,老公的妹妹穿的比我還像新娘。我一直安慰自己蜻展,他們只是感情好喉誊,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著纵顾,像睡著了一般伍茄。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上施逾,一...
    開(kāi)封第一講書(shū)人閱讀 49,111評(píng)論 1 285
  • 那天敷矫,我揣著相機(jī)與錄音,去河邊找鬼汉额。 笑死曹仗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蠕搜。 我是一名探鬼主播怎茫,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼妓灌!你這毒婦竟也來(lái)了轨蛤?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤旬渠,失蹤者是張志新(化名)和其女友劉穎端壳,沒(méi)想到半個(gè)月后告丢,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡损谦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年岖免,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片照捡。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡颅湘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出栗精,到底是詐尸還是另有隱情闯参,我是刑警寧澤瞻鹏,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站鹿寨,受9級(jí)特大地震影響新博,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜脚草,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一赫悄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧馏慨,春花似錦埂淮、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至慕趴,卻和暖如春误窖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背秩贰。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工霹俺, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人毒费。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓丙唧,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親觅玻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子想际,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • feisky云計(jì)算、虛擬化與Linux技術(shù)筆記posts - 1014, comments - 298, trac...
    不排版閱讀 3,815評(píng)論 0 5
  • 【什么是大數(shù)據(jù)溪厘、大數(shù)據(jù)技術(shù)】 大數(shù)據(jù)胡本,又稱巨量資料,指的是所涉及的數(shù)據(jù)資料量規(guī)模巨大到無(wú)法在合理時(shí)間內(nèi)通過(guò)傳統(tǒng)的應(yīng)...
    kimibob閱讀 2,733評(píng)論 0 51
  • 一畸悬、系統(tǒng)參數(shù)配置優(yōu)化 1侧甫、系統(tǒng)內(nèi)核參數(shù)優(yōu)化配置 修改文件/etc/sysctl.conf,添加如下配置蹋宦,然后執(zhí)行s...
    張偉科閱讀 3,721評(píng)論 0 14
  • 一.簡(jiǎn)述如何安裝配置apache 的一個(gè)開(kāi)源的hadoop 1.使用root賬戶登陸 2.修改ip 3.修改hos...
    梔子花_ef39閱讀 4,933評(píng)論 0 52
  • 考研倒計(jì)時(shí)32天 今日任務(wù) 7:30-8:00 背單詞 8:00-9:00 專(zhuān)業(yè)課名詞解釋?zhuān)?jiǎn)答題 9...
    _然而閱讀 171評(píng)論 0 0