MongoDB1.7.x版本有哪些新特性

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)MongoDB 1.7.x版本有哪些新特性,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

目前創(chuàng)新互聯(lián)已為數(shù)千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、鄂倫春網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

MongoDB官方博客最近發(fā)表文章,對1.7.4版本中關(guān)于ReplicaSets的五個(gè)重要新特性做了一個(gè)介紹,這些特性會(huì)繼續(xù)在1.8.x版本中存在并持續(xù)改進(jìn)。

MongoDB1.7.x版本有哪些新的特性

1.從一個(gè)secondary結(jié)點(diǎn)初始化新結(jié)點(diǎn)(Initialsyncfromasecondary)

可以在新啟動(dòng)的ReplicaSets結(jié)點(diǎn)上設(shè)置initialSync選項(xiàng)來指定從某個(gè)secondary結(jié)點(diǎn)獲取初始化數(shù)據(jù)。如下:

>rs.add({"_id":num,"host":hostname,"initialSync":{"state":2}})

在initialSync選項(xiàng)中是一個(gè)篩選條件,你可以選擇從哪個(gè)角色的機(jī)器上獲取初始化數(shù)據(jù)(primaryorsecondary),也可以直接指定_id,hostname或者從數(shù)據(jù)最新的節(jié)點(diǎn)。如果指定的是從數(shù)據(jù)最新的結(jié)點(diǎn)上獲取初始化化數(shù)據(jù),你可以指定一個(gè)日期或者時(shí)間戳,這時(shí)候新加入的結(jié)點(diǎn)會(huì)選擇一個(gè)比你設(shè)定的時(shí)間點(diǎn)數(shù)據(jù)更新的結(jié)點(diǎn)獲取數(shù)據(jù)。

新加入的結(jié)點(diǎn)默認(rèn)是從某個(gè)secondary結(jié)點(diǎn)獲取初始化數(shù)據(jù),只有在找不到這樣的結(jié)點(diǎn)時(shí),才會(huì)從primary結(jié)點(diǎn)上獲取數(shù)據(jù)。如果他找到了某個(gè)secondary機(jī)器,那么他只會(huì)從他獲取初始化需要的數(shù)據(jù),一旦他的數(shù)據(jù)與這個(gè)secondary機(jī)器同步了,他就會(huì)切換到從primary節(jié)點(diǎn)上獲取新的更新操作。

2.從機(jī)延遲時(shí)間配置(slavedelay選項(xiàng))

這個(gè)slavedelay選項(xiàng)之前在master-slave模式的replication里支持,主要用于配置一個(gè)較長的時(shí)間以防止一些人為的錯(cuò)誤。比如設(shè)定這個(gè)時(shí)間為86400,則同步操作只會(huì)同步超過一天前的數(shù)據(jù),同步操作一直在,并非一天只同步一次(感謝ElmerZhang同學(xué)的留言提醒)。而現(xiàn)在ReplicaSets也支持它了,使用方式:

>rs.add({"_id":num,"host":hostname,"slaveDelay":3600})

MongoDB1.7.x版本有哪些新的特性

3.隱藏節(jié)點(diǎn)(hiddennode)

隱藏節(jié)點(diǎn)的描述很簡單,就是這個(gè)節(jié)點(diǎn)是隱藏的不可為客戶端所見。配置方式:

>rs.add({"_id":num,"host":hostname,"priority":0,"hidden":true})

4.結(jié)點(diǎn)凍結(jié)(Freezeamember)

ReplicaSets的一個(gè)特點(diǎn)就是自動(dòng)故障轉(zhuǎn)移,也就是說在一臺(tái)primary機(jī)器故障后,其他的secondary機(jī)器會(huì)盡快地選出一臺(tái)新的主機(jī)。但是在我們進(jìn)行某些維護(hù)操作時(shí),會(huì)希望某段時(shí)間內(nèi)不要讓失去primary連接的secondary機(jī)器晉升為primary,而是等待一段時(shí)間再進(jìn)行選舉工作。這個(gè)操作就被稱為結(jié)點(diǎn)凍結(jié)操作,具體操作方式如下:

>rs.freeze(3600)

解凍方式:

>rs.freeze(0)

5.快速同步(Fastsync)

在過去,啟動(dòng)一個(gè)新節(jié)點(diǎn)時(shí)只能從primary節(jié)點(diǎn)獲取新的數(shù)據(jù),而上面第一條特性允許從secondary節(jié)點(diǎn)獲取初始化數(shù)據(jù)。但是無論如何,全量數(shù)據(jù)的同步都會(huì)是一個(gè)比較慢的過程。Fastsync特性能夠讓新節(jié)點(diǎn)啟動(dòng)更加快速,F(xiàn)astsync就是讓新節(jié)點(diǎn)在啟動(dòng)時(shí)指定dbpath為一個(gè)過去備份好的數(shù)據(jù)文件目錄,只要保證這個(gè)數(shù)據(jù)備份的時(shí)間還不長(不超過primary的最老的oplog),則就可以先通過已有的備份數(shù)據(jù)文件啟動(dòng)然后再從primary機(jī)器獲取新的更新。

查看最老的oplog的方法如下:

>uselocal

>newDate(db.oplog.rs.find().sort({$natural:1}).limit(1).next()["ts"]["t"])

10gen的團(tuán)隊(duì)還列出了今后會(huì)加入的新特性如下:authentication,syncingfromsecondariesbeyondtheinitialsync,datacenterawareness,andmore.如果你希望加入其他一些什么功能你可以到voteonthecasesyoucareabout去為你期待的功能投票。

上述就是小編為大家分享的MongoDB 1.7.x版本有哪些新特性了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享名稱:MongoDB1.7.x版本有哪些新特性
分享網(wǎng)址:http://bm7419.com/article38/ijpdpp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站設(shè)計(jì)公司、建站公司、軟件開發(fā)、用戶體驗(yàn)、網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)