Win环境下包管理工具

1 Win下包管理工具

1.1 简介

Scoopwinget 两个 Windows 下常见的包管理器

  • Scoop:类 Unix 风格、以用户目录安装、无需管理员权限、适合把程序装在自定义位置,版本要求:Windows 7 或更高版本;PowerShell ≥ 5.0
  • winget:微软官方的 Windows 包管理器,集成 Microsoft 存储库和社区清单,适合统一安装/升级系统级软件(有时需要管理员权限),但不保证能把所有程序装到自定义盘(安装路径由各包的安装器决定)
    版本要求:Windows 10 build 17763 或更高版本 / Windows 11

1.2 winget

1.2.1 简介

作为微软官方工具,winget的目标是成为Windows上统一的软件包管理标准。它的源包括一个庞大的社区仓库和Microsoft Store,能管理几乎所有类型的Windows应用。

winget 特点:

  • 官方支持(Windows 10/11 能获取),集成 Microsoft Store / community repository
  • 能够方便地 search / install / upgrade 系统软件
  • --scope user / --scope machine 等选项(决定是否为当前用户或全局安装),但大多数包的最终安装目录受安装程序本身限制,不一定能自由指定盘符。

1.2.2 操作使用

如何使用(PowerShell / CMD)

# 搜索
winget search <关键字>

# 安装(举例)
winget install --id <包ID> -e

# 查看已装
winget list

# 升级单个/全部
winget upgrade <包ID>
winget upgrade --all

# 卸载
winget uninstall <包ID>

示例:先 winget search bruno 看有没有 Bruno 的包 ID,再 winget install --id <id>。如果包支持 --scope user,可以尝试 --scope user 来做用户安装(有时用户安装位置在用户目录)。

1.2.3 安装指定盘

是否能指定安装盘?

通常不能通用指定。是否能指定安装路径取决于该软件的安装器(MSI/EXE)的参数,winget 本身并不对所有包统一提供 --location。可以查看 winget show <id> 看包支持哪些参数,或使用 --override 把自定义安装参数传给原安装器(高级用法,并非所有包都支持)。

虽然 可以使用 winget install <软件包> --location <路径> 来尝试指定安装目录。
也可以在配置文件中设置默认的安装根路径。然而,最关键的一点是:这些设置对于许多传统安装器(如.msi或.exe)来说只是建议值。软件包自身的安装器(Installer)拥有最终决定权,可能会忽略这些路径设置。因此,无法保证把所有程序都安装到自定义位置

下面这个表格汇总了 winget 指定安装路径的主要方法及其局限性:

方法 命令/配置 主要局限性
--location 参数 winget install <软件包> --location "D:\Your\Path" 依赖安装程序支持:并非所有安装器(如MSI、Inno Setup)都会接收并遵从该参数
配置文件预设 settings.json 中设置 defaultInstallRoot 通过 winget settings 命令打开配置文件,在其中设置一个默认的安装根目录,同样依赖安装程序支持:本质上和 --location 参数一样,只是一个"建议",可能被忽略。
--scope 参数 winget install <软件包> --scope user (用户目录) 或 machine (系统目录) 仅控制安装作用域:决定软件安装在用户目录还是系统目录(如 Program Files),不能指定任意路径。
--override 参数 winget install ... --override "/INSTALLDIR=D:\Your\Path" 技术要求高:需要知晓特定安装器(如某些使用MSI的软件)支持的参数,通用性差。

1.2.4 软件源来源&加速

1.2.4.1 软件源

winget 的软件清单(manifest)主要来自 微软维护的社区仓库:

  • 默认源:winget-pkgs GitHub 仓库,里面存放着每个软件的 manifest(安装描述),告诉 winget 如何下载安装。
  • 软件下载来源:
    winget 自身不托管安装包,而是从 软件的官方发布地址 或 微软商店 (MS Store) 下载。
  • 地域问题:
    如果源链接是国外的(比如 GitHub、国外官网),在国内可能会比较慢;
    如果链接是 MS Store 或微软 CDN(如 aka.ms),通常在国内速度会好一些。

1.2.4.2 加速

移除默认源 winget source remove winget
添加中科大源 winget source add winget https://mirrors.ustc.edu.cn/winget-source
查看当前源 winget source list
重置回官方源 winget source reset winget

1.3 Scoop

1.3.1 简介

Scoop的设计初衷是提供一个无需管理员权限、绿色便携的软件管理方案。它安装的软件通常是便携式的,解压后即可使用,不会将文件散落或注册表信息写入系统。

软件默认安装在C:\Users\<用户名>\scoop,但完全可以通过设置SCOOP环境变量,将其安装到任何自定义位置,例如D:\Scoop。此后所有通过Scoop安装的软件都会集中在这个目录下

Scoop 特点:

  • 无需管理员权限(默认安装在用户目录)
  • 把每个应用解压到 SCOOP\apps\<name>\<version>,通过 SCOOP\shims 把可执行文件放到 PATH(shim 是可移植的可执行代理)。
  • 数据和可执行文件都是普通文件夹,方便备份/Git 管理。
  • 可以通过环境变量在安装前指定 SCOOP 根目录,从而安装到 D:、E: 等盘。

1.3.2 操作&安装

在 PowerShell(非管理员也可)中执行:

# 1 把 scoop 根目录设为 D:\scoop(持久化设置)当前写入用户变量,如果想写入系统变量setx 后面加 \M 即可
setx SCOOP D:\Scoop
# 关闭并重新打开 PowerShell(或在当前会话临时设置)
$env:SCOOP='D:\Scoop'

# 设置全局安装目录(可选)
# Scoop 还有一个 global apps(全局软件目录),默认在 C:\ProgramData\scoop。
# 如果也想放到 D 盘,可以设置 SCOOP_GLOBAL 当前写入用户变量,如果想写入系统变量setx 后面加 \M 即可
setx SCOOP_GLOBAL D:\ScoopGlobal
$env:SCOOP_GLOBAL='D:\ScoopGlobal'
# 注意:SCOOP_GLOBAL 是系统级变量,要管理员权限

# 2 允许脚本并安装(如果网络需要 TLS, 再执行第二个命令)
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser -Force
[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072

# 3 安装 scoop
iwr -useb get.scoop.sh | iex
或者 更简洁的 irm get.scoop.sh | iex
或者 直接安装国内且直接指定脚本:irm scoop.201704.xyz | iex -ArgumentList @('-ScoopDir', 'D:\Scoop', '-ScoopGlobalDir', 'D:\GlobalScoopApps')

注意setx 会把环境变量写入系统(用户)配置,重启 shell 后生效。若想临时在当前 PowerShell 会话生效,可先执行 $env:SCOOP='D:\scoop' 再安装。

irm get.scoop.sh | iexiwr -useb get.scoop.sh | iex 的区别:

方面 irm get.scoop.sh | iex iwr -useb get.scoop.sh | iex
命令 使用 Invoke-RestMethod(irm) 使用 Invoke-WebRequest(iwr)
输出 直接返回响应主体(脚本的文本内容) 返回完整 HTTP 响应对象,需通过 .Content 访问主体。
解析模式 默认不解析 HTML,直接返回文本,简洁高效 需要 -useb(UseBasicParsing)避免 HTML 解析
语法简洁性 更简洁,无需额外参数 稍复杂,需显式指定 -useb(在旧版 PowerShell 中)
适用场景 更适合直接获取文本或 JSON 内容的场景 适合需要完整 HTTP 响应(如状态码、头信息)的场景
性能 略轻量,因无需处理完整响应对象 略重,因返回完整响应对象

报错:Running the installer as administrator is disabled by default, see https://github.com/ScoopInstaller/Install#for-admin for details.
因为 Scoop 默认禁止通过管理员权限的 PowerShell 来安装。它设计为在普通用户模式下运行,这样可以避免一些潜在的权限冲突和系统文件误改风险

1.3.3 常用命令

1.3.4 软件源来源&加速

1.3.4.1 软件源

scoop 的软件源叫 bucket(相当于软件仓库),默认和社区提供:

  • 主 bucket(main):ScoopInstaller/Main,常见工具的清单,比如 git、nodejs、python。
  • 其他官方 bucket:
    ScoopInstaller/Extras 各种 GUI 软件
    ScoopInstaller/Versions 不同版本
    ScoopInstaller/Java 各种 JDK
    ScoopInstaller/Nirsoft Nirsoft 工具集
  • 第三方 bucket:
    任何人都能建自己的 bucket(比如国内的一些 bucket,会提供加速链接)。
    添加命令:scoop bucket add <名字> <git地址>

Scoop 的软件清单放在 bucket(Git 仓库)里。默认只安装了 main bucket

scoop bucket list                   #查看当前已添加 bucket  
scoop bucket known                  #查看官方推荐  
scoop bucket add <bucket_name>      #添加一个官方已知的 bucket 
scoop bucket add <name> <repo_url>  #通过 Git 仓库地址添加第三方 bucket
scoop bucket rm <bucket_name>       #移除指定的 bucket

添加额外 bucket
scoop bucket add extras
scoop bucket add versions
scoop bucket add java
scoop bucket add nirsoft

# 示例:添加 Gitee 上的 Extras 仓库
scoop bucket add dorado https://github.com/chawyehsu/dorado
scoop bucket add extras https://gitee.com/scoop-installer/Extras

1.3.4.2 加速

使用国内加速 bucket,一些社区提供国内源,例如:

如果尚未安装 Scoop,可以直接使用国内镜像提供的安装脚本,这会自动配置好主程序源
# 使用国内镜像安装 Scoop
iwr -useb scoop.201704.xyz | iex


如果已经安装了 Scoop,可以手动将其仓库地址修改为国内镜像:
scoop config SCOOP_REPO "https://gitee.com/scoop-installer/scoop"
scoop update

里面很多常见软件都有国内加速下载地址。
修改 aria2 加速下载

Scoop 默认用 PowerShell 下载,比较慢。推荐开启 aria2 多线程下载:
scoop install aria2 # 安装

优化配置
scoop config aria2-enabled true  # 默认开启,改为false 即可关闭多线程下载
scoop config aria2-split 16
scoop config aria2-max-connection-per-server 16
scoop config aria2-min-split-size 1M

启用后下载会变成多线程,大幅加速

1.3.5 apps下目录

1.3.5.1 current作用

当执行 scoop install <name>后,会在 Scoop\apps\<app>下有一个current文件夹,同时有一个文件链接符号
大致目录结构:

D:\Scoop\apps\<name>\
├── <version>\
│   ├── bin\
│   └── LICENSE.txt
├── current -> D:\Scoop\apps\<name>\<version>\

<version> 是实际安装的版本文件夹。
current 是一个 符号链接(symlink),指向当前正在使用的版本,在powershell里面使用命令可以查看

Get-Item D:\Scoop\apps\ffmpeg\current | Format-List
输出如下:
    目录: D:\Scoop\apps\ffmpeg
Name           : current
CreationTime   : 2025/10/16 11:26:49
LastWriteTime  : 2025/10/16 11:26:49
LastAccessTime : 2025/10/16 11:26:49
Mode           : d-r--l
LinkType       : Junction
Target         : {D:\Scoop\apps\ffmpeg\8.0}

在cmd里面用dir /al查看

D:\Scoop\apps\ffmpeg>dir /al
 驱动器 D 中的卷是 新加卷
 卷的序列号是 641B-9BCA

 D:\Scoop\apps\ffmpeg 的目录

2025/10/16  11:26    <JUNCTION>     current [\??\D:\Scoop\apps\ffmpeg\8.0]
               0 个文件              0 字节
               1 个目录 296,425,242,624 可用字节

D:\Scoop\apps\ffmpeg>

由于 current 始终指向当前版本,所以:无论更新、回滚、切换版本,命令行依旧执行的是 <name>.exe,而无需改 PATH

1.3.5.2 shims作用

%SCOOP%\shims 目录 是在当前用户环境变量 PATH
路径示例:

D:\Scoop\
├── apps\
│   ├── git\
│   │   ├── current → 3.0.0
│   │   └── 3.0.0\
│   └── python\
├── shims\
│   ├── git.exe
│   ├── python.exe
│   └── ...

shims作用:

  • %SCOOP%\shims 目录下生成一个小代理 exe(shim);
  • 这个 shim 指向真实的软件可执行文件,比如 D:\Scoop\apps\git\current\bin\git.exe。
  • 当输入 git → 系统先查 PATH → 找到 D:\Scoop\shims\git.exe;
  • git.exe(shim)再跳转执行真正的 git。

这样设计的优点 :

  • PATH 永远不乱
    不管装多少软件,PATH 只包含一个 shims 路径。
  • 版本切换方便
    每个软件版本是独立目录(apps\git\3.0.0),current 是个符号链接
    切换版本时,只改 current 链接,不动 PATH
  • 软件卸载干净
    删除软件 → 删除 apps\git 文件夹 → 删除对应 shim → 无需动 PATH。
  • 非管理员也能全功能使用
    一切
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容