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
|