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

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

Chinaunix

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

[MongoDB] MongoDB oplog刪除策略優(yōu)化 [復(fù)制鏈接]

求職 : Linux運(yùn)維
論壇徽章:
203
拜羊年徽章
日期:2015-03-03 16:15:432015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:092015小元宵徽章
日期:2015-03-06 15:58:182015年亞洲杯之約旦
日期:2015-04-05 20:08:292015年亞洲杯之澳大利亞
日期:2015-04-09 09:25:552015年亞洲杯之約旦
日期:2015-04-10 17:34:102015年亞洲杯之巴勒斯坦
日期:2015-04-10 17:35:342015年亞洲杯之日本
日期:2015-04-16 16:28:552015年亞洲杯紀(jì)念徽章
日期:2015-04-27 23:29:17操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-06-06 22:20:00操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-06-09 22:20:00
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2016-05-23 17:17 |只看該作者 |倒序?yàn)g覽
MongoDB oplog是一個(gè)capped collection,創(chuàng)建capped collection時(shí),createCollection可以設(shè)置size(最大字節(jié)數(shù))和max(最大文檔數(shù))的參數(shù),當(dāng)這個(gè)集合的『總大小超過size』或者『總文檔數(shù)超過max』時(shí),在新插入文檔時(shí)就會(huì)自動(dòng)刪除一些集合內(nèi)最先插入的文檔,相當(dāng)于一片環(huán)形的存儲(chǔ)空間。

oplog(local.oplog.rs集合)默認(rèn)情況下配置為可用磁盤空間的5%,當(dāng)oplog寫滿時(shí),就會(huì)開始刪除最先寫入的oplog,一次正常的insert操作包含如下步驟:

將文檔寫入指定的集合
將寫入操作記錄到oplog
如果oplog滿了,刪除最先寫入的oplog
優(yōu)化策略

MongoDB 3.2為了提升寫入性能,使用wiredtiger引擎時(shí),針對(duì)local.oplog.rs這個(gè)集合的刪除策略進(jìn)行了優(yōu)化,主要改進(jìn):

將刪除動(dòng)作從用戶的寫入路徑移除,放到后臺(tái)線程執(zhí)行
批量刪除,并不是oplog一滿就立馬觸發(fā)刪除,而是一次刪除一批
實(shí)施方案

monogd啟動(dòng)時(shí),會(huì)根據(jù)oplog的最大字節(jié)數(shù)將整個(gè)集合分為10-100個(gè)Stone(可以理解為oplog的一段數(shù)據(jù),包含多個(gè)文檔,Stone的具體個(gè)數(shù)oplogSizeMB的配置相關(guān))。

WiredTigerRecordStore::OplogStones::OplogStones(OperationContext* txn, WiredTigerRecordStore* rs)
    : _rs(rs) {
    //...
    unsigned long long maxSize = rs->cappedMaxSize();

    const unsigned long long kMinStonesToKeep = 10ULL;
    const unsigned long long kMaxStonesToKeep = 100ULL;

    unsigned long long numStones = maxSize / BSONObjMaxInternalSize;
    _numStonesToKeep = std::min(kMaxStonesToKeep, std::max(kMinStonesToKeep, numStones));
    _minBytesPerStone = maxSize / _numStonesToKeep;
    // ...
}
其中_numStonesToKeep為oplog應(yīng)該保持的Stone個(gè)數(shù),而_minBytesPerStone代表每個(gè)Stone的最小字節(jié)數(shù)。



接下來,會(huì)根據(jù)oplog當(dāng)前的大小以及_minBytesPerStone來估算下,當(dāng)前的oplog大致包含的Stone數(shù)量,并通過采樣的方式來獲取每個(gè)Stone的起始位置(不能保證每個(gè)Stone的大小跟預(yù)期完全一樣),然后將所有的Stone按順序存儲(chǔ)到一個(gè)隊(duì)列中。

mongod在服務(wù)寫請(qǐng)求的過程中,每次都會(huì)記錄下新產(chǎn)生oplog的大小,當(dāng)新產(chǎn)生的oplog的總量超過_minBytesPerStones時(shí),就會(huì)產(chǎn)生一個(gè)新的Stone加入到隊(duì)列中。

void WiredTigerRecordStore::OplogStones::createNewStoneIfNeeded(RecordId lastRecord) {

    if (_currentBytes.load() < _minBytesPerStone) {
        // Must have raced to create a new stone, someone else already triggered it.
        return;
    }

    // ...

    OplogStones::Stone stone = {_currentRecords.swap(0), _currentBytes.swap(0), lastRecord};
    _stones.push_back(stone);

    _pokeReclaimThreadIfNeeded(); // **后臺(tái)回收oplog空間的線程
}
當(dāng)隊(duì)列中的Stone數(shù)量超過_numStonesToKeep,后臺(tái)線程就會(huì)刪除最老的Stone里的數(shù)據(jù),來回收oplog的存儲(chǔ)空間。
您需要登錄后才可以回帖 登錄 | 注冊(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)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP