- MongoDB Administrator’s Guide
- Cyrus Dasadia
- 304字
- 2021-07-02 15:47:44
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.
- The Complete Rust Programming Reference Guide
- Cocos2D-X權威指南(第2版)
- Servlet/JSP深入詳解
- AngularJS深度剖析與最佳實踐
- NumPy Essentials
- Mastering Python Networking
- QGIS By Example
- ServiceNow:Building Powerful Workflows
- 編程改變生活:用Python提升你的能力(進階篇·微課視頻版)
- Python計算機視覺和自然語言處理
- jQuery for Designers Beginner's Guide Second Edition
- R的極客理想:量化投資篇
- Java從入門到精通(視頻實戰版)
- 例解Python:Python編程快速入門踐行指南
- Bitcoin Essentials