亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問(wèn)板塊 發(fā)新帖
查看: 4265 | 回復(fù): 1
打印 上一主題 下一主題

[Redis] Redis實(shí)現(xiàn)MongoDB的getlasterror功能 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2012-02-16 19:31 |只看該作者 |倒序?yàn)g覽
Redis實(shí)現(xiàn)MongoDB的getlasterror功能








MongoDB有一個(gè)命令叫g(shù)etlasterror,從名字上看它的作用好像是獲取最近的一個(gè)error。但其實(shí)這是MongoDB的一種客戶端阻塞的方式。官方的解釋如下:

MongoDB does not wait for a response by default when writing to the database. Use the getLastError command to ensure that operations have succeeded.

MongoDB 在寫(xiě)操作時(shí),默認(rèn)不會(huì)等數(shù)據(jù)寫(xiě)完后才返回,你可以通過(guò)使用getLastError命令來(lái)保證你的寫(xiě)是成功的。

說(shuō)白了,MongoDB的寫(xiě)是異步的,返回給客戶端成功但其寫(xiě)并不一定成功,而且在多個(gè)數(shù)據(jù)結(jié)點(diǎn)進(jìn)行replication的時(shí)候,更無(wú)法保證數(shù)據(jù)同步到其它結(jié)點(diǎn)上。getLastError就是為此而生的,你指定一個(gè)條件,然后這個(gè)函數(shù)會(huì)一直阻塞到服務(wù)端告知這個(gè)條件滿足了才會(huì)返回值。(當(dāng)然,為了防止死等,這個(gè)函數(shù)還有一個(gè)超時(shí)參數(shù)),例子:

db.runCommand( { getlasterror : 1 , w : 2 } )上面命令表示等寫(xiě)操作被寫(xiě)到兩個(gè)結(jié)點(diǎn)再返回成功。

這一功能使得數(shù)據(jù)安全性的保證更加靈活。

而最近有朋友在Redis上也實(shí)現(xiàn)了這一功能,實(shí)現(xiàn)的方式不是修改Redis源碼,而是使用現(xiàn)有的功能拼得出,具體過(guò)程如下:

1. Client SUBSCRIBEs to  KEY on *slave*
2. Client writes KEY (e.g. set foo bar) to master
3. Client publishes KEY to master

由于Redis的單線程寫(xiě)操作,下面兩個(gè)操作會(huì)被順序執(zhí)行

4. Master will replicate KEY to slave
5 Master will propogate *PUBLISH KEY* to slave

最后,在Master同步完數(shù)據(jù)后,客戶端會(huì)收到SUBSCRIBE的消息:
6. Gets KEY event on SUBSCRIBE!

來(lái)源:http://goo.gl/7zDPb

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2012-02-17 22:32 |只看該作者
謝謝分享
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專(zhuān)區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過(guò)ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP