npm、yarn、pnpm之间的区别

ops/2024/12/22 21:20:37/

文章目录

  • npm、yarn、pnpm之间的区别
    • 一、引言
    • 二、安装速度
      • 1、第一步:速度对比
    • 三、磁盘空间利用
      • 2、第二步:磁盘空间利用
    • 四、依赖管理
      • 3、第三步:依赖管理方式
    • 五、安全性
      • 4、第四步:安全性对比
    • 六、日常使用
      • 5、第五步:日常使用对比
    • 七、总结

npmyarnpnpm_1">npm、yarn、pnpm之间的区别

一、引言

在JavaScript项目的依赖管理中,npmyarnpnpm是三个最常用的包管理工具。它们各自有其特点和优势,同时也存在一些差异。本文将从安装速度、磁盘空间利用、依赖管理、安全性和日常使用等方面对比这三种工具。

二、安装速度

1、第一步:速度对比

在安装速度方面,pnpm具有明显优势。根据苍青浪的文章,pnpm在大多数场景下,包安装的速度都明显优于npmyarn,速度会比npmyarn快2-3倍。

例如

# 使用npm安装React
npm install react
# 大概所需时间:30秒# 使用yarn安装React
yarn add react
# 大概所需时间:25秒# 使用pnpm安装React
pnpm add react
# 大概所需时间:10秒

三、磁盘空间利用

2、第二步:磁盘空间利用

pnpm在磁盘空间利用方面同样表现出色。它使用基于内容寻址的文件系统存储文件,避免了重复安装同一个包的问题。

例如

# 使用npm安装lodash
npm install lodash
# 磁盘空间占用:20MB# 使用yarn安装lodash
yarn add lodash
# 磁盘空间占用:20MB# 使用pnpm安装lodash
pnpm add lodash
# 磁盘空间占用:5MB(假设其他项目已经安装过lodash)

四、依赖管理

3、第三步:依赖管理方式

npmyarn采用扁平化的依赖管理方式,所有依赖都被放置在node_modules目录下。这种方式虽然解决了嵌套依赖的问题,但也带来了依赖结构的不确定性和非法访问依赖的风险。

例如

# 使用npm和yarn时,如果foo依赖bar,bar依赖baz
# foo
# ├── node_modules
# │   ├── bar
# │   └── baz(依赖提升)
# └── package.json# 使用pnpm时,依赖不会提升
# foo
# ├── node_modules
# │   └── .pnpm
# │       └── foo@1.0.0
# │           └── node_modules
# │               ├── bar
# │               └── baz
# └── package.json

五、安全性

4、第四步:安全性对比

在安全性方面,pnpm通过其独特的依赖管理方式,确保了只有声明过的依赖才能被项目访问,从而避免了非法访问依赖的风险。

例如

# 使用npm或yarn时,如果项目A依赖项目B,项目B依赖项目C
# 项目A可以直接访问项目C,即使项目A没有直接依赖项目C# 使用pnpm时,项目A不能直接访问项目C
# 项目A
# ├── node_modules
# │   ├── .pnpm
# │   │   └── project-b@1.0.0
# │   │       └── node_modules
# │   │           └── project-c
# │   └── project-b
# └── package.json

六、日常使用

5、第五步:日常使用对比

在日常使用方面,pnpm提供了与npmyarn相似的命令行接口,使得从npmyarn迁移到pnpm变得非常容易。

例如

# 使用npm安装依赖
npm install# 使用yarn安装依赖
yarn install# 使用pnpm安装依赖
pnpm install

七、总结

综上所述,pnpm在安装速度、磁盘空间利用、依赖管理和安全性方面都展现出了明显的优势。虽然npmyarn在社区中有着广泛的使用,但pnpm的创新和性能优化使其成为了一个值得考虑的选择。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • 为什么现在我更推荐 pnpm 而不是 npm/yarn?

http://www.ppmy.cn/ops/124064.html

相关文章

讯飞星火与昇腾AI双向奔赴:本土化技术创新应对全球化挑战的一次成功验证

文 | 智能相对论 作者 | 陈泊丞 2019年,彼时的AI赛道还不像今天这么热。 这一年,人工智能连续第三年出现在政府工作报告中,政策关键词从“加快”“加强”转变为“深化”,开始进入行业需求快速增长的应用探索期。而华为也在这个…

IO,进程线程面试题

1.标准IO和文件IO的区别 标准IO:调用封装好的相关库函数,来实现数据的输入输出 文件IO:调用系统(内核)提供的相关函数,来实现数据的输入输出 1、标准IO属于库函数,文件IO属于系统调用 2、标准…

go 的 timer reset

在 Go 语言 1.23 版本之前,与Timer(定时器)关联的通道是异步的(有缓冲,容量为 1)。这意味着即使在调用Timer.Stop(停止定时器)或Timer.Reset(重置定时器)并返…

基于Arduino的宠物食物分配器

创作本文的初衷是本人的一个养宠物的梦想(因为家里人对宠物过敏,因此养宠物的action一直没有落实),但是梦想总是要有的哈哈哈哈哈。上周正好是和一个很好的朋友见面,聊到了养宠物的事情,她大概是讲到了喂宠…

详解RTL design的 CDC和RDC

一、CDC(跨时钟域处理,Clock Domain Crossing) (一)基本原理 时钟域的概念 在芯片设计中,时钟域是由一个时钟信号及其相关逻辑组成的区域。每个时钟域内的电路元件(如寄存器、组合逻辑等)都由同一个时钟信号来同步操作。例如,一个微处理器芯片可能有多个时钟域,如用…

垃圾回收器

一、垃圾回收器的三种类型 1.串行 单线程执行:所有的垃圾回收工作都由单个线程完成,即在进行垃圾回收时,应用程序的其他所有线程都会停止。简单而高效:由于单线程执行,实现上相对简单,适用于小型或中小型…

HTML实现飘动广告效果

上述HTML代码创建了一个简单的网页,其中包含一个可以在页面内自动移动的小方块(div元素),并且当鼠标悬停在该方块上时,动画会暂停;当鼠标移开时,动画会继续。以下是代码的详细分析: …

k8s之ingress-nginx-controller安装

作者:程序那点事儿 日期:2024/01/30 01:25 要在master节点上安装 helm repo add ingress-nginx Welcome - Ingress-Nginx Controller helm search repo ingress-nginx helm pull ingress-nginx/ingress-nginx --version 4.4.2 mv ingress-nginx-4.4.…