Crates.io | tower-sessions-sled-store |
lib.rs | tower-sessions-sled-store |
version | 0.1.0 |
source | src |
created_at | 2024-03-03 15:28:57.940747 |
updated_at | 2024-03-03 15:28:57.940747 |
description | Sled session store. Not for direct use; see the `tower-sessions` crate for details. |
homepage | |
repository | |
max_upload_size | |
id | 1160708 |
size | 42,718 |
A tower-sessions backend for Sled
This create provides an Sled back-end for the tower-session session management crate.
The sled library has not yet released their 1.0 release. According to the sled developers there will be an overhaul of the on disk format for version 1.0 which may require additional efforts to migrate data.
While sled performs fairly well for general tasks, deletion of expired records may cause slowdowns when using sled as your session store.
As sled is a simple key-value database checking the expiration for every key requires iterating every key in the database. This may cause performance issues with high numbers of active sessions
Creating a SledStore
only requires a sled Tree
use std::net::SocketAddr;
use axum::{response::IntoResponse, routing::get, Router};
use serde::{Deserialize, Serialize};
use time::Duration;
use tower_sessions::{Expiry, Session, SessionManagerLayer};
use tower_sessions_sled_store::SledStore;
const COUNTER_KEY: &str = "counter";
#[derive(Default, Deserialize, Serialize)]
struct Counter(usize);
async fn handler(session: Session) -> impl IntoResponse {
let counter: Counter = session.get(COUNTER_KEY).await.unwrap().unwrap_or_default();
session.insert(COUNTER_KEY, counter.0 + 1).await.unwrap();
format!("Current count: {}", counter.0)
}
#[tokio::main]
async fn main() {
// Open a new sled database
let sled = sled::open("storage").unwrap();
// Open a tree named session within that database
let session_store = SledStore::new(sled.open_tree("session").unwrap());
let session_layer = SessionManagerLayer::new(session_store)
.with_secure(false)
.with_expiry(Expiry::OnInactivity(Duration::seconds(10)));
let app = Router::new().route("/", get(handler)).layer(session_layer);
let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
let listener = tokio::net::TcpListener::bind(&addr).await.unwrap();
axum::serve(listener, app.into_make_service())
.await
.unwrap();
}