https://github.com/buraksenyurt/kiwi-store
Deneysel ve hafifsiklet bir key-value store çalışmasıdır.
https://github.com/buraksenyurt/kiwi-store
asynchronous-programming clap-rs experimental key-value-store poc rust rust-lang tokio-rs
Last synced: 4 months ago
JSON representation
Deneysel ve hafifsiklet bir key-value store çalışmasıdır.
- Host: GitHub
- URL: https://github.com/buraksenyurt/kiwi-store
- Owner: buraksenyurt
- License: mit
- Created: 2025-05-26T12:29:01.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2025-09-13T16:49:11.000Z (10 months ago)
- Last Synced: 2026-01-30T13:27:31.339Z (5 months ago)
- Topics: asynchronous-programming, clap-rs, experimental, key-value-store, poc, rust, rust-lang, tokio-rs
- Language: Rust
- Homepage:
- Size: 272 KB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Kiwi-Store
Deneysel ve hafifsiklet bir key-value store çalışmasıdır. Amaç geliştirmesi kolay, in-memory çalışan ve başlangıçta tek node üzerinden işleyen bir sistem kurmaktır. Çalışmada yer alan uygulamalar ve genel özellikleri şöyledir.
- Server Side _(kiwi-store-server)_
- Sadece string türden key ve value çiftleri tutar
- Key bilgisi 20, Value bilgisi 100 karakterden fazla olamaz
- Key-Value bilgileri in-memory saklanır
- Sunucu tarafı Tcp protokolü üzerinden çalışır
- Tamamen asenkrondur
- CLI _(kiwi-store-client)_
- Key, Value eklenmesi, çekilmesi, silinmesi gibi temel işlevleri sağlayan terminal uygulamasıdır
- Tester _(kiwi-store-loadtest)_
- Server side için load, fuzz test işleten bir test koşucusudur
- Test değerleri postgresql dosyasına yazılır
- Metrics Api _(kiwi-store-metric-api)_
- Load/Fuzz testlerine ait metrikleri verir
- Dashboard _(dashboard/index.html)_
- Test metrikleri ile ilgili ölçümleri gösteren board'dur.
- .Net Port Library _(KiwiStore)_
- KiwiStore'u .net uygulamalarında kullanabilmek için yazılmış kütüphane
- Kütüphane testlerin kolay yapılabilmesi için [Nuget ortamına da](https://www.nuget.org/packages/KiwiStore/) yüklenmiştir.
- .Net Test App _(KiwiStore.Test.Api)_
- KiwiStore paketinin DI üzerinden kullanımının test edildiği basit Web API hizmeti
- Set, Get, Remove, List ve diğer tüm hizmetler için örnek kullanımlar sağlar [Postman Koleksiyonuna buradan ulaşılabilir](Key-Value%20Store%20.Net%20Api.postman_collection.json)
## Runtime
Gerekli ortamlar için docker compose kullanılabilir. _(Sunucu uygulama, metrik ölçümlerinin depolanması için postgresql)_
```bash
docker-compose up -d
```
İstemci tarafı için komut satır aracı kullanılabilir.
```bash
# cargo run ile
# kiwi-store-client klasöründe
# Yeni bir key-value eklemek
cargo run -- set smtp fake
# Value değeri çekmek
cargo run -- get smtp
# İçinde farklı karakterler olan value eklemek
cargo run -- set conn "data source=localhost;database=Northwind;integrated security=sspi"
# Key listesini çekmek
cargo run -- list
# Bir key-value çiftini çıkarmak
cargo run -- remove smtp
# Genel istatistikleri elde etmek
cargo run -- stats
# Ping-Pong oynamak
cargo run -- ping
# Geçersiz komut girmek
cargo run -- set Itsalonglonglonglongwaywemusttogo "lorem ipsum connnection string"
cargo run -- set ConnectionString "data source = localhot; database = Nortwhing; integrated security=sspi; mars = true; distributed transaction=off"
```
Load ve Fuzz test yapan kiwi-store-loadtest uygulaması da komut satırından aşağıdaki gibi çalıştırılabilir.
```bash
# 10 istemci, istemci başına 50 komut
cargo run -- -k load -c 10 -s 50
# 100 istemci, istemci başına 1000 komut
cargo run -- -k load -c 100 -s 1000
# 10 istemci, istemci başına 100 geçersiz komut
cargo run -- -k fuzz -c 10 -s 100
```
## Metric Toplama
Test aracının topladığı metrikler text tabanlı olarak CSV formatında tutulabileceği gibi Postgresql veri tabanında bir tabloda da tutulabilir.
```sql
CREATE TABLE metrics (
id SERIAL PRIMARY KEY,
time_stamp TIMESTAMPTZ NOT NULL,
test_type TEXT NOT NULL,
total_commands INT NOT NULL,
successful_commands INT NOT NULL,
failed_commands INT NOT NULL,
average_latency_ms DOUBLE PRECISION NOT NULL
);
```
Toplanan metrikleri dashboard uygulamasına vermek içinse basit bir Web API hizmeti kullanılmaktadır _(kiwi-store-metric-api)_ Bu hizmet şu an için 5556 nolu porttan hizmet verir. Bu servisi kullanarak son 50 test verisine ait çizgi grafiğini de dashboard klasöründe yer alan index.html aracılığı ile görebiliriz. Aşağıdakine benzer bir çıktı olacaktır. Burada zaman bazlı bir çıktı söz konusudur. Bunun anlamlı olması için
belli periyotlarda aynı load ve fuzz oranlarına göre test yapılması daha iyi olabilir.

## .Net Tarafında Kullanım
Key-Value store'un .net projelerinden kullanılabilmesi için sonradan Nuget paketi haline de getirilebilecek bir kütüphane yazılmıştır. Nuget paketi KiwiStore.Test.Api isimli Web API hizmetinde basitçe ele alınmıştır. İlgili örnekte KiwiStore bilgileri appsettings.json dosyasından karşılanır. Örnek çalışma zamanı görüntüsü aşağıdaki gibidir.

## Planlanan Ekler
- [x] Load ve Fuzz test yapan bir uygulama.
- [x] Test çıktılarının Postgresql tablosuna yazdırılması.
- [x] Metrik ölçümlerini dışarıya veren API hizmetinin yazılması.
- [x] Metrik ölçümleri için basit bir montoring dashboard.
- [x] .Net ile entegrasyon kütüphanesi.
- [x] Nuget paketi yardımıyla key-value store kullanan örnek uygulama.
- [ ] Mesajların şifrelenerek iletiminin sağlanması.
- [ ] Multi-Node Çalışma.
## Problemler
- [x] Key store'da hiçbir eleman kalmadığında client taraftaki list komutu sonsuz döngüde kalıyor.
- [ ] Windows ortamında docker container portu zaman zaman kullanımda kalıyor ve yenisi başlatılamıyor.