蕭十郎
2018-10-11 13:28:49
目前有一些工具可以很方便的升級(jí)線上的數(shù)據(jù)庫的結(jié)構(gòu),比如ruby寫的rails以及php的doctrine都有migration,不知道m(xù)ongodb有沒有很方便升級(jí)庫結(jié)構(gòu)的方法。
2 回答

largeQ
TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊
MongoDB升級(jí)數(shù)據(jù)庫還是相對(duì)比較方便的,如非特殊版本更新,基本上都不用停服務(wù)。
1.如果你的數(shù)據(jù)結(jié)構(gòu)有變化,MongoDB的Schema-free機(jī)制使你可以不用遷移
2.如果你想使用新版本中的新功能,那確實(shí)得遷移數(shù)據(jù)了,一種比較通常的做法是通過其Replication機(jī)制??梢钥匆幌鹿俜降南鄳?yīng)版本的release notes,通常會(huì)寫升級(jí)時(shí)是否可以用Replication的方式,不能用的話可能是因?yàn)楸敬涡掳姹驹赗eplicastion協(xié)議上本來就有改動(dòng)。那可能就得停服務(wù)來做遷移了。
3.停服務(wù)遷移前,也可以先通過mongodump和mongorestore遷移當(dāng)前數(shù)據(jù),然后停服務(wù)再遷移增量數(shù)據(jù),通常也不會(huì)停太長時(shí)間服務(wù)。
添加回答
舉報(bào)
0/150
提交
取消