UNPKG

5.99 kBMarkdownView Raw
1[中文](https://pnpm.io/zh/) | [Español](https://pnpm.io/es/)
2
3![](https://i.imgur.com/qlW1eEG.png)
4
5Fast, disk space efficient package manager:
6
7* **Fast.** Up to 2x faster than the alternatives (see [benchmark](#benchmark)).
8* **Efficient.** Files inside `node_modules` are linked from a single content-addressable storage.
9* **[Great for monorepos](https://pnpm.io/workspaces).**
10* **Strict.** A package can access only dependencies that are specified in its `package.json`.
11* **Deterministic.** Has a lockfile called `pnpm-lock.yaml`.
12* **Works everywhere.** Supports Windows, Linux, and macOS.
13* **Battle-tested.** Used in production by teams of [all sizes](https://pnpm.io/users) since 2016.
14
15To quote the [Rush](https://rushjs.io/) team:
16
17> Microsoft uses pnpm in Rush repos with hundreds of projects and hundreds of PRs per day, and we’ve found it to be very fast and reliable.
18
19[![npm version](https://img.shields.io/npm/v/pnpm.svg)](https://www.npmjs.com/package/pnpm)
20[![Join the chat at Discord](https://img.shields.io/discord/731599538665553971.svg)](https://r.pnpm.io/chat)
21[![OpenCollective](https://opencollective.com/pnpm/backers/badge.svg)](#backers)
22[![OpenCollective](https://opencollective.com/pnpm/sponsors/badge.svg)](#sponsors)
23[![Twitter Follow](https://img.shields.io/twitter/follow/pnpmjs.svg?style=social&label=Follow)](https://twitter.com/pnpmjs)
24
25## Background
26
27pnpm uses a content-addressable filesystem to store all files from all module directories on a disk.
28When using npm or Yarn, if you have 100 projects using lodash, you will have 100 copies of lodash on disk.
29With pnpm, lodash will be stored in a content-addressable storage, so:
30
311. If you depend on different versions of lodash, only the files that differ are added to the store.
32 If lodash has 100 files, and a new version has a change only in one of those files,
33 `pnpm update` will only add 1 new file to the storage.
341. All the files are saved in a single place on the disk. When packages are installed, their files are linked
35 from that single place consuming no additional disk space. Linking is performed using either hard-links or reflinks (copy-on-write).
36
37As a result, you save gigabytes of space on your disk and you have a lot faster installations!
38If you'd like more details about the unique `node_modules` structure that pnpm creates and
39why it works fine with the Node.js ecosystem, read this small article: [Flat node_modules is not the only way](https://pnpm.io/blog/2020/05/27/flat-node-modules-is-not-the-only-way).
40
41## Installation
42
43On macOS, Linux, or Windows Subsystem for Linux:
44
45```
46curl -f https://get.pnpm.io/v6.js | node - add --global pnpm
47```
48
49On Windows (using PowerShell):
50
51```
52(Invoke-WebRequest 'https://get.pnpm.io/v6.js' -UseBasicParsing).Content | node - add --global pnpm
53```
54
55Using npm:
56
57```
58npx pnpm add -g pnpm
59```
60
61For other installation options [visit our website](https://pnpm.io/installation).
62
63## Usage
64
65Just use pnpm in place of npm/Yarn. E.g., install dependencies via:
66
67```
68pnpm install
69```
70
71Also, pnpx instead of npx:
72
73```
74pnpx create-react-app my-cool-new-app
75```
76
77For more advanced usage, read [pnpm CLI](https://pnpm.io/pnpm-cli) on our website, or run `pnpm help`.
78
79## Benchmark
80
81pnpm is up to 2x faster than npm and Yarn classic. See all benchmarks [here](https://r.pnpm.io/benchmarks).
82
83Benchmarks on an app with lots of dependencies:
84
85![](https://pnpm.io/img/benchmarks/alotta-files.svg)
86
87## Support
88
89- [Frequently Asked Questions](https://pnpm.io/faq)
90- [Stack Overflow](https://stackoverflow.com/questions/tagged/pnpm)
91- [Chat](https://r.pnpm.io/chat)
92- [Twitter](https://twitter.com/pnpmjs)
93- [Awesome list](https://github.com/pnpm/awesome-pnpm)
94
95## Contributors
96
97This project exists thanks to all the people who contribute. [[Contribute](../../blob/main/CONTRIBUTING.md)].
98<a href="../../graphs/contributors"><img src="https://opencollective.com/pnpm/contributors.svg?width=890&button=false" /></a>
99
100### Backers
101
102Thank you to all our backers! 🙏 [[Become a backer](https://opencollective.com/pnpm#backer)]
103
104<a href="https://opencollective.com/pnpm#backers" target="_blank"><img src="https://opencollective.com/pnpm/backers.svg?width=890"></a>
105
106### Sponsors
107
108Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [[Become a sponsor](https://opencollective.com/pnpm#sponsor)]
109
110<a href="https://opencollective.com/pnpm/sponsor/0/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/0/avatar.svg"></a>
111<a href="https://opencollective.com/pnpm/sponsor/1/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/1/avatar.svg"></a>
112<a href="https://opencollective.com/pnpm/sponsor/2/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/2/avatar.svg"></a>
113<a href="https://opencollective.com/pnpm/sponsor/3/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/3/avatar.svg"></a>
114<a href="https://opencollective.com/pnpm/sponsor/4/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/4/avatar.svg"></a>
115<a href="https://opencollective.com/pnpm/sponsor/5/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/5/avatar.svg"></a>
116<a href="https://opencollective.com/pnpm/sponsor/6/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/6/avatar.svg"></a>
117<a href="https://opencollective.com/pnpm/sponsor/7/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/7/avatar.svg"></a>
118<a href="https://opencollective.com/pnpm/sponsor/8/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/8/avatar.svg"></a>
119<a href="https://opencollective.com/pnpm/sponsor/9/website" target="_blank"><img src="https://opencollective.com/pnpm/sponsor/9/avatar.svg"></a>
120
121## License
122
123[MIT](https://github.com/pnpm/pnpm/blob/main/LICENSE)
124
125***
126
127Like this project? Let people know with a [tweet](https://bit.ly/tweet-pnpm).