WSL中使用Mermaid离线生成LangGraph流程图

在WSL(Ubuntu/Debian)环境下,Mermaid离线生成PNG常卡在Chrome Headless下载、依赖缺失、版本兼容等问题上。本文提供极简配置流程,10分钟搞定环境,支持一键自动化生成。

一、核心痛点

  1. Chrome Headless下载报错ECONNRESET
  2. 系统共享库缺失(如libnspr4.so);
  3. mmdc与Chrome版本不兼容;
  4. 自动化生成时路径不匹配、误判结果。

二、环境准备(3步搞定)

  1. WSL发行版:Ubuntu 20.04/22.04;

  2. Node.js(LTS版)+ npm,配置淘宝镜像:

    bash 复制代码
    npm config set registry https://registry.npmmirror.com/
  3. Python 3.8+,安装IPython:

    bash 复制代码
    pip install ipython

三、核心配置:Chrome Headless(关键步骤)

1. 配置网络代理(如果网络不通报ECONNRESET错)

Windows启动代理工具(如端口7897),WSL终端执行:

bash 复制代码
export HTTP_PROXY=http://127.0.0.1:7897
export HTTPS_PROXY=http://127.0.0.1:7897

2. 一键下载Chrome Headless

bash 复制代码
npx puppeteer browsers install chrome-headless-shell
  • 自动缓存到/home/用户名/.cache/puppeteer/

3. 补全系统依赖

bash 复制代码
sudo apt update && sudo apt install -y libnspr4 libnss3 libatk1.0-0 libgtk-3-0

4. 验证Chrome有效性

bash 复制代码
# 查找Chrome路径
find /home/用户名/.cache/puppeteer/ -name "chrome-headless-shell" -type f
# 验证版本(替换为查找结果)
/你的Chrome路径 --headless=new --version
  • 输出Chrome xxx.xx.xxxx.xxx即为成功

四、安装配置mmdc(2步)

1. 安装新版mmdc(兼容Chrome)

bash 复制代码
npm install -g @mermaid-js/mermaid-cli

2. 配置环境变量(永久生效)

bash 复制代码
vim ~/.bashrc
# 末尾添加(替换为你的Chrome路径)
export PUPPETEER_EXECUTABLE_PATH=/home/用户名/.cache/puppeteer/.../chrome-headless-shell
# 生效配置
source ~/.bashrc

3. 快速验证

bash 复制代码
# 新建测试文件
echo "```mermaid
flowchart LR
A[开始] --> B[执行] --> C[结束]
```" > test.md
# 生成PNG
mmdc -i test.md -o test.png -w 2000 -H 1000
  • 目录出现test.png(或test-1.png)即成功

五、Python自动化:LangGraph流程图一键生成

1. 前置准备

bash 复制代码
pip install langgraph

2. 自动化函数(直接复制使用)

python 复制代码
import os
import re
import subprocess
from IPython.display import Image, display

def display_langgraph_flow(agent):
    """从LangGraph Agent提取Mermaid,离线生成PNG并显示"""
    try:
        # 1. 固定路径,提取Mermaid文本
        script_dir = os.path.dirname(os.path.abspath(__file__))
        mermaid_text = agent.get_graph(xray=True).draw_mermaid()
        mermaid_file = os.path.join(script_dir, "langgraph_flow.md")
        
        # 2. 保存带代码块的Markdown(mmdc必需)
        with open(mermaid_file, "w", encoding="utf-8") as f:
            f.write(f"```mermaid\n{mermaid_text}\n```")
        
        # 3. 调用mmdc生成PNG
        png_base = os.path.join(script_dir, "langgraph_flow")
        result = subprocess.run(
            f"mmdc -i {mermaid_file} -o {png_base}.png -w 2000 -H 1000",
            shell=True, capture_output=True, text=True
        )
        
        # 4. 解析实际生成的PNG文件(兼容-1后缀)
        actual_png = None
        match = re.search(r'✅\s*(.+?\.png)', result.stdout, re.IGNORECASE)
        if match:
            actual_png = os.path.join(script_dir, match.group(1).strip())
        else:
            for file in os.listdir(script_dir):
                if file.startswith("langgraph_flow") and file.endswith(".png"):
                    actual_png = os.path.join(script_dir, file)
                    break
        
        # 5. 验证并显示
        if not actual_png or not os.path.exists(actual_png):
            raise Exception("未找到生成的PNG文件")
        print(f"✅ 流程图生成:{actual_png}")
        display(Image(actual_png))
        
    except Exception as e:
        print(f"❌ 错误:{str(e)}")

3. 使用方法

python 复制代码
# 传入LangGraph Agent对象调用
display_langgraph_flow(your_langgraph_agent)

六、避坑速查

  1. 下载报错ECONNRESET:检查代理或切换手机热点;
  2. 库缺失:执行apt install -y libnspr4 libgtk-3-0
  3. 后缀-1问题:函数自动兼容,无需手动处理;
  4. 找不到mmdc:用which mmdc获取绝对路径,替换函数中命令。

总结

核心流程:代理下载Chrome → 补依赖 → 配置mmdc → 自动化生成。配置完成后,可离线生成任意Mermaid图表,LangGraph流程图无需重复配置。

相关推荐
陌殇殇12 小时前
001 Spring AI Alibaba框架整合百炼大模型平台 — 快速入门
人工智能·spring boot·ai
zzzzls~12 小时前
Python 工程化: 用 Copier 打造“自我进化“的项目脚手架
开发语言·python·copier
数据知道12 小时前
claw-code 源码分析:成本追踪(Cost)与 Hook——企业落地时,计量与策略注入该挂在哪一层?
ai·claude code·claw code
韶博雅12 小时前
emcc24ai
开发语言·数据库·python
He少年12 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
AI_Claude_code12 小时前
ZLibrary访问困境方案四:利用Cloudflare Workers等边缘计算实现访问
javascript·人工智能·爬虫·python·网络爬虫·边缘计算·爬山算法
jedi-knight13 小时前
AGI时代下的青年教师与学术民主化
人工智能·python·agi
迷藏49413 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏49413 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
weixin_1562415757613 小时前
基于YOLOv8深度学习花卉识别系统摄像头实时图片文件夹多图片等另有其他的识别系统可二开
大数据·人工智能·python·深度学习·yolo