WSL Ubuntu中安装Mermaid CLI失败解决

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

1. Node.js环境问题

  • 前置条件:确保已安装Node.js(建议v16+)
  • 检查版本:运行 node --version 验证
  • 安装失败时:使用以下命令安装Node.js:
bash 复制代码
# 使用nvm安装Node.js(推荐)
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
source ~/.bashrc
nvm install --lts
nvm 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(推荐):
bash 复制代码
# 安装Chromium浏览器
sudo apt-get update
sudo apt-get install -y chromium-browser

# 配置Puppeteer使用系统Chromium
export PUPPETEER_EXECUTABLE_PATH=$(which chromium-browser)

# 永久生效(添加到~/.bashrc)
echo 'export PUPPETEER_EXECUTABLE_PATH=$(which chromium-browser)' >> ~/.bashrc
source ~/.bashrc
  • 备选方案:手动安装Chrome
bash 复制代码
# 下载并安装Chrome
wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
sudo apt install ./google-chrome-stable_current_amd64.deb
rm google-chrome-stable_current_amd64.deb

# 设置环境变量
export PUPPETEER_EXECUTABLE_PATH=/usr/bin/google-chrome
echo 'export PUPPETEER_EXECUTABLE_PATH=/usr/bin/google-chrome' >> ~/.bashrc
source ~/.bashrc

3. 网络问题

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

4. 权限问题

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

5. 其他问题

  • 检查日志:安装失败时查看详细日志定位问题:cat ~/.npm/_logs/*.log
  • 使用Docker:若环境配置复杂,可用Docker容器替代
相关推荐
江畔柳前堤1 天前
github实战指南01-账号配置与 SSH 密钥
运维·人工智能·深度学习·ssh·github·pyqt·信号处理
Moshow郑锴1 天前
Ubuntu 26.04 中文输入法 : fcitx5+Rime中州韵引擎
linux·运维·ubuntu
小赖同学啊1 天前
智能连接器集群化高可用生产方案
linux·运维·人工智能
wanghao6664551 天前
DevOps 从入门到实践:构建高效交付流水线
运维·devops
qq_546937271 天前
从“能用”到“超神”,DeepSeek++给网页版装上“大脑”和“手脚”,支持长期记忆、MCP工具与自动化任务!
运维·自动化
ZStack开发者社区1 天前
基于AI Agent的ZCF API文档全链路自动化
运维·人工智能·自动化
Moshow郑锴1 天前
Ubuntu 26.04 更换阿里云源镜像
linux·运维·ubuntu
迷糊小面包1 天前
Docker Hadopp集群版部署搭建及常规问题解疑
运维·docker·容器
ShineWinsu1 天前
对于Linux:线程概念与分页存储管理的解析
linux·运维·服务器·面试·线程·进程·虚拟空间地址
器灵科技1 天前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github