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

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.

主站蜘蛛池模板: 麻栗坡县| 阜南县| 法库县| 汝城县| 资兴市| 板桥市| 平南县| 三门峡市| 凌海市| 澎湖县| 河西区| 阿巴嘎旗| 扎鲁特旗| 冷水江市| 尚志市| 车致| 新化县| 财经| 安图县| 大理市| 彩票| 大邑县| 永福县| 阿图什市| 屯留县| 长春市| 南乐县| 资兴市| 巴彦淖尔市| 收藏| 上林县| 竹溪县| 肥西县| 仁寿县| 巫山县| 罗源县| 荥阳市| 福鼎市| 保德县| 徐水县| 山阳县|