Hi Guys. Based on a conversation with a close friend who pointed me to the EventStore website, I am beginning to become very interested in the project and the concepts behind it. I am quite keen to get started using the EventStore, possibly in my next project. Before I do I need to get started running some tests to see if I have the concepts correct and test out performance etc. I was hoping to get an opinion on how some data could be stored and the environments possible to communicate with the server.
-
Libraries. My next project is going to be using nodejs as the server. I noticed there is a TCP connector to the EventStore (https://github.com/kenpratt/nodejs-EventStore) but with the last commit a year ago, and the basic.js example not working, and errors communicating with the server using basic code, I don’t think this is an option for me. Failing to find any other projects, I was wondering if anyone knew of any other libraries I can use with nodejs to make my learning curve easier.
-
I suppose my biggest leap to understanding the best way to use the system is ‘what is a stream’. Is my understanding correct that a stream is like a row in a relational table? e.g. if I have a shopping cart table, someone comes to my site and adds something to their cart, do I create a stream at that point to identify all the events that are associated with the cart?
-
If my above understanding is correct, do I also need to create an event on a ‘carts’ stream that will keep track of all my carts (thinking of the abstraction, this would be similar to the table in a relational database). e.g. if i wanted a list of all the carts, would this appear on a separate stream? I could imagine a scenario where I would want to get a list of all my users, I would need some way to work out which of my cart and users and products and (ad-nausium) streams would be just my user streams.
-
A big hurdle I have is doing ‘finds’ on the EventStore (i.e. find all users with the first name john). Am I to believe that the projections api would help with this? I have the thought that I would also run a rethinkdb/mongodb/mariadb instance along side EventStore to hold the current state of my entities. This way the EventStore could be my authoritative source, however for doing things like finding all the carts that have been abandoned could be done very quickly and easily in a more conventional database. It would report back the data as well as the stream id’s. If this is the way to do it, then my solution would be to run some kind of worker (running the tcp connection to EventStore) to listen to every event, and simply modify the row/document each time. Any thoughts/suggestions about if this is good, bad or ugly? Or how to improve? Or have I missed the mark completely
-
Similar question to above, if I do keep an index of current states, and my ‘finds’ are off them, when I instantiate a new instance of an object, would I be better rebuilding the state of the object from the event store, or simply use the index? My thinking at the moment is to make that flexible, or even do both (this way I can keep track if the state in the index is up to date, or has been corrupted somehow, forcing a delete of the object in the index and playing back its stream again).
-
Is the project production ready? I cant see that I would need any more than a single node for any real use, but I would want to investigate the clustering if for nothing more than replication and fast failover in the event of a disaster. But if I was to go into production, how stable will it be? Are updates backward compatible (or have reliable upgrade paths?) How many nodes can be managed using the cluster? How many events/streams/etc can be expected? How big are systems out there now? How performant are the big systems (do they need to rely on snapshots for performance for example?)
I think thats it for the moment. Thank you in advance for any answers, and thank you for making it this far
Matt.