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流程图无需重复配置。

相关推荐
天下·第二8 小时前
python - 【编译.py文件】部署运行
开发语言·python
还不秃顶的计科生8 小时前
力扣hot100第三题:最长连续序列python
python·算法·leetcode
linuxxx1108 小时前
request.build_absolute_uri()关于使用IP+端口
网络·python·网络协议·tcp/ip·django
linuxxx1108 小时前
request.build_absolute_uri()用法
python·django
玄同7659 小时前
我是如何学习编程的?——从 “扳手使用” 到编程学习:踩坑式实践的底层方法论
开发语言·人工智能·经验分享·笔记·python·学习·自然语言处理
Java后端的Ai之路9 小时前
【Python进阶学习】-NumPy详细介绍指南(附demo)
python·学习·numpy
xingzhemengyou19 小时前
Python lambda函数
开发语言·python
像风一样的男人@9 小时前
python --生成ico图标
java·python·spring
多打代码9 小时前
2026.1.2 删除二叉搜索树中的节点
开发语言·python·算法