Command-line interface for Dakera AI — inspect and manage a Dakera memory instance from the terminal.
The Dakera memory engine scores 87.8% on LoCoMo (1,540 questions, standard eval) — benchmark details
You need a running Dakera server to connect to. The fastest way:
docker run -d \
--name dakera \
-p 3000:3000 \
-e DAKERA_ROOT_API_KEY=dk-mykey \
ghcr.io/dakera-ai/dakera:latestFor persistent storage (recommended):
curl -sSfL https://raw.githubusercontent.com/Dakera-AI/dakera-deploy/main/docker-compose.yml \
-o docker-compose.yml
DAKERA_ROOT_API_KEY=dk-mykey docker compose up -d
curl http://localhost:3000/health # → {"status":"ok"}Full deployment guide (Docker Compose, Kubernetes, Helm): dakera-deploy
brew install dakera-ai/tap/dkcurl -fsSL https://dakera-ai.github.io/apt-repo/KEY.gpg \
| sudo gpg --dearmor -o /usr/share/keyrings/dakera-archive-keyring.gpg
echo "deb [signed-by=/usr/share/keyrings/dakera-archive-keyring.gpg] https://dakera-ai.github.io/apt-repo stable main" \
| sudo tee /etc/apt/sources.list.d/dakera.list
sudo apt-get update && sudo apt-get install -y dksudo tee /etc/yum.repos.d/dakera.repo << 'EOF'
[dakera]
name=Dakera AI
baseurl=https://dakera-ai.github.io/rpm-repo/
enabled=1
gpgcheck=0
EOF
sudo dnf install -y dk# From crates.io (compiles from source)
cargo install dakera-cli
# Pre-built binary via cargo-binstall (faster)
cargo binstall dakera-cliPre-built binaries for macOS (arm64/x64), Linux (x64/arm64), and Windows are available on the releases page.
| Platform | File |
|---|---|
| macOS (Apple Silicon) | dk-aarch64-apple-darwin.tar.gz |
| macOS (Intel) | dk-x86_64-apple-darwin.tar.gz |
| Linux x64 | dk-x86_64-unknown-linux-musl.tar.gz |
| Linux arm64 | dk-aarch64-unknown-linux-musl.tar.gz |
| Windows x64 | dk-x86_64-pc-windows-msvc.zip |
# 1. Configure the CLI (server URL + API key)
dk init
# 2. Verify connectivity
dk health
# 3. Store your first memory
dk memory store my-agent "The user prefers concise responses" --importance 0.8
# 4. Recall by semantic query
dk memory recall my-agent "user preferences" --top-k 5
# 5. Full-text BM25 search
dk text search "user preferences"| Variable | Description | Default |
|---|---|---|
DAKERA_URL |
Server base URL | http://localhost:3000 |
DAKERA_API_KEY |
API key for authentication | — |
DAKERA_PROFILE |
Named profile to use | active profile in config |
dk init creates ~/.dakera/config.toml:
[server]
url = "http://localhost:3000"
api_key = "dk-mykey"
[defaults]
namespace = "default"dk config profile add staging --url http://staging:3000 --key dk-staging-key
dk config profile use staging
dk --profile staging namespace listEnvironment variables > CLI flags > config file > defaults.
| Flag | Short | Default | Description |
|---|---|---|---|
--url |
-u |
http://localhost:3000 |
Server URL |
--format |
-f |
table |
Output format: table, json, compact |
--verbose |
-v |
false | Log HTTP requests and response timing |
--profile |
-p |
— | Named server profile |
dk --format json memory recall my-agent "recent tasks"
dk --format compact namespace list | jq '.[].name'
dk --verbose memory store my-agent "new memory"Check server health and connectivity.
dk health
dk health --detailedManage namespaces.
dk namespace list
dk namespace create my-ns
dk namespace policy --namespace my-nsStore, recall, search, and manage agent memories. This is the primary interface to Dakera.
# Store a memory
dk memory store my-agent "The user likes dark mode" --importance 0.8 --type semantic
# Recall by semantic query
dk memory recall my-agent "UI preferences" --top-k 10
# Full-text search within an agent's memories
dk memory search my-agent "dark mode" --top-k 5
# Get a specific memory by ID
dk memory get my-agent mem-abc123
# Update a memory
dk memory update my-agent mem-abc123 --content "Updated content"
# Delete a single memory
dk memory forget my-agent mem-abc123
# Batch delete by filters (dry-run first!)
dk memory batch-forget my-agent --min-importance 0.3 --dry-run
dk memory batch-forget my-agent --min-importance 0.3 --max-age-days 90
# Update importance scores
dk memory importance my-agent --ids mem-1,mem-2 --value 0.9
# Consolidate similar memories into summaries
dk memory consolidate my-agent --dry-run
# Submit recall quality feedback
dk memory feedback my-agent mem-abc123 "Highly relevant" --score 1.0Full-text (BM25) search across memories.
# Search all namespaces
dk text search "machine learning"
# Search within a specific namespace
dk text search "temporal reasoning" --namespace my-ns --limit 20Manage agent sessions.
dk session start my-agent
dk session end sess-abc123
dk session list --agent-id my-agent --active-only
dk session get sess-abc123
dk session memories sess-abc123View and manage agents.
dk agent list
dk agent stats my-agent
dk agent memories my-agent --type episodic --limit 20
dk agent sessions my-agent --active-onlyKnowledge graph management and memory summarization.
# Build a knowledge graph from a memory
dk knowledge graph my-agent --memory-id mem-abc123 --depth 3
# Full knowledge graph for an agent
dk knowledge full-graph my-agent --max-nodes 100
# Summarize a set of memories into a new memory
dk knowledge summarize my-agent --memory-ids m1,m2,m3 --dry-run
# Find and remove duplicate memories
dk knowledge deduplicate my-agent --threshold 0.9 --dry-runIndex management.
dk index stats --namespace my-ns
dk index fulltext-stats --namespace my-ns
dk index rebuild --namespace my-ns --dry-run
dk index rebuild --namespace my-ns --index-type vector --yesAPI key management.
dk keys list
dk keys create my-key --permissions read,write
dk keys delete key-abc123
dk keys usage key-abc123Cluster administration, caching, backups, and server configuration.
# Cluster overview
dk admin cluster-status
dk admin cluster-nodes
# Namespace index management
dk admin optimize my-ns
dk admin index-stats my-ns
dk admin rebuild-indexes my-ns
# Cache management
dk admin cache-stats
dk admin cache-clear
dk admin cache-clear --namespace my-ns
# Server configuration
dk admin config-get
dk admin config-set --key max_connections --value 100
# Namespace quotas
dk admin quotas-get
dk admin quotas-set --data '{"max_memories": 10000}'
# Performance diagnostics
dk admin slow-queries --limit 10Show or manage connection profiles.
dk config
dk config profile add staging --url http://staging:3000
dk config profile use staging
dk config profile listGenerate shell completion scripts.
dk completion bash --install
dk completion zsh --install
dk completion fish --install
dk completion powershell| Code | Meaning |
|---|---|
| 0 | Success |
| 1 | General error |
| 2 | Connection error (server unreachable) |
| 3 | Not found |
| 4 | Permission denied / authentication failure |
| 5 | Invalid input |
| 6 | Server-side error (5xx) |
Scripts can check $? after each command.
| Repo | What it is |
|---|---|
| dakera-py | Python SDK |
| dakera-js | TypeScript SDK |
| dakera-mcp | MCP server · 14 core tools (86+ via profiles) |
| dakera-deploy | Self-host Dakera |
dakera.ai · Documentation · Request Early Access
Part of the Dakera AI open-source ecosystem. Built with Rust. Self-hosted. Zero dependencies.