K6压测工具

编程技巧 网站经验
📅 2026-03-21 11:00 👤 admin

**完整安装过程总结(含踩坑与解决)**

1. 目标  
在 Windows 上全局安装 `k6`,并能在任意目录执行 `k6` 命令。

2. 初始问题  
你一开始执行:
```powershell
winget install k6 --source winget
```
报错:`winget` 无法识别。  
原因:系统虽有“应用安装程序(App Installer)”,但 `winget` 命令入口未生效(PATH/别名/注册问题)。

3. 修复 `winget` 的过程  
你做了这些关键操作:

```powershell
$pkg = Get-AppxPackage Microsoft.DesktopAppInstaller
Add-AppxPackage -DisableDevelopmentMode -Register "$($pkg.InstallLocation)\AppXManifest.xml"
```

中途遇到错误 `0x80073D02`(资源被占用),通过关闭占用程序后重试解决。  
之后又发现:
```powershell
$env:Path -split ';' | Select-String "WindowsApps"
```
为空,说明 `WindowsApps` 不在 PATH。补 PATH 后,`winget --info` 成功,说明 `winget` 已恢复可用。

4. 安装 `k6` 时的问题  
你先用:
```powershell
winget install -e --id k6.k6 --source winget
```
失败“找不到包”。  
原因:包 ID 写错。正确 ID 来自搜索结果:
```powershell
winget search k6 --source winget
```
显示正确 ID 是 `GrafanaLabs.k6`。

5. 正确安装命令  
最终成功安装:
```powershell
winget install -e --id GrafanaLabs.k6 --source winget
```
安装日志显示已下载并安装 MSI 成功。

6. 安装后 `k6` 仍不可识别  
你执行 `k6 version` 仍报找不到命令。  
原因:新安装路径未在当前终端会话生效(常见 PATH 刷新问题)。  
解决方式:
1. 关闭并重新打开 PowerShell 再试。  
2. 若仍不行,定位 `k6.exe` 路径并加入 PATH(通常是 `C:\Program Files\k6`)。

7. 最终结论  
你已经完成了核心安装,当前只差终端会话/PATH 生效这一步。  
最终应达到:
```powershell
k6 version
```
可正常输出版本号,即全局安装成功。

---

**这次最关键的经验**
1. `winget search` 里 `ID` 列才是可安装的精确包名。  
2. “安装成功但命令不可用”通常是 PATH 未刷新,不一定是安装失败。  
3. `App Installer` 显示已安装,不代表 `winget` 一定立即可用,可能还需注册/别名/PATH 修复。