Use DBOS With Pydantic AI
Pydantic AI is a Python agent framework for building production-grade applications and workflows powered by Generative AI.
Also check out the integration guide in the Pydantic docs!
This guide shows you how to build a durable AI agent with DBOS and Pydantic AI. By combining the two, you can build reliable agents that preserve progress across transient API failures, application errors, and restarts, while also handling long-running, asynchronous, and human-in-the-loop workflows with production-grade reliability.
Overview
Pydantic AI has native support for DBOS agents. The diagram below shows the architecture of an agentic application built with DBOS. DBOS runs fully in-process as a library: functions remain standard Python functions but are checkpointed to a database for durability.
                      Clients
              (HTTP, RPC, Kafka, etc.)
                          |
                          v
  +------------------------------------------------------+
  |               Application Servers                    |
  |                                                      |
  |   +----------------------------------------------+   |
  |   |        Pydantic AI + DBOS Libraries          |   |
  |   |                                              |   |
  |   |  [ Workflows (Agent Run Loop) ]              |   |
  |   |  [ Steps (Tool, MCP, Model) ]                |   |
  |   |  [ Queues ]   [ Cron Jobs ]   [ Messaging ]  |   |
  |   +----------------------------------------------+   |
  |                                                      |
  +------------------------------------------------------+
                          |
                          v
  +------------------------------------------------------+
  |                      Database                        |
  |   (Stores workflow and step state, schedules tasks)  |
  +------------------------------------------------------+
Any Pydantic AI agent can be wrapped in a DBOSAgent to enable durable execution. DBOSAgent automatically:,
- Wraps Agent.runandAgent.run_sync(the agent's main loop) as DBOS workflows.
- Wraps model requests and MCP communication as DBOS steps.
Custom tool functions and event stream handlers are not automatically wrapped by DBOS. You can decide how to integrate them:
- Decorate with @DBOS.stepif the function involves non-determinism or I/O.
- Skip the decorator if durability isn't needed (e.g., debug logging), to avoid the extra DB checkpoint write.
- If the function needs to enqueue tasks or invoke other DBOS workflows, skip the decorator so it runs inside the agent's main workflow (not as a step).
The original agent, model, and MCP server can still be used normally outside the DBOS agent.
Installation and Requirements
Simply install Pydantic AI with the DBOS optional dependency:
- pip
- uv
pip install pydantic-ai[dbos]
uv add pydantic-ai[dbos]
Or if you're using the slim package, you can install it with the DBOS optional dependency:
- pip
- uv
pip install pydantic-ai-slim[dbos]
uv add pydantic-ai-slim[dbos]
Using DBOS Agent
Here is a simple but complete example of wrapping an agent for durable execution. With fewer than 10 additional lines (highlighted below), you can add DBOS into an existing Pydantic AI application.
import asyncio
from dbos import DBOS, DBOSConfig
from pydantic_ai import Agent
from pydantic_ai.durable_exec.dbos import DBOSAgent
dbos_config: DBOSConfig = {
    'name': 'pydantic_dbos_agent',
    'system_database_url': 'sqlite:///dbostest.sqlite',
}
DBOS(config=dbos_config)
agent = Agent(
    'gpt-5',
    instructions="You're an expert in geography.",
    name='geography',
)
dbos_agent = DBOSAgent(agent)
async def main():
    DBOS.launch()
    result = await dbos_agent.run('What is the capital of Mexico?')
    print(result.output)
    #> Mexico City (Ciudad de México, CDMX)
if __name__ == "__main__":
    asyncio.run(main())
Notes:
- Workflows and DBOSAgentmust be defined beforeDBOS.launch()so that recovery can correctly find all workflows.
- DBOSAgent.run()works like- Agent.run(), but runs as a DBOS workflow and executes model requests, decorated tool calls, and MCP communication as DBOS steps.
- This example uses SQLite for simplicity. Postgres is recommended for production.
- Each agent must have a unique name, which DBOS uses to identify its workflows.
For more details on building agents, see the Pydantic AI documentation. For information about durable execution and workflow design, see the DBOS programming guide. Together, these resources cover everything from getting started with simple agents to designing production-ready, fault-tolerant applications.