Event Store
LiteDB
Our great sponsors
Event Store | LiteDB | |
---|---|---|
5 | 11 | |
5,073 | 8,215 | |
0.6% | - | |
9.5 | 8.0 | |
about 11 hours ago | 9 days ago | |
C# | C# | |
GNU General Public License v3.0 or later | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Event Store
-
Event Store State of the Art
I've been doing some research and found this: https://github.com/EventStore/EventStore
-
if you had to restart at 0 knowledge what would you do?
C#: In Europe, Java is still strong but many trading firms use C# because of the strong Microsoft culture in Europe, as well as because of strongly supported C# libraries like say EventStore, which tends to be used for the matchmaking engines for stock exchanges (especially that exchange matchmaking problem is basically SMR). And skimming over the code, it has Paxos implemented too, making it good for dealing with partial failures (failover), essential for any HFT/trading firm. C#'s also the biggest ecosystem that many of the breakthrough java tech mentioned earlier was first ported to.
- Call for Help - Open Source Datom/EAV/Fact database in Rust.
-
Event sourcing two years later (almost)
Support for eventstore.com eventstore. esdb
-
3 reasons to adopt Event Sourcing
Where's the catch, then? Well, there's a couple of catches, in fact. First of all, in a distributed setting, appending data to a log isn't that easy. First, you need to make your log distributed. Again, Kafka/Cassandra/EventStore make this possible, however, whenever you start dealing with distributed data, you‘re introducing new operational and implementation complexity.
LiteDB
-
Local migrations for embedded SQLite in F#
Personally, I used to use LiteDB which is a NoSQL version which in v4 paired very nicely with F# thanks to Zaid's lovely LiteDB.FSharp library. Sadly, when v5 showed up, a lot of the F# niceties were lost given how the API was changed and v5 was not very F# friendly. You can still use it of course but you fall back to more unsafe F# code which is not ideal.
-
Generic DB with minimal boilerplate code
Maybe you want LiteDB? I don't think you need to write SQL, you can interact with the API.
-
Yet another embedded DB (kind of)
Are you aware of LiteDB? It seems like your project is going for a very similar niche. Most people looking for this type of thing will probably go for the more mature and feature-rich solution (LiteDB). So if your project has some unique value proposition to distinguish it from LiteDB, you should elaborate on that.
-
How to introduce a queue for my API.
Please consider using the primary key to generate an unique value on the db side.
-
Unity MVVM
LiteDB
-
LiteDB: A .NET embedded NoSQL database
Before checking this out, people might want to take a look through the issues and pull requests of which there are 500+ and 50+ respectively [1]. I was really optimistic about this project and it was headed in a great direction, but it's not in a production ready state, and it seems that the main guy behind it has decided to move onto other things. It's been about a year since there was any significant activity.
I just mention this because a lot of these little issues might only become more apparent after integrating the db into your project and so it can be a bit annoying. I ended up swapping to Linq2DB [1]. It's something, more or less, similar offering an ORM/LINQ type system as well as the ability to also use direct SQL if desired. But the neat thing is that it also uses a standardized API for the LINQ query language, so you can do things like swap from SQLite to PostgreSQL in one* line of code, so long as you're not using any provider specific extensions.
-
What sort of mature, open-source libraries do you feel Rust should have but currently lacks?
A mature NoSQL embedded/flatfile database like LiteDB would be nice. There are some similar Rust libraries but they aren't very close to production ready and the API tends to not be too user friendly. I had trouble finding one of these for a small app I had to write recently.
What are some alternatives?
Marten - .NET Transactional Document DB and Event Store on PostgreSQL
RavenDB - ACID Document Database
Streamstone - Event store for Azure Table Storage
MongoDB - The MongoDB Database
Apache Ignite - Apache Ignite
Realm Xamarin - Realm is a mobile database: a replacement for SQLite & ORMs
Firebase.Net - C# wrapper over Firebase database REST API
Apache Cassandra - Mirror of Apache Cassandra
DBreeze - C# .NET NOSQL ( key value store embedded ) ACID multi-paradigm database management system.
Yessql - A .NET document database working on any RDBMS