Skip to main content

Documentation Index

Fetch the complete documentation index at: https://docs.agno.com/llms.txt

Use this file to discover all available pages before exploring further.

Agents can persist every data point they generate and use in a database, set by the db param. We can store sessions, memory, knowledge, traces, schedules, approvals, learnings and even usage metrics. The primitives (agents, teams, workflows) and the AgentOS accept a db param. Pick from JSON files (local or cloud), embedded (SQLite), relational (Postgres, MySQL), document (MongoDB), key-value (Redis, DynamoDB, Firestore), or distributed (SingleStore).
from agno.db.postgres import PostgresDb
from agno.os import AgentOS

db = PostgresDb(db_url="postgresql://user:pass@host:5432/agno")

agent_os = AgentOS(agents=[agent], db=db)
When we set the db param, AgentOS creates the tables and indexes on first boot.

What gets stored

TableHolds
agno_sessionsConversation history per (user_id, session_id)
agno_memoriesUser memories the agent decides to keep
agno_knowledgeEmbeddings
agno_traces, agno_spansOpenTelemetry traces
agno_approvalsPending and resolved HITL requests
agno_schedules, agno_schedule_runsCron jobs
agno_metrics, agno_eval_runsMetrics and eval results
  • Backend-specific names may vary.
  • Schema changes are generally additive.

Pick a backend

PostgresDb is the default for most tutorials and the recommended production database. It pairs well with PgVector to keep relational data and embeddings on the same engine.
BackendWhen to use
PostgresDbProduction. Vector + relational on one box.
SqliteDbLocal dev, single-user demos, edge deployments
MongoDbAlready on Mongo
MySQLDbAlready on MySQL
SingleStoreDbVector + analytics on one engine, high-throughput
RedisDbCache-friendly, ephemeral sessions
DynamoDbAWS-native, serverless
FirestoreDbGCP-native, serverless
GCSJsonDbCheap cold storage, knowledge as JSON in Cloud Storage
InMemoryDbTests, ephemeral demos
Postgres-compatible managed services like Neon and Supabase work with PostgresDb directly. Point db_url at the managed instance. Async variants (AsyncPostgresDb, AsyncSqliteDb, AsyncMongoDb, AsyncMySQLDb) are documented under Database.

Vector storage

Knowledge needs a vector store and agno supports every vector database out of the box.
from agno.knowledge import Knowledge
from agno.vectordb.pgvector import PgVector

agent = Agent(
    db=db,
    knowledge=Knowledge(
        vector_db=PgVector(
            table_name="my_kb",
            db_url=DB_URL,
            search_type="hybrid",   # vector + BM25
        ),
    ),
)
Other options: LanceDB, Qdrant, Weaviate, Pinecone, Chroma, MongoDB Atlas, Cosmos, Cassandra, ClickHouse, SurrealDB, Milvus. See Vector Stores. For most production AgentOS deployments, PgVector + PostgresDb on the same Postgres is the right default. One database, hybrid search, transactional reads, no extra service to operate.

Splitting concerns across databases

Every agent, team, and workflow can take its own db, overriding the AgentOS default. Use the AgentOS db for shared state and hand individual components a separate database when they need isolation:
shared_db = PostgresDb(db_url="postgresql://shared/...")
tenant_db = PostgresDb(db_url="postgresql://tenant-a/...")

tenant_agent = Agent(name="tenant-a-support", db=tenant_db, ...)
internal_agent = Agent(name="ops", db=shared_db, ...)

agent_os = AgentOS(
    agents=[tenant_agent, internal_agent],
    db=shared_db,
)
Common splits: per-tenant DBs for strict isolation, a high-traffic agent on its own engine, or routing one workflow’s session history to a cheaper backend.

File and blob storage

For media that doesn’t belong in the relational store (generated images, audio, large PDFs), store them in object storage and reference paths in agno_knowledge or agno_sessions.