pnpm deploy
Deploy a package from a workspace. During deployment, the files of the deployed package are copied to the target directory. All dependencies of the deployed package, including dependencies from the workspace, are installed inside an isolated node_modules
directory at the target directory. The target directory will contain a portable package that can be copied to a server and executed without additional steps.
Использование:
pnpm --filter=<deployed project name> deploy <target directory>
Если проект строите перед развертыванием, также используйте параметр --prod
, чтобы пропустить установку devDependencies
.
pnpm --filter=<имя развёртываемого проекта> --prod deploy <целевая директория>
Использование в образе docker. После построения всего в своем monorepo, сделайте это во втором образе, использующий базовый образ monorepo в качестве контекста сборки или в дополнительном этапе сборки:
# syntax=docker/dockerfile:1.4
FROM workspace as pruned
RUN pnpm --filter <имя вашего пакета> --prod deploy pruned
FROM node:18-alpine
WORKDIR /app
ENV NODE_ENV=production
COPY --from=pruned /app/pruned .
ENTRYPOINT ["node", "index.js"]
Опции
--dev, -D
Установить только devDependencies
, вне зависимости от NODE_ENV
.
--no-optional
Не устанавливать optionalDependencies
.
--prod, -P
Не устанавливать devDependencies
.
--filter <селектор пакета>
Файлы, включенные в развернутый проект
By default, all the files of the project are copied during deployment but this can be modified in one of the following ways which are resolved in order:
- The project's
package.json
may contain a "files" field to list the files and directories that should be copied. - If there is an
.npmignore
file in the application directory then any files listed here are ignored. - If there is a
.gitignore
file in the application directory then any files listed here are ignored.