Разработка блокчейн-проекта

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Разработка блокчейн-проекта
Сложная
от 2 недель до 3 месяцев
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1240
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1167
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    867
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1084
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    563
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    829

Разработка блокчейн-проекта

"Блокчейн-проект" — намеренно широкое определение. Прежде чем говорить о технологиях, нужно ответить на конкретный вопрос: что именно блокчейн решает в вашем продукте, чего не решает традиционная база данных? Если ответ размытый — скорее всего, вам нужна просто распределённая система, а не блокчейн. Если ответ чёткий — trustless исполнение логики, верифицируемость данных, токенизация активов, permissionless участие — тогда начинаем проектировать.

Выбор блокчейна: архитектурное решение с долгосрочными последствиями

Не существует "лучшего блокчейна" — есть правильный для конкретного use case.

EVM-совместимые сети

Ethereum mainnet — максимальная decentralization и security, development tooling первого уровня (Foundry, Hardhat, Slither, Echidna). Оправдан для: протоколов с большими TVL, где безопасность > стоимости; финансовых примитивов, которые должны быть composable с DeFi экосистемой.

Arbitrum / Optimism — Optimistic Rollups. EVM-эквивалентность (Arbitrum One) или EVM-совместимость (OP Stack). Gas в 10–50x дешевле mainnet, finality ~7 дней для withdrawals (fraud proof window). Оправдан для приложений с высокой частотой транзакций: trading, gaming, социальные приложения.

Base — OP Stack L2 от Coinbase. Быстро растущая экосистема, хороший onramp через Coinbase. Подходит для consumer-facing приложений.

Polygon PoS — не L2, а sidechain с мостом к Ethereum. Быстро, дёшево, но иная модель безопасности. Хорош для NFT-проектов с частыми транзакциями.

zkSync Era / Polygon zkEVM / Scroll — ZK Rollups. Более строгие гарантии безопасности чем Optimistic (нет fraud window), но ZK proofs создают overhead на execution. zkSync имеет Native Account Abstraction (AA) на уровне протокола — это important архитектурное преимущество для UX.

Не-EVM

Solana — high throughput (65k TPS теоретически, ~3–5k TPS реально), параллельное выполнение транзакций через Sealevel, низкие комиссии. Программирование на Rust через Anchor framework. Tooling значительно менее зрелый чем EVM, debugger примитивный, ошибки хуже читаются. Оправдан для: high-frequency trading, gaming с real-time механиками, приложений где gas cost критичен.

TON — нативная интеграция с Telegram (900M MAU). FunC/Tact для смарт-контрактов. Если ваша аудитория в Telegram — серьёзный аргумент в пользу TON.

Cosmos SDK — для случаев, когда нужен собственный blockchain (application-specific chain). IBC для межсетевого взаимодействия. Высокий порог входа, но полный контроль над консенсусом, governance, gas token.

Смарт-контракты: от архитектуры до деплоя

Паттерны архитектуры

Proxy upgradeable patterns — большинство production контрактов используют апгрейдимость. Три основных паттерна:

  • Transparent Proxy (OpenZeppelin) — admin и пользователи вызывают разные функции. Проблема: admin не может использовать протокол как пользователь.
  • UUPS (EIP-1822) — upgrade логика в implementation контракте. Меньше gas overhead, более гибко. Риск: если задеплоить implementation без upgrade функции — контракт навсегда залочится.
  • Diamond (EIP-2535) — множество "facets" (реализаций) за одним прокси. Решает лимит размера контракта (24KB), но сложно в аудите.

Для большинства проектов — UUPS через @openzeppelin/contracts-upgradeable это правильный выбор.

Access control — не Ownable, а AccessControl от OpenZeppelin для проектов с несколькими ролями:

bytes32 public constant ADMIN_ROLE = keccak256("ADMIN_ROLE");
bytes32 public constant OPERATOR_ROLE = keccak256("OPERATOR_ROLE");
bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

Pausable — аварийная пауза всегда нужна в DeFi контрактах. Паузер должен быть multisig или timelock, не EOA.

Типичные уязвимости

За годы работы с аудитами, вот что встречается чаще всего:

Reentrancy — классика. В 2024 году всё ещё встречается. Защита: ReentrancyGuard от OZ + CEI паттерн (Checks-Effects-Interactions):

// НЕПРАВИЛЬНО:
function withdraw(uint256 amount) external {
    token.transfer(msg.sender, amount); // interaction до effect
    balances[msg.sender] -= amount;     // effect после
}

// ПРАВИЛЬНО:
function withdraw(uint256 amount) external nonReentrant {
    balances[msg.sender] -= amount;     // effect
    token.transfer(msg.sender, amount); // interaction
}

Price manipulation через flash loans — если контракт читает цену из Uniswap spot price. Решение: TWAP (Time-Weighted Average Price) через IUniswapV3Pool.observe() или Chainlink Price Feed.

Integer overflow/underflow — в Solidity 0.8.x встроенная защита, но при unchecked блоках и при кастомной математике с downcast — всё ещё актуально.

Signature replay — при использовании ecrecover без nonce или chain ID в подписанном сообщении. EIP-712 + EIP-2612 (Permit) решают это стандартным способом.

Front-running — MEV. Для AMM-подобных контрактов: deadline + slippage tolerance. Для сенситивных операций: commit-reveal схема.

Инструментарий разработки

Foundry — предпочтительный инструмент для серьёзной разработки. Тесты на Solidity, fuzz testing из коробки, форки mainnet в один флаг:

forge test --fork-url $ETH_RPC --fork-block-number 19000000 -vvv

Fuzz тестирование находит edge cases, которые ручные тесты пропускают:

function testFuzz_deposit(uint256 amount) public {
    amount = bound(amount, 1, type(uint128).max); // разумные границы
    deal(address(token), user, amount);
    vm.prank(user);
    vault.deposit(amount, user);
    assertEq(vault.totalAssets(), amount);
}

Slither — статический анализатор. Запускаем в CI на каждый PR, критические находки блокируют мерж.

Echidna — property-based fuzzer. Для инвариантов: "totalSupply всегда равен сумме всех балансов", "здоровье протокола никогда не уходит в минус".

Инфраструктура и DevOps

Деплой и мультисиг

Никаких деплоев с EOA в production. Схема:

Developer EOA → Gnosis Safe 3/5 multisig → Timelock (48h delay) → Contract

Timelock даёт пользователям время среагировать на вредоносный апгрейд. Для DeFi протоколов с TVL > $1M — обязателен.

Hardhat Ignition или Foundry Deploy Scripts для воспроизводимых деплоев. Все параметры деплоя — в version control, не в головах разработчиков.

Мониторинг on-chain

OpenZeppelin Defender — мониторинг транзакций, автоматические реакции (пауза при аномалии), безопасное управление ключами для автоматизации.

Tenderly — симуляция транзакций, алерты, debugger. Незаменим для отладки сложных multicontract взаимодействий.

The Graph — индексирование событий для фронтенда и аналитики. Subgraph пишется один раз, деплоится в decentralized network, данные доступны через GraphQL.

Аудит

Аудит — не финальный шаг, а часть процесса. Для серьёзных протоколов: внутренний review (Slither + Echidna + ручной анализ) → предварительный аудит от одной фирмы → основной аудит → исправление находок → повторный аудит изменений. Сроки: 4–8 недель для типичного DeFi протокола средней сложности. Бюджет: $20k–$150k в зависимости от аудитора (Trail of Bits, Spearbit, Code4rena contest).

Этапы проекта

Фаза Содержание Срок
Architecture & design Выбор сети, архитектура контрактов, tokenomics 1–2 нед
Core contracts Разработка и unit тесты 2–6 нед
Integration testing Fork tests, integration сценарии 1–2 нед
Frontend dApp, wallet integration 2–6 нед
Audit Внешний аудит + исправления 4–8 нед
Testnet deployment Публичный тестнет, bug bounty 2–4 нед
Mainnet Деплой, мониторинг 1 нед

Реалистичный срок от идеи до mainnet: 3–6 месяцев для протокола средней сложности. Проекты, которые "запускаются за 2 недели", обычно имеют незакрытые критические уязвимости.