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

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.

主站蜘蛛池模板: 佛冈县| 田阳县| 荣成市| 通海县| 万全县| 平凉市| 海晏县| 永昌县| 哈巴河县| 汝阳县| 富裕县| 宜春市| 郧西县| 临洮县| 通山县| 甘孜| 桐庐县| 伊吾县| 临汾市| 高平市| 宁河县| 大埔区| 镇宁| 藁城市| 灵石县| 大洼县| 定西市| 华宁县| 金溪县| 霍邱县| 环江| 永平县| 许昌县| 海城市| 扶绥县| 凤台县| 丽江市| 华安县| 迭部县| 桃源县| 青海省|