layero deploy
Упаковывает cwd и публикует его как новый деплой проекта. Git и GitHub не требуются — CLI заливает локальную директорию напрямую.
Базовое использование
cd my-site
npx layero deploy
Что происходит:
- CLI авто-детектит фреймворк (
package.json, конфиги типаvite.config.ts/next.config.js) — заполняетframework_hint/build_cmd/output_dirесли они ещё не заданы в.layero/project.json. - Обходит cwd, применяет правила игнорирования (см. ниже), пакует в tar.gz во временной директории и считает sha256 на лету.
- Архив заливается в Yandex Object Storage по presigned URL.
- Бэкенд создаёт деплой и запускает сборку.
- CLI поллит логи деплоя (
/deploys/{id}/logs) до статусаreadyилиfailed, выводя их в терминал. - По окончании печатается ссылка — preview или production URL.
Первый layero deploy в новой папке создаст проект и запишет ./.layero/project.json. Последующие запуски используют тот же проект — никакого визарда в браузере, никакой ручной привязки.
Авто-детект фреймворка
CLI читает package.json и характерные конфиги:
| Сигнал | Фреймворк | build_cmd | output_dir |
|---|---|---|---|
next в deps / next.config.* | nextjs | npm run build (или npx next build) | out |
nuxt в deps / nuxt.config.* | nuxt | npm run generate если есть, иначе npm run build | .output/public |
@sveltejs/kit / svelte.config.js | sveltekit | npm run build | build |
gatsby в deps | gatsby | npm run build | public |
astro в deps / astro.config.* | astro | npm run build | dist |
@docusaurus/core / docusaurus.config.* | docusaurus | npm run build | build |
vite в deps / vite.config.* | vite | npm run build | dist |
react-scripts в deps | cra | npm run build | build |
.html в корне, нет package.json | static | true (no-op) | . |
Если детект ошибся — отредактируйте .layero/project.json вручную или передайте --type явно.
Эти значения хранятся в .layero/project.json после первого деплоя. Они переживают повторные запуски и редактируются вручную.
Флаги
| Флаг | Описание |
|---|---|
--prod | Деплой приземляется в default-ветку проекта (то же что push в main). Если у проекта включён auto-promote — apex переключится на свежий билд автоматически. |
--promote | После успешного билда сразу двигает production_deploy_id на этот деплой. Работает для любой ветки — удобно чтобы выкатить feature-ветку в production одной командой. |
--branch <name> | Деплой в конкретную ветку (создаст окружение, если не было). Без флага CLI кладёт в псевдо-ветку cli. |
--type <preset> | Оверрайд авто-детекта: vite, next, astro, cra, sveltekit, nuxt, gatsby, docusaurus, static. |
--name <name> | Имя проекта. Только при первом деплое. |
--project <id_or_slug> | Деплоить в конкретный проект, игнорируя ./.layero/project.json. Удобно для CI. |
--org <slug> | Создать проект в указанной Layero-организации (при первом деплое). |
--yes, -y | Пропустить подтверждение --prod / --promote и интерактивные вопросы. |
--json | JSON-lines на stdout (для AI-агентов и CI). |
--config | Legacy alias текущего поведения (авто-детект + .layero/project.json). |
Куда приземляется деплой
# preview на CLI-pseudo-ветку — изолированный URL, не трогает apex
npx layero deploy
# → https://<org>-<project>-cli.preview.layero.ru (24 ч TTL)
# preview на конкретную ветку
npx layero deploy --branch=staging
# → https://<org>-<project>-staging.preview.layero.ru (24 ч TTL)
# деплой в default-ветку проекта (push-эквивалент)
# если auto-promote включён → apex переключится автоматом
# CLI спросит: deploy to production? [y/N]
npx layero deploy --prod
# выкатить из любой ветки сразу в production одной командой
# (промоут идёт сразу после успешного билда, без полной поездки CI)
npx layero deploy --branch=staging --promote
# → apex: https://<org>-<project>.layero.ru теперь отдаёт этот деплой
# CI-режим: без подтверждения
npx layero deploy --prod --yes
Чем --prod отличается от --promote:
--prod= «положи на default-ветку». Дальше за apex отвечает либо auto-promote (если включён в Settings), либо ваш ручной клик «Promote».--promote= «после того как соберётся, переведи apex на этот деплой». Работает для любой ветки — короткий путь «hot-fix из feature-ветки → production».
Обычно одно из двух: либо --prod --yes в CI на пуш в main, либо --branch=hot-fix --promote --yes для срочного фикса.
Зачем псевдо-ветка cli: локальные эксперименты не должны случайно затронуть production. По умолчанию layero deploy уходит в изолированный cli-env с preview-URL — apex остаётся нетронутым.
Mixed-mode: GitHub + CLI на одном проекте
Один и тот же проект может одновременно принимать:
- push в GitHub → автоматический деплой (webhook)
layero deploy→ CLI-загрузка тарбола
GitHub-интеграция — необязательна. Первый деплой через CLI не требует ни git-репозитория, ни GitHub-аккаунта. Подключить GitHub можно потом, через дашборд, если захочется auto-deploy on push.
Mixed-mode удобен, когда:
- GitHub-build долгий или нестабильный, и нужен быстрый локальный hot-fix:
layero deploy --prod --yesподнимет ваш локальный код в production за секунды без коммита. - В CI после успешного теста хочется явно зафиксировать релиз:
layero deploy --prod --yesпослеgit push.
Артефакты в дашборде помечаются источником:
| Бейдж | Что значит |
|---|---|
push | Webhook от GitHub push |
cli | Загружен через layero deploy |
manual | Запущен через дашборд (Redeploy) |
Пример CI-сборки:
LAYERO_TOKEN=$LAYERO_DEPLOY_TOKEN npx layero deploy --prod --yes \
--project alice-my-site
JSON-режим для агентов и CI
Любая команда CLI поддерживает --json (или LAYERO_JSON=1):
npx layero deploy --json
Каждая строка stdout — JSON-объект с полем event:
{"event":"detected","framework":"vite","build_cmd":"npm run build","output_dir":"dist","confident":true}
{"event":"project_created","project_id":"...","slug":"my-site","organization":"alice"}
{"event":"packing","files":124,"bytes":2401234,"sha256":"..."}
{"event":"uploading"}
{"event":"deploy_started","deploy_id":"..."}
{"event":"build_log","line":"...","stream":"stdout"}
{"event":"ready","url":"https://alice-my-site-cli.preview.layero.ru","preview_url":"https://alice-my-site-cli.preview.layero.ru","deploy_id":"..."}
Ошибки приходят со стабильным code и next_action:
{"event":"error","code":"not_logged_in","next_action":"run: layero login","message":"not authenticated"}
Поле preview_url в ready событии — это всегда живая preview-ссылка ветки (*.preview.layero.ru), доступная через ~30 секунд после успешной сборки. Поле url — production-apex, если этот деплой стал production (через --prod + auto-promote, или --promote); иначе равно preview_url. Apex'у нужно 5–15 мин на первый прогрев CDN — пока он не готов, шерьте preview_url.
JSON-режим включается автоматически когда CLI запущен внутри Cursor / Claude Code / любого процесса с не-TTY stdout. Подробнее — Деплой из AI-агентов, полный список событий — JSON-events схема.
Правила игнорирования
CLI уважает:
.gitignore(как git).layeroignore(тот же синтаксис, можно расширять/исключать)- встроенный denylist:
node_modules.gitdistbuild.next.env*.DS_Store
Артефакты сборки (dist, build, .next) не нужно заливать — сборка запускается на стороне Layero после распаковки.
Лимиты
- Максимальный размер архива — 200 MB.
- Время
layero deployограничено таймаутами на бэкенде:Стадия Лимит clone / unpack 15 мин install 30 мин build 15 мин upload в S3 10 мин
Если ваш билд не укладывается — напишите в поддержку, лимиты повышаются индивидуально.
Окружение сборки
Каждая сборка запускается в изолированной песочнице на выделенной builder-VM:
- CPU / память: 2 vCPU, 4 GB RAM, swap до 4 GB, лимит процессов — 1024.
- Диск: writable scratch (
/mnt/scratch, ~40 GB на одну сборку), tmpfs/tmp256 MB. Кэшиnpm/yarn/pnpmавтоматически перенаправляются на scratch — большие бинарники (rolldown,swc,sharp) скачиваются без ENOSPC. - Сеть: разрешён исходящий HTTPS к npm-зеркалу, GitHub, реестрам пакетов (npm, yarn) и S3. Произвольные внешние эндпоинты с этапа сборки недоступны — это защищает чужие билды от случайного или вредоносного трафика. Если вашему билду нужен доступ к закрытому реестру или CDN, напишите в поддержку.
- Изоляция: gVisor (
runsc) + seccomp + drop-all capabilities + read-only rootfs. Сборки разных проектов не видят друг друга и не имеют доступа к инфраструктуре Layero.
Среда не персистентна между билдами: всё, что вы записали в /tmp или /mnt/scratch, исчезает после завершения. Артефакты в output_dir (dist по умолчанию) загружаются в S3 и попадают в CDN.
После деплоя
После ready:
- Preview-URL ветки
https://<org>-<project>-<branch>.preview.layero.ruживёт через ~30 сек и работает 24 часа. - Apex
https://<org>-<project>.layero.ruотдаёт этот деплой если он стал production (auto-promote default-ветки или--promote). Если деплой остался в preview — apex продолжает отдавать предыдущий production-билд, а ваш текущий доступен только через preview-URL.
См. Окружения, preview и production для полной картины.
Postinstall-баннер
После npm install -g layero или npm install -D layero (без --silent) CLI пишет краткий quick-start в /dev/tty. В CI-окружениях баннер подавляется автоматически (CI=1). Чтобы выключить вручную:
LAYERO_SKIP_POSTINSTALL=1 npm install -D layero