Разработка бэкенда сайта на Python (FastAPI)

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.
Разработка и обслуживание любых видов сайтов:
Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

Это лишь некоторые из технических типов сайтов, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Разработка бэкенда сайта на Python (FastAPI)
Средняя
от 1 недели до 3 месяцев
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    874
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851

Разработка бэкенда сайта на Python (FastAPI)

FastAPI — современный Python-фреймворк, который строит API вокруг типов. Вы объявляете функцию с type hints, а FastAPI автоматически генерирует валидацию через Pydantic, OpenAPI-документацию и JSON Schema. Никакой ручной документации, никаких отдельных валидаторов — всё выводится из типов.

Производительность FastAPI на асинхронных операциях (I/O) сопоставима с Node.js. Для CPU-bound задач — отдельный вопрос, там нужны process pool или выгрузка в Celery.

Основы и структура эндпоинтов

from fastapi import FastAPI, Depends, HTTPException, Query, Path, status
from pydantic import BaseModel, EmailStr, Field
from typing import Optional, List
import uvicorn

app = FastAPI(
    title="My API",
    version="1.0.0",
    docs_url="/api/docs",
    redoc_url="/api/redoc"
)

class ProductCreate(BaseModel):
    name: str = Field(..., min_length=2, max_length=255)
    price: float = Field(..., gt=0)
    category_id: int
    description: Optional[str] = None

class ProductResponse(BaseModel):
    id: int
    name: str
    price: float
    category_id: int

    class Config:
        from_attributes = True  # позволяет создавать из ORM-объектов

@app.get('/api/v1/products', response_model=List[ProductResponse])
async def list_products(
    page: int = Query(1, ge=1),
    limit: int = Query(20, ge=1, le=100),
    category_id: Optional[int] = Query(None),
    db: AsyncSession = Depends(get_db)
):
    offset = (page - 1) * limit
    query = select(Product).offset(offset).limit(limit)
    if category_id:
        query = query.where(Product.category_id == category_id)
    result = await db.execute(query)
    return result.scalars().all()

@app.post('/api/v1/products', response_model=ProductResponse, status_code=status.HTTP_201_CREATED)
async def create_product(
    body: ProductCreate,
    current_user: User = Depends(require_role('admin')),
    db: AsyncSession = Depends(get_db)
):
    product = Product(**body.model_dump())
    db.add(product)
    await db.commit()
    await db.refresh(product)
    return product

Dependency Injection

DI в FastAPI работает через Depends — один из лучших механизмов в Python-экосистеме:

from fastapi.security import OAuth2PasswordBearer
from jose import jwt, JWTError
from sqlalchemy.ext.asyncio import AsyncSession, create_async_engine

# Подключение к БД на запрос
async_engine = create_async_engine(settings.DATABASE_URL, pool_size=10)

async def get_db():
    async with AsyncSession(async_engine) as session:
        try:
            yield session
        except Exception:
            await session.rollback()
            raise
        finally:
            await session.close()

# Аутентификация
oauth2_scheme = OAuth2PasswordBearer(tokenUrl='/api/auth/token')

async def get_current_user(
    token: str = Depends(oauth2_scheme),
    db: AsyncSession = Depends(get_db)
) -> User:
    try:
        payload = jwt.decode(token, settings.JWT_SECRET, algorithms=['HS256'])
        user_id: int = payload.get('sub')
    except JWTError:
        raise HTTPException(status_code=401, detail='Invalid token')

    user = await db.get(User, user_id)
    if not user or not user.is_active:
        raise HTTPException(status_code=401, detail='Inactive user')
    return user

def require_role(*roles: str):
    async def checker(user: User = Depends(get_current_user)) -> User:
        if user.role not in roles:
            raise HTTPException(status_code=403, detail='Insufficient permissions')
        return user
    return checker

SQLAlchemy 2.0 (async)

FastAPI хорошо работает с SQLAlchemy 2.0 в async-режиме:

from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column, relationship
from sqlalchemy import String, Numeric, ForeignKey, DateTime, func

class Base(DeclarativeBase):
    pass

class Product(Base):
    __tablename__ = 'products'

    id: Mapped[int] = mapped_column(primary_key=True)
    name: Mapped[str] = mapped_column(String(255))
    slug: Mapped[str] = mapped_column(String(255), unique=True)
    price: Mapped[float] = mapped_column(Numeric(10, 2))
    category_id: Mapped[int | None] = mapped_column(ForeignKey('categories.id'), nullable=True)
    created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())

    category: Mapped['Category'] = relationship(back_populates='products', lazy='selectin')

lazy='selectin' для связей — лучший выбор в async-режиме, избегает N+1 без явных join.

Фоновые задачи

Простые задачи — через BackgroundTasks, тяжёлые — через Celery:

from fastapi import BackgroundTasks
import asyncio

# Лёгкие async-задачи прямо в запросе
@app.post('/api/orders/{order_id}/confirm')
async def confirm_order(
    order_id: int,
    background_tasks: BackgroundTasks,
    db: AsyncSession = Depends(get_db)
):
    order = await get_order_or_404(order_id, db)
    order.status = 'confirmed'
    await db.commit()

    # Не ждём завершения
    background_tasks.add_task(send_confirmation_email, order.user.email, order_id)
    background_tasks.add_task(update_inventory, order.items)

    return {'status': 'confirmed'}

# Тяжёлые задачи — Celery
from celery import Celery

celery = Celery(__name__, broker=settings.REDIS_URL)

@celery.task(name='generate_report')
def generate_report(user_id: int, date_range: dict):
    # CPU-интенсивная обработка
    pass

Middleware и CORS

from fastapi.middleware.cors import CORSMiddleware
from fastapi.middleware.gzip import GZipMiddleware
import time

app.add_middleware(GZipMiddleware, minimum_size=1000)
app.add_middleware(
    CORSMiddleware,
    allow_origins=settings.ALLOWED_ORIGINS,
    allow_credentials=True,
    allow_methods=['*'],
    allow_headers=['*']
)

@app.middleware('http')
async def add_process_time(request: Request, call_next):
    start = time.perf_counter()
    response = await call_next(request)
    duration = time.perf_counter() - start
    response.headers['X-Process-Time'] = str(round(duration * 1000, 2))
    return response

WebSocket

from fastapi import WebSocket, WebSocketDisconnect

class ConnectionManager:
    def __init__(self):
        self.active: dict[int, list[WebSocket]] = {}

    async def connect(self, user_id: int, ws: WebSocket):
        await ws.accept()
        self.active.setdefault(user_id, []).append(ws)

    async def broadcast_to_user(self, user_id: int, message: dict):
        for ws in self.active.get(user_id, []):
            await ws.send_json(message)

manager = ConnectionManager()

@app.websocket('/ws/notifications')
async def notifications_ws(
    websocket: WebSocket,
    token: str = Query(...),
):
    user = await verify_ws_token(token)
    await manager.connect(user.id, websocket)
    try:
        while True:
            await websocket.receive_text()  # держим соединение
    except WebSocketDisconnect:
        manager.disconnect(user.id, websocket)

Развёртывание

FastAPI запускается через Uvicorn или Gunicorn с Uvicorn workers:

# Production: несколько воркеров
gunicorn app.main:app \
  -w 4 \
  -k uvicorn.workers.UvicornWorker \
  --bind 0.0.0.0:8000 \
  --timeout 30 \
  --keepalive 5

Сроки разработки

  • Каркас + модели + auth — 4–7 дней
  • API endpoints + валидация — 1–2 недели
  • Интеграции и фоновые задачи — 1–2 недели
  • Тесты (pytest + httpx AsyncClient) — 5–7 дней

API для сайта среднего масштаба: 4–8 недель. FastAPI выигрывает, когда команда знает Python и нужна автодокументация — Swagger/ReDoc генерируется из кода без усилий.