XIO: fatal IO error 22 (Invalid argument) on X server “localhost:10.0“【小白找bug】

最近在服务器上跑代码时,遇到了这个错误:

python 复制代码
XIO:  fatal IO error 22 (Invalid argument) on X server "localhost:10.0"
      after 383 requests (383 known processed) with 4 events remaining.

它是怎么出现的呢?即使我跑代码时挂了tmux、nohup,试图使得关闭mobaxterm客户端之后让代码在Linux服务器上继续跑。

当关闭客户端,后台运行的代码运行到plt.savefig时出现这个错误;关闭mobaxterm客户端,当后台运行的代码没有运行到plt.savefig时不出现这个错误;不关闭mobaxterm客户端,plt.savefig时不出现这个错误。

原因:

X11:X Window System 版本 11 的简称,是一种用于图形用户界面(GUI)的协议,X Server 是 X11 协议的具体实现。

当使用 MobaXterm 连接到服务器时,DISPLAY 环境变量会被设置为 localhost:10.0,指向 MobaXterm 提供的 X Server。

matplotlib 默认后端(Qt5Agg)需要一个可用的图形环境X11,即使是保存图像也会尝试创建一个图形窗口。当关闭了 MobaXterm 客户端,matplotlib 试图访问 X Server 就会失败,从而导致 XIO: fatal IO error 22。

解决方法:

步骤1、执行 unset DISPLAY删除 DISPLAY 变量 ,程序不会再尝试连接 X11 服务器。

原因:DISPLAY 变量指示当前进程的图形显示服务器,即 X11 服务器的地址。DISPLAY=localhost:10.0就表示 X11 Forwarding 将图形输出到本地客户端(MobaXterm)。

步骤2、强制使用无 GUI 的 Agg 后端(专门用于生成文件,如 PNG、PDF,而不需要图形显示的后端),在代码的最前面加上:

python 复制代码
import matplotlib
matplotlib.use('Agg')
import matplotlib.pyplot as plt

问题解决。

后记:小白之前关闭MobaXterm也不会报这个错误,但是这两天突然出现了这个错误,不知道为什么,😔唉

相关推荐
爱打代码的小林15 分钟前
基于 MediaPipe 实现实时面部关键点检测
python·opencv·计算机视觉
LJianK116 分钟前
idea自带的数据库修改默认值有bug
bug
极客小云34 分钟前
【ComfyUI API 自动化利器:comfyui_xy Python 库使用详解】
网络·python·自动化·comfyui
闲人编程1 小时前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
痴儿哈哈1 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
花酒锄作田1 小时前
SQLAlchemy中使用UPSERT
python·sqlalchemy
SoleMotive.1 小时前
一个准程序员的健身日志:用算法调试我的增肌计划
python·程序员·健身·职业转型
亓才孓1 小时前
[Properties]写配置文件前,必须初始化Properties(引用变量没执行有效对象,调用方法会报空指针错误)
开发语言·python
Bruk.Liu1 小时前
(LangChain 实战14):基于 ChatMessageHistory 自定义实现对话记忆功能
人工智能·python·langchain·agent
大江东去浪淘尽千古风流人物2 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法