DB
driver and Agno handles the rest. You can use Sqlite, Postgres, Mongo or any other database you want.
Here’s a simple example that demonstrates persistence across execution cycles:
storage.py
Benefits of Storage
Storage has typically been an under-discussed part of Agent Engineering — but we see it as the unsung hero of production agentic applications. In production, you need storage to:- Continue sessions: retrieve session history and pick up where you left off.
- Get list of sessions: To continue a previous session, you need to maintain a list of sessions available for that agent.
- Save session state between runs: save the Agent’s state to a database or file so you can inspect it later.
- Storage saves our Agent’s session data for inspection and evaluations, including session metrics.
- Storage helps us extract few-shot examples, which can be used to improve the Agent.
- Storage enables us to build internal monitoring tools and dashboards.
Storage is such a critical part of your Agentic infrastructure that it should never be offloaded to a third party. You should almost always use your own storage layer for your Agents.
Session table schema
If you have adb
configured for your agent, the sessions will be stored in the a sessions table in your database.
The schema for the sessions table is as follows:
Field | Type | Description |
---|---|---|
session_id | str | The unique identifier for the session. |
session_type | str | The type of the session. |
agent_id | str | The agent ID of the session. |
team_id | str | The team ID of the session. |
workflow_id | str | The workflow ID of the session. |
user_id | str | The user ID of the session. |
session_data | dict | The data of the session. |
agent_data | dict | The data of the agent. |
team_data | dict | The data of the team. |
workflow_data | dict | The data of the workflow. |
metadata | dict | The metadata of the session. |
runs | list | The runs of the session. |
summary | dict | The summary of the session. |
created_at | int | The timestamp when the session was created. |
updated_at | int | The timestamp when the session was last updated. |
Developer Resources
- View the Agent schema
- View Examples
- View Cookbook