本文使用的 PyCharm 2024.2.1
版本,如果使用低版本 PyCharm
,那么在调试 Xinference v0.15.1
源码时可能会报错 Connection to Python debugger failed Socket closed
。
一.PyCharm 调试 Xinference 源码
由于 Xinference 中的一些依赖包仅支持 Linux,所以在 PyCharm 调试 Xinference 源码时,最好使用 PyCharm+WSL2 环境,或者直接使用 PyCharm+Ubuntu 22.04 环境,以此实现 PyCharm 对 Xinference 源码调试。
1.环境配置
环境为 Python 3.10.12 版本,WSL2,如下所示:
data:image/s3,"s3://crabby-images/10b96/10b9633e8628ea834e6428b51881c82560212388" alt=""
根据配置文件 inference\setup.cfg
可知,debug 入口点为 inference/xinference/deploy/cmdline.py
。如下所示:
data:image/s3,"s3://crabby-images/7421e/7421e6d48f948066498d4eff06d572e287f6d084" alt=""
Run/Debug Configuration 参数及配置,如下所示:
data:image/s3,"s3://crabby-images/c0e5a/c0e5ad9369b12fbc9b2fbd2d4422b0c8e8d57ba7" alt=""
2.运行前端代码
bash
npm install # 安装依赖包
npm run start # 实际执行react-scripts start
data:image/s3,"s3://crabby-images/31654/31654a650e8495b85fea7024dd295ef2ad0092f6" alt=""
自动打开链接 http://localhost:3000/#/launch_model/llm,如下所示:
data:image/s3,"s3://crabby-images/56811/56811ad925ee3b09e7923842455d03ebb3dfa06b" alt=""
3.运行后端代码
点击 Debug 调试 Xinference 源码,如下所示:
data:image/s3,"s3://crabby-images/f584b/f584badc6d0d9263b0af9fbe5fbf59d8a11a92ba" alt=""
如果调试后端代码时遇到相对路径相关问题,那么修改为完整路径即可。如下所示:
(1)inference\xinference\deploy\cmdline.py
data:image/s3,"s3://crabby-images/4dc3e/4dc3eb32ba8172f4af079fe1dd2a1d3b7f90e5cd" alt=""
(2)inference\xinference\deploy\local.py
data:image/s3,"s3://crabby-images/6ca27/6ca277830483a209a68acecfc39e26c88a594e7b" alt=""
(3)inference\xinference\deploy\utils.py
data:image/s3,"s3://crabby-images/d63f8/d63f8f5b4169354c14f4c9174f5aa86107df3d43" alt=""
(4)inference\xinference\deploy\worker.py
data:image/s3,"s3://crabby-images/7bbbe/7bbbeef0f2b291f1da0fa16f900ca6dbc10bc1ab" alt=""
4.源码修改
比如,修改"Launch Model"为"启动模型",如下所示:
data:image/s3,"s3://crabby-images/a3a0f/a3a0fb48ef7c4c1840beac5a5bd8260f7ffeb992" alt=""
Web 前端页面也会跟随着相应变化,如下所示:
data:image/s3,"s3://crabby-images/29e6e/29e6e43b70aa0c01709cfda3b3cf8310abffd0e4" alt=""
二.PyCharm+WSL2 调试遇到的问题
如果使用 PyCharm 版本过低,比如 PyCharm 2023.3.2。直接 Run 是可以的,但是 Debug 报错,如下所示:
data:image/s3,"s3://crabby-images/218cf/218cf8db4f6f68439713b8ab5f275273d0cd6b81" alt=""
Connection to Python debugger failed Socket closed
使用版本为 PyCharm 2023.3.2,如下所示:
data:image/s3,"s3://crabby-images/d9d7b/d9d7b687e8c233caba1e60e6dc429e11bbe74105" alt=""
报该错误可能是 PyCharm 本身的问题,解决方案是升级为最新的 PyCharm 2024.2.1 版本。
三.PyCharm+WSL2 安装和运行
源码编译安装,如下所示:
https://github.com/xorbitsai/inference
python setup.py install
xinference-local --host 0.0.0.0 --port 9997
data:image/s3,"s3://crabby-images/c1a01/c1a0159890ec91b769cfa353c45eb3758a96b6f5" alt=""
打开链接 http://127.0.0.1/ui/#/cluster_info,如下所示:
data:image/s3,"s3://crabby-images/73721/73721758aad39b639f15335c2c8cb813fb9b76c4" alt=""
参考文献
[1] Xorbits 官网:https://xorbits.cn/inference
[2] Xinference 官方文档:https://inference.readthedocs.io/zh-cn/latest/index.html
[3] Xorbits Inference GitHub:https://github.com/xorbitsai/inference
NLP工程化(星球号)