官术网_书友最值得收藏!

How it works...

As WiredTiger is the default storage engine for MongoDB 3.2, for this exercise, we explicitly started a MongoDB instance with MMAPv1 storage engine in step 1. In step 2, we stored the db.serverStatus() command's output in a temporary variable to inspect the output of the server's storageEngine key. This helps us see which storage engine our MongoDB instance is running on. In step 3, we switched to database mydb and ran a simple JavaScript function to add 100 documents to a collection called mycol. Next, in step 4, we created a backup directory /data/backup which is passed as a parameter to mongodump utility. We will discuss more about the mongodump utility in Chapter 6, Managing MongoDB Backups.

Once we shutdown the mongod instance, in step 5, we are now ready to start a new instance of MongoDB but this time with WiredTiger storage engine. We follow the basic practice of covering for failure and instead of removing /data/db, we create a new path for this instance (#AlwaysHaveABackupPlan). Our new MongoDB instance is empty, so in step 7 we import the aforementioned backup into the database using the mongorestore utility. As the new MongoDB instance is running WiredTiger storage engine, our backup (which is essentially BSON data) is restored and saved on disk using this storage engine. Lastly, in step 8, we simply inspect the storageEngine key on the db.serverStatus() output and confirm that we are indeed using WiredTiger.

As you can see, this is an overly simplistic example of how to convert MongoDB data from one storage engine format to another. One has to keep in mind that this operation will take a significant amount of time depending on the size of data. However, application downtime can be averted if we were to use a replica set. More on this later.

主站蜘蛛池模板: 大同县| 麦盖提县| 枞阳县| 莎车县| 全椒县| 甘肃省| 揭东县| 陇西县| 高平市| 永兴县| 鄂托克旗| 平原县| 蓬安县| 碌曲县| 略阳县| 仙桃市| 临潭县| 定结县| 从江县| 固原市| 潮安县| 永泰县| 监利县| 咸宁市| 祁东县| 辉县市| 介休市| 武威市| 宜川县| 云林县| 孙吴县| 四子王旗| 台东市| 平顶山市| 原阳县| 道真| 临武县| 长治市| 尉氏县| 桃园市| 巴南区|