Storing data in MongoDB with the official C# driver sooner or later you might run into the following exception:
System.IO.FileFormatException: Size 22327168 is larger than MaxDocumentSize 16777216. This is happening because of the limitation of a single document size that exists in MongoDB by design.
The maximum BSON document size is 16 megabytes. The maximum document size helps ensure that a single document cannot use excessive amount of RAM or, during transmission, excessive amount of bandwidth.
Though there is a JIRA ticket called Increase max document size to at least 64mb, it doesn’t seem likely to be done in the near future. Geert Bosch, senior software engineer at MongoDB, wrote the following comment:
In order to support much larger documents, such as the 64Mb documents suggested, assumptions such as that we can easily allocate copies of documents for modification will no longer hold. Transactions could grow extremely large (just think of a 64Mb array of elements to index). We would need to significantly throttle the number of concurrent operations, or raise the memory requirements for mongod.
But, if you find yourself stuck in such a situation, don’t get frustrated – there is a solution.