Hi Gregori,

I'm about to start a new project and I was considering using MongoDB too, but I 
just couldn't find a nice way to scale it. Seems like for scaling you need to 
use the same style as MySQL, having master/slaves and replicas, which for us 
was a deal breaker. We just couldn't see how you would scale MongoDB to support 
massive databases that you can reach using Cassandra/HBase.

I personally think that's where Cassandra shines and if you don't need that 
massive scale, then there are a lot nicer solutions out there.

How do you scale MongoDB to store massive amounts of data?

- Drew





On Mar 29, 2011, at 5:11 PM, Gregori Schmidt wrote:

> hi,
> 
> After using Cassandra during development for the past 8 months my team and I 
> made the decision to switch from Cassandra to MongoDB this morning.  I 
> thought I'd share some thoughts on why we did this and where Cassandra might 
> benefit from improvement.
> The API is horrible and it produces pointlessly verbose code in addition to 
> being utterly confusing.  EVERYTHING takes a lot of time to implement with 
> Cassandra, and to be frank, it is incredibly tiring.  For this reason alone I 
> no longer recommend Cassandra.  If you want an example, pick up the O'Reilly 
> book on Cassandra and look through the examples.  Such MASSIVE amounts of 
> code for doing nearly NOTHING.  This is ridiculous.  Didn't this strike 
> anyone else as ridiculous?  It should have!
> You need to have official client libraries and they need to be programmer 
> friendly.  Yes, I know there are nice people maintaining a plethora of 
> different libraries, but you need to man up and face reality:  the chaos that 
> is the Cassandra client space is a horrible mess.
> It is buggy and the solution seems to be to just go to the next release.  And 
> the next.  And the next.  Which would be okay if you could upgrade all the 
> time, but what to do once you hit production?
> I would recommend that everyone interested in improving Cassandra take the 
> day off,  download MongoDB and read 
> https://github.com/karlseguin/the-little-mongodb-book . Then, while you are 
> downloading, unpacking, looking at what was in the JAR, reading the book and 
> pawing through the examples: _pay attention_ to the neatness and the 
> effortlessness the ease with which you can use MongoDB.  Then spend the rest 
> of the day implementing something on top of it to gain some hacking 
> experience.
> 
> No, really.  Do it.  This is important.  You need to connect with the user 
> and you need to understand what you ought to be aspiring to.
> 
> In any case, thanks for all the effort that went into Cassandra.  I will 
> check back from time to time and perhaps in a year or so it'll be time to 
> re-evaluate Cassandra.
> 
> PS: one last thing.  It took us less time to rewrite the DB-interface for our 
> system to MongoDB AND port over our data than it took to write the Cassandra 
> implementation.
> 
> ~G

Reply via email to