- Notifications
You must be signed in to change notification settings - Fork666
KurrentDB is a database that's engineered for modern software applications and event-driven architectures. Its event-native design simplifies data modeling and preserves data integrity while the integrated streaming engine solves distributed messaging challenges and ensures data consistency.
License
kurrent-io/KurrentDB
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation

- What is Kurrent
- What is KurrentDB
- What is Kurrent Cloud
- Licensing
- Documentation
- Getting started with KurrentDB
- Getting started with Kurrent Cloud
- Client libraries
- Deployment
- Communities
- Contributing
- Building KurrentDB
- More resources
Event Store – the company and the product – are rebranding as Kurrent.
- The flagship product will be referred to as “the Kurrent event-native data platform” or “the Kurrent platform” or simply “Kurrent"
- EventStoreDB will be referred to as KurrentDB
- Event Store Cloud will now be called Kurrent Cloud
Read more about the rebrand in therebrand FAQ.
KurrentDB is a database that's engineered for modern software applications and event-driven architectures. Its event-native design simplifies data modeling and preserves data integrity while the integrated streaming engine solves distributed messaging challenges and ensures data consistency.
Download thelatest version.For more product information visitthe website.
Kurrent Cloud is a fully managed cloud offering that's designed to make it easy for developers to build and run highly available and secure applications that incorporate KurrentDB without having to worry about managing the underlying infrastructure. You can provision KurrentDB clusters in AWS, Azure, and GCP, and connect these services securely to your own cloud resources.
For more details visitthe website.
ViewKurrentDB's licensing information.
For guidance on installation, development, deployment, and administration, see theUser Documentation.
Follow thegetting started guide.
Kurrent can manage KurrentDB for you, so you don't have to run your own clusters.See the online documentation:Getting started with Kurrent Cloud.
This guide shows you how to get started with KurrentDB by setting up an instance or cluster and configuring it.KurrentDB supports the gRPC protocol.
- Python:pyeventsourcing/kurrentdbclient
- Node.js (javascript/typescript):kurrent-io/KurrentDB-Client-NodeJS
- Java:(kurrent-io/KurrentDB-Client-Java
- .NET:kurrent-io/EventStore-Client-Dotnet
- Go:kurrent-io/KurrentDB-Client-Go
- Rust:kurrent-io/KurrentDB-Client-Rust
- Read more in thegRPC clients documentation
- Elixir:NFIBrokerage/spear
- Ruby:yousty/event_store_client
Read more in thedocumentation.
- Kurrent Cloud -steps to get started in Kurrent Cloud.
- Self-managed -steps to host KurrentDB yourself.
Join our global community of developers.
Development is done on themaster
branch.We attempt to do our best to ensure that the history remains clean and to do so, commits are automatically squashed into a single logical commit when pull requests are merged.
If you want to switch to a particular release, you can check out the release branch for that particular release. For example:git checkout release/v25.0
KurrentDB is written in a mixture of C# and JavaScript. It can run on Windows, Linux and macOS (using Docker) using the .NET Core runtime.
Prerequisites
Once you've installed the prerequisites for your system, you can launch aRelease
build of KurrentDB as follows:
dotnet build -c Release src
The build scripts:build.sh
andbuild.ps1
are also available for Linux and Windows respectively to simplify the build process.
To start a single node, you can then run:
dotnet ./src/KurrentDB/bin/Release/net8.0/KurrentDB.dll --dev --db ./tmp/data --index ./tmp/index --log ./tmp/log
You can launch the tests as follows:
dotnet test src/KurrentDB.sln
You can also build a Docker image by running the command:
docker build --tag mykurrentdb . \--build-arg CONTAINER_RUNTIME={container-runtime}--build-arg RUNTIME={runtime}
For instance:
docker build --tag mykurrentdb . \--build-arg CONTAINER_RUNTIME=bookworm-slim \--build-arg RUNTIME=linux-x64
Note: Because of theDocker issue, if you're building a Docker image on Windows, you may need to set theDOCKER_BUILDKIT=0
environment variable. For instance, running in PowerShell:
$env:DOCKER_BUILDKIT=0; docker build --tag mykurrentdb . `--build-arg CONTAINER_RUNTIME=bookworm-slim `--build-arg RUNTIME=linux-x64
Currently, we support the following configurations:
- Bookworm slim:
CONTAINER_RUNTIME=bookworm-slim
RUNTIME=linux-x64
- Jammy:
CONTAINER_RUNTIME=Jammy
RUNTIME=linux-x64
- Alpine:
CONTAINER_RUNTIME=alpine
RUNTIME=linux-musl-x64
You can verify the built image by running:
docker run --rm mykurrentdb --insecure --what-if
About
KurrentDB is a database that's engineered for modern software applications and event-driven architectures. Its event-native design simplifies data modeling and preserves data integrity while the integrated streaming engine solves distributed messaging challenges and ensures data consistency.
Topics
Resources
License
Security policy
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Packages0
Uh oh!
There was an error while loading.Please reload this page.
Uh oh!
There was an error while loading.Please reload this page.