当前位置: 首页 > news >正文

WSL Ubuntu中安装Mermaid CLI失败解决

在WSL中安装Mermaid CLI失败时,可参考以下详细解决方案:

1. Node.js环境问题

  • 前置条件:确保已安装Node.js(建议v16+)
  • 检查版本:运行node --version验证
  • 安装失败时:使用以下命令安装Node.js:
# 使用nvm安装Node.js(推荐)curl-o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh|bashsource~/.bashrc nvminstall--ltsnvm use--lts
  • 清理npm缓存:npm cache clean --force
  • 永久设置镜像:npm config set registry https://registry.npmmirror.com

2. Puppeteer依赖问题

  • 核心原因:Mermaid CLI依赖Puppeteer,而Puppeteer默认会下载Chromium,可能因权限或路径问题失败
  • 解决方案
  • 跳过Chromium下载:设置环境变量export PUPPETEER_SKIP_DOWNLOAD=true
  • Ubuntu系统直接安装Chromium(推荐):
# 安装Chromium浏览器sudoapt-getupdatesudoapt-getinstall-ychromium-browser# 配置Puppeteer使用系统ChromiumexportPUPPETEER_EXECUTABLE_PATH=$(whichchromium-browser)# 永久生效(添加到~/.bashrc)echo'export PUPPETEER_EXECUTABLE_PATH=$(which chromium-browser)'>>~/.bashrcsource~/.bashrc
  • 备选方案:手动安装Chrome
# 下载并安装Chromewgethttps://dl.google.com/linux/direct/google-chrome-stable_current_amd64.debsudoaptinstall./google-chrome-stable_current_amd64.debrmgoogle-chrome-stable_current_amd64.deb# 设置环境变量exportPUPPETEER_EXECUTABLE_PATH=/usr/bin/google-chromeecho'export PUPPETEER_EXECUTABLE_PATH=/usr/bin/google-chrome'>>~/.bashrcsource~/.bashrc

3. 网络问题

  • 国内用户推荐:安装时强制使用国内镜像
npminstall-g@mermaid-js/mermaid-cli--verbose--registry=https://registry.npmmirror.com
  • 证书过期:若遇CERT_HAS_EXPIRED错误,切换镜像源
npmconfigsetregistry https://registry.npmmirror.com

4. 权限问题

  • 提升权限安装:在安装命令前添加sudo,避免全局安装路径无写入权限
  • 检查权限:确保用户对~/.cache/puppeteer有读写权限

5. 其他问题

  • 检查日志:安装失败时查看详细日志定位问题:cat ~/.npm/_logs/*.log
  • 使用Docker:若环境配置复杂,可用Docker容器替代
http://www.jsqmd.com/news/895130/

相关文章:

  • CASCADE架构:AI加速器的矩阵乘法革命
  • 开源项目推荐——HyperFrames
  • Kafka核心概念与架构深度解析
  • OAuth 2.0与JWT:从授权流程到令牌格式的完整解析与实战指南
  • Mysql--基础知识点--111--innodb中的change buffer为什么只针对非唯一二级索引
  • AI辅助固件开发:R-P-E-T四步法提升嵌入式开发效率
  • Unity 2D Tilemap保姆级避坑指南:从素材切割到碰撞体合并,搞定像素风游戏地图
  • 【深度实战复盘】校园管理中的“纪律高危型”学生考勤画像可视化全流程分析报告
  • DeepSeek V4 Pro降价后开发者该怎么用?附API接入与成本优化指南
  • DataWeave实战:动态构建LLM提示词的两大陷阱与解决方案
  • NestJS 是优秀的 SaaS 框架吗?——按“SaaS底座要求“逐项拆解
  • Theta正则化克里金模型:提升代理模型预测精度与稳定性的关键技术
  • codex访问deepseek
  • Kafka生产者配置详解与最佳实践
  • CTV广告变现中10个致命的VAST错误与优化实战
  • 构建本地语音AI助手:人在回路机制与隐私优先设计
  • 从‘刷车没颜色’说起:深入理解UE4材质Usage属性,避免打包后的材质‘罢工’
  • Terraform自动化部署Vertex AI模型:基础设施即代码实践指南
  • 拒绝被官转割韭菜!Cursor / Claude Code 接入自定义 API 避坑与终极省钱指南
  • Docker化部署Ansible AWX:从零搭建企业级自动化运维平台
  • 手工测试工程师如何转型为质量赋能者:技能升级与思维转变
  • 智能体系统架构设计:从LLM到编排器、工具与记忆层的工程实践
  • Mysql--基础知识点--112--聚簇索引和非聚簇索引
  • 模型安全扫描器失效:29种绕过技术揭示PyTorch与Hugging Face模型加载风险
  • AI智能体实战指南:从核心架构到LangChain搭建全解析
  • CentOS 7服务器配置实录:用yum安装PHP 8.1并搞定常用扩展(bcmath, gd, pdo_mysql...)
  • NSSM实战:除了基础注册,这些高级配置让你的Windows服务更稳定(日志、重启、权限篇)
  • 【干细胞突破性进展】中国科学家发现“全能开关”基因,改写再生医学未来!2026最新研究深度解读
  • 薄膜铌酸锂光波导 vs 传统铌酸锂波导:基于台阶仪的波导刻蚀深度与损耗差异分析
  • 源启重大,智创未来 | AtomGit「源启高校」计划重庆大学站圆满落幕!