Passer au contenu principal
Version : 9.x

pnpm deploy

Déployer un paquet à partir d'un espace de travail. Lors du déploiement, les fichiers du paquet déployé sont copiés dans le répertoire cible. All dependencies of the deployed package, including dependencies from the workspace, are installed inside an isolated node_modules directory at the target directory. Le répertoire cible contiendra un paquet portable qui pourra être copié sur un serveur et exécuté sans étapes supplémentaires.

Utilisation :

pnpm --filter=<deployed project name> deploy <target directory>

In case you build your project before deployment, also use the --prod option to skip devDependencies installation.

pnpm --filter=<deployed project name> --prod deploy <target directory>

Utilisation dans une image docker. Après avoir tout généré dans votre monorepo, faites ceci dans une deuxième image qui utilise votre image de base monorepo comme contexte de construction ou dans une étape de génération supplémentaire :

# syntax=docker/dockerfile:1.4

FROM workspace as pruned
RUN pnpm --filter <your package name> --prod deploy pruned

FROM node:18-alpine
WORKDIR /app

ENV NODE_ENV=production

COPY --from=pruned /app/pruned .

ENTRYPOINT ["node", "index.js"]

Options

--dev, -D

Only devDependencies are installed regardless of the NODE_ENV.

--no-optional

optionalDependencies are not installed.

--prod, -P

Packages in devDependencies won't be installed.

--filter &lt;package_selector>

Read more about filtering.

Fichiers inclus dans le projet déployé

Par défaut, tous les fichiers du projet sont copiés pendant le déploiement. The project's package.json may contain a "files" field to list the files and directories that should be copied.