• pnpm的浅了解



    前言

    没学过相关的计算机基础,对于一直火热pnpm很好奇,但是对其中的硬链接与软链接等专业词不怎么理解。看了王老师讲的pnpm,理解了一些,记录一下。

    1.硬链接和软链接概念

    # 硬链接 hard link
    1.是电脑文件系统中的多个文件平等的共享同一个文件存储单元;
    2.删除一个文件名后,还可以用其它名字继续访问该文件;
    
    # 软链接 soft link
    1.软链接(符号链接)是一类特殊的文件;
    2.其包含有一条以绝对路径或相对路径的形式指向其它文件或者目录的引用;
    3. 我理解的就是快捷方式;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.硬链接demo

    # windows系统:mklink /H aaa_hard.js aaa.js
    // 必须在cmd中以管理员身份运行,powershell是不支持mklink的
    
    • 1
    • 2

    两个文件形成了硬链接的关系,共享同一个文件存储单元。随意更改一个文件中的内容,另一个文件内容也被实时改变,内容始终保持一致,我理解的这两个文件就是两个指针哈。

    在这里插入图片描述

    3.软链接demo

    # windows系统:mklink aaa_soft.js aaa.js
    
    • 1

    只是创建了一个文件的快捷方式。

    在这里插入图片描述

    4.pnpm安装与使用

    # 安装pnpm
    npm install -g pnpm
    
    # 查看版本
    pnpm -v
    
    # 基础使用方法
    npm install           pnpm install
    npm install <pkg>     pnpm add <pkg>
    npm uninstall <pkg>   pnpm remove <pkg>
    npm run <cmd>         pnpm <cmd>
        
    # 获取当前活跃的store目录
    pnpm store path
    
    # 从store中删除当前未被引用的包来释放store的空间
    pnpm store prune
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    5.pnpm安装依赖原理

    1. 同一个依赖包的相同的版本,磁盘上只有这个依赖包的一份文件;
    2. 同一个依赖包需要使用不同的版本,则仅有版本间不同的文件会被存储起来;
    3. 使用pnpm,依赖包将被存放在一个统一的位置,而且是非扁平化的目录结构,是目录树的结构;当安装依赖包时,所有文件都会硬链接到此位置,不会占用额外的磁盘空间,可以在项目间共享相同版本的依赖包;

    6.pnpm安装依赖demo

    1.pnpm init
    2.pnpm install chalk
    
    • 1
    • 2

    生成的node_modules目录结构如下,node_modules下的chalk为软链接,指向的真实文件为.pnpm中的chalk,而.pnpm中的chalk为硬链接,链接着磁盘中的文件存储单元。

    后面在别的项目中使用pnpm安装chalk库时,如在磁盘中查到了此库的缓存单元,且是符合条件的兼容版本,则会在.pnpm中创建相应的chalk硬链接文件,此文件指向缓存单元,在.pnpm同一层创建指向此硬链接的软链接。

    在这里插入图片描述

  • 相关阅读:
    消耗服务器cpu和内存
    【矩阵分解】PCA - 主成分分析中的数学原理
    【Unity每日一记】WheelColider组件汽车游戏的关键
    【Redis】Java客户端使用list命令
    RocketMQ特性--Broker是如何存储事务消息的?
    Linux 漏洞处理
    python学习: count()、find()、index()方法
    启动 Nginx.exe出现闪退的问题
    Linux进程概念
    Spring Boot的魔法:构建高性能Java应用
  • 原文地址:https://blog.csdn.net/weixin_47359038/article/details/127777095