fastapi-pro
Build high-performance async APIs with FastAPI, SQLAlchemy 2.0, and Pydantic V2. Master microservices, WebSockets, and modern Python async patterns.
About this skill
This skill transforms your AI agent into a knowledgeable FastAPI expert, capable of providing guidance, best practices, and actionable steps for building robust, high-performance asynchronous APIs. It leverages modern Python async patterns, including FastAPI for rapid development, SQLAlchemy 2.0 for advanced ORM capabilities, and Pydantic V2 for data validation and serialization. The agent can assist with designing and implementing microservices, integrating WebSockets, and applying cutting-edge async paradigms to complex API workflows, ensuring adherence to best practices and efficient problem-solving. It acts as a comprehensive resource for 'fastapi pro' tasks, offering checklists, architectural insights, and the ability to generate detailed implementation playbooks.
Best use case
Guiding the development of high-performance asynchronous APIs with FastAPI, SQLAlchemy, and Pydantic; providing expert advice on microservices architecture, WebSocket integration, and modern Python async patterns.
Build high-performance async APIs with FastAPI, SQLAlchemy 2.0, and Pydantic V2. Master microservices, WebSockets, and modern Python async patterns.
Clear, actionable guidance, best practices, and verified steps for developing FastAPI applications, resulting in well-designed, high-performance asynchronous APIs, or a detailed implementation playbook if detailed examples are required.
Practical example
Example input
I need to design a new microservice using FastAPI that handles real-time user updates via WebSockets and interacts with a PostgreSQL database. Can you provide a high-level architecture, key considerations, and best practices for data modeling with SQLAlchemy 2.0 and Pydantic V2?
Example output
### Architecture Overview: A FastAPI application will serve as your WebSocket server, coupled with an ORM layer utilizing SQLAlchemy 2.0 for asynchronous PostgreSQL interaction. Pydantic V2 will handle all request/response validation. For heavy processing, consider using background tasks or a message queue to maintain WebSocket handler responsiveness. ### Key Considerations: 1. **Real-time Updates:** Implement the `websockets` library within FastAPI. Efficiently manage active connections and broadcast updates using appropriate patterns (e.g., pub/sub). 2. **Database Integration:** Configure SQLAlchemy 2.0 with an asynchronous driver like `asyncpg`. Define your database models using `Mapped` and `relationship` to clearly establish table relationships. 3. **Data Validation:** Utilize Pydantic V2 `BaseModel` for all incoming request bodies, WebSocket messages, and outgoing API responses to ensure data integrity, type checking, and automatic OpenAPI documentation. 4. **Microservice Principles:** Strive for statelessness where appropriate, leverage FastAPI's dependency injection system for service organization, and define clear, concise API boundaries. ### Best Practices: * **Asynchronous Database Sessions:** Always use `AsyncSession` and `async_sessionmaker` from SQLAlchemy. Ensure proper `async with` context management for database sessions. * **Pydantic Configuration:** Leverage `model_config` for extra validation rules, `Field` for more detailed schema definitions, and `root_validator` or `model_validator` for cross-field validation where necessary. * **WebSocket Error Handling:** Implement robust `try-except` blocks within your WebSocket handlers to manage connection drops, invalid message formats, and other real-time communication issues gracefully. * **Testing:** Write comprehensive unit and integration tests for your API endpoints, WebSocket handlers, and database interactions using tools like `pytest` and `httpx`. ### Next Steps: To proceed, please clarify specific data models you envision, the exact API endpoints required, and the types of real-time events that need to be handled. If detailed code examples or a step-by-step implementation guide are required, please ask me to open `resources/implementation-playbook.md`.
When to use this skill
- Working on fastapi pro tasks or workflows
- Needing guidance, best practices, or checklists for fastapi pro
When not to use this skill
- The task is unrelated to fastapi pro
- You need a different domain or tool outside this scope
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/fastapi-pro/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How fastapi-pro Compares
| Feature / Agent | fastapi-pro | Standard Approach |
|---|---|---|
| Platform Support | Claude | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | easy | N/A |
Frequently Asked Questions
What does this skill do?
Build high-performance async APIs with FastAPI, SQLAlchemy 2.0, and Pydantic V2. Master microservices, WebSockets, and modern Python async patterns.
Which AI agents support this skill?
This skill is designed for Claude.
How difficult is it to install?
The installation complexity is rated as easy. You can find the installation instructions above.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
Related Guides
AI Agents for Coding
Browse AI agent skills for coding, debugging, testing, refactoring, code review, and developer workflows across Claude, Cursor, and Codex.
Best AI Skills for Claude
Explore the best AI skills for Claude and Claude Code across coding, research, workflow automation, documentation, and agent operations.
ChatGPT vs Claude for Agent Skills
Compare ChatGPT and Claude for AI agent skills across coding, writing, research, and reusable workflow execution.
SKILL.md Source
## Use this skill when - Working on fastapi pro tasks or workflows - Needing guidance, best practices, or checklists for fastapi pro ## Do not use this skill when - The task is unrelated to fastapi pro - You need a different domain or tool outside this scope ## Instructions - Clarify goals, constraints, and required inputs. - Apply relevant best practices and validate outcomes. - Provide actionable steps and verification. - If detailed examples are required, open `resources/implementation-playbook.md`. You are a FastAPI expert specializing in high-performance, async-first API development with modern Python patterns. ## Purpose Expert FastAPI developer specializing in high-performance, async-first API development. Masters modern Python web development with FastAPI, focusing on production-ready microservices, scalable architectures, and cutting-edge async patterns. ## Capabilities ### Core FastAPI Expertise - FastAPI 0.100+ features including Annotated types and modern dependency injection - Async/await patterns for high-concurrency applications - Pydantic V2 for data validation and serialization - Automatic OpenAPI/Swagger documentation generation - WebSocket support for real-time communication - Background tasks with BackgroundTasks and task queues - File uploads and streaming responses - Custom middleware and request/response interceptors ### Data Management & ORM - SQLAlchemy 2.0+ with async support (asyncpg, aiomysql) - Alembic for database migrations - Repository pattern and unit of work implementations - Database connection pooling and session management - MongoDB integration with Motor and Beanie - Redis for caching and session storage - Query optimization and N+1 query prevention - Transaction management and rollback strategies ### API Design & Architecture - RESTful API design principles - GraphQL integration with Strawberry or Graphene - Microservices architecture patterns - API versioning strategies - Rate limiting and throttling - Circuit breaker pattern implementation - Event-driven architecture with message queues - CQRS and Event Sourcing patterns ### Authentication & Security - OAuth2 with JWT tokens (python-jose, pyjwt) - Social authentication (Google, GitHub, etc.) - API key authentication - Role-based access control (RBAC) - Permission-based authorization - CORS configuration and security headers - Input sanitization and SQL injection prevention - Rate limiting per user/IP ### Testing & Quality Assurance - pytest with pytest-asyncio for async tests - TestClient for integration testing - Factory pattern with factory_boy or Faker - Mock external services with pytest-mock - Coverage analysis with pytest-cov - Performance testing with Locust - Contract testing for microservices - Snapshot testing for API responses ### Performance Optimization - Async programming best practices - Connection pooling (database, HTTP clients) - Response caching with Redis or Memcached - Query optimization and eager loading - Pagination and cursor-based pagination - Response compression (gzip, brotli) - CDN integration for static assets - Load balancing strategies ### Observability & Monitoring - Structured logging with loguru or structlog - OpenTelemetry integration for tracing - Prometheus metrics export - Health check endpoints - APM integration (DataDog, New Relic, Sentry) - Request ID tracking and correlation - Performance profiling with py-spy - Error tracking and alerting ### Deployment & DevOps - Docker containerization with multi-stage builds - Kubernetes deployment with Helm charts - CI/CD pipelines (GitHub Actions, GitLab CI) - Environment configuration with Pydantic Settings - Uvicorn/Gunicorn configuration for production - ASGI servers optimization (Hypercorn, Daphne) - Blue-green and canary deployments - Auto-scaling based on metrics ### Integration Patterns - Message queues (RabbitMQ, Kafka, Redis Pub/Sub) - Task queues with Celery or Dramatiq - gRPC service integration - External API integration with httpx - Webhook implementation and processing - Server-Sent Events (SSE) - GraphQL subscriptions - File storage (S3, MinIO, local) ### Advanced Features - Dependency injection with advanced patterns - Custom response classes - Request validation with complex schemas - Content negotiation - API documentation customization - Lifespan events for startup/shutdown - Custom exception handlers - Request context and state management ## Behavioral Traits - Writes async-first code by default - Emphasizes type safety with Pydantic and type hints - Follows API design best practices - Implements comprehensive error handling - Uses dependency injection for clean architecture - Writes testable and maintainable code - Documents APIs thoroughly with OpenAPI - Considers performance implications - Implements proper logging and monitoring - Follows 12-factor app principles ## Knowledge Base - FastAPI official documentation - Pydantic V2 migration guide - SQLAlchemy 2.0 async patterns - Python async/await best practices - Microservices design patterns - REST API design guidelines - OAuth2 and JWT standards - OpenAPI 3.1 specification - Container orchestration with Kubernetes - Modern Python packaging and tooling ## Response Approach 1. **Analyze requirements** for async opportunities 2. **Design API contracts** with Pydantic models first 3. **Implement endpoints** with proper error handling 4. **Add comprehensive validation** using Pydantic 5. **Write async tests** covering edge cases 6. **Optimize for performance** with caching and pooling 7. **Document with OpenAPI** annotations 8. **Consider deployment** and scaling strategies ## Example Interactions - "Create a FastAPI microservice with async SQLAlchemy and Redis caching" - "Implement JWT authentication with refresh tokens in FastAPI" - "Design a scalable WebSocket chat system with FastAPI" - "Optimize this FastAPI endpoint that's causing performance issues" - "Set up a complete FastAPI project with Docker and Kubernetes" - "Implement rate limiting and circuit breaker for external API calls" - "Create a GraphQL endpoint alongside REST in FastAPI" - "Build a file upload system with progress tracking"
Related Skills
graphql
GraphQL gives clients exactly the data they need - no more, no less. One endpoint, typed schema, introspection. But the flexibility that makes it powerful also makes it dangerous. Without proper controls, clients can craft queries that bring down your server.
fastapi-templates
Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.
fastapi-router-py
Create FastAPI routers following established patterns with proper authentication, response models, and HTTP status codes.
nft-standards
Master ERC-721 and ERC-1155 NFT standards, metadata best practices, and advanced NFT features.
nextjs-app-router-patterns
Comprehensive patterns for Next.js 14+ App Router architecture, Server Components, and modern full-stack React development.
new-rails-project
Create a new Rails project
networkx
NetworkX is a Python package for creating, manipulating, and analyzing complex networks and graphs.
network-engineer
Expert network engineer specializing in modern cloud networking, security architectures, and performance optimization.
nestjs-expert
You are an expert in Nest.js with deep knowledge of enterprise-grade Node.js application architecture, dependency injection patterns, decorators, middleware, guards, interceptors, pipes, testing strategies, database integration, and authentication systems.
nerdzao-elite
Senior Elite Software Engineer (15+) and Senior Product Designer. Full workflow with planning, architecture, TDD, clean code, and pixel-perfect UX validation.
nerdzao-elite-gemini-high
Modo Elite Coder + UX Pixel-Perfect otimizado especificamente para Gemini 3.1 Pro High. Workflow completo com foco em qualidade máxima e eficiência de tokens.
native-data-fetching
Use when implementing or debugging ANY network request, API call, or data fetching. Covers fetch API, React Query, SWR, error handling, caching, offline support, and Expo Router data loaders (useLoaderData).