Linux DISPLAY环境变量的妙用(error:QXcbConnection: Could not connect to display) ,xhost 命令, 通过ssh连接显示界面

#PS:要转载请注明出处,本人版权所有

#PS:这个只是 《 我自己 》理解,如果和你的

#原则相冲突,请谅解,勿喷

最近由于特殊原因,要在字符终端中的bash运行一个带GUI的PyQT程序。
报了一个错误为:QXcbConnection: Could not connect to display

我在GUI桌面中的bash能够执行此PyQt程序,但是在字符终端中的bash执行就会报错

想到是由于无图形界面的原因,在网上找了一下午,想实现一个功能就是在tty1中指定tty7来运行这个程序,但是没有找到解决办法,最后发现一个环境变量可以很Ok的解决此问题。

###此类问题可以归结于:在非图形终端执行了一个GUI程序,导致X11Server在此终端的环境下无法显示图形,需要手动指定X11Server把图形显示到其他的带图形界面的终端。

DISPLAY 变量
eg:DISPLAY=hostip:NumA.NumB
(注意当显示到本机的其他tty时,hostip 为空,一般情况下NumA,NumB为0)
eg:DISPLAY=:0.0

2019/03/25更新

有意栽花花不发,无心插柳柳成荫。

原文的本意只是简单记录了我的一个试验成功的实验,没想到那么多人关注这个。
原试验内容:你按ctrl+atl+F1进入tty1,然后你在tty1中执行带GUI功能的程序,一般就会报相应的显示错误。这个错误的原因就是DISPLAY变量没有设置的原因。你可以通过:echo ${DISPLAY}

简单来说,当你在终端执行一个带GUI功能的程序的时候,如果DISPLAY变量没有定义,就会报相应的错误。至少对于Xserver的系统是这样的。

DISPLAY 简单说明

我就是简单翻译此网页的某些我们关注的段落(如有侵权,联系我立即删除):https://gerardnico.com/ssh/x11/display

The magic word in the X window system is DISPLAY.
在X视窗系统中,这个比较神奇的SHELL变量是DISPLAY。

The X display server install itself normally as display number 0 on your local machine. 
在你的本地机器上,X显示服务程序在安装的时候,会把自己设置为“显示0”。

A display consists (simplified) of:
a keyboard,
a mouse
and a screen.
一个“显示”一般由以下内容组成:
一个键盘
一个鼠标
一个显示器。

A display is managed by a server program, known as an X server. The server serves displaying capabilities to other programs that connect to it.
一个“显示”被一个叫做X服务的服务程序管理。这个服务为连接它的其他程序提供“显示“服务。

The SSH protocol has the ability to securely forward X Window System applications over an encrypted SSH connection, so that you can run an application on the SSH server machine and have it put its windows up on your local machine without sending any X network traffic in the clear. $DISPLAY on the remote machine should point to localhost. SSH does the forwarding.
SSH协议通过一个加密的SSH连接,能够安全地传输X桌面系统程,因此,在没有发送任何X网络传输的时候,你可以毫无阻碍地在SSH所在的服务器运行你的程序并让其界面在你本地电脑启动起来。DISPLAY变量必须在远程机器上设置为localhost,SSH配置为启用X11转发。

The value of the display environment variable is:
这个DISPLAY环境变量的值是:

hostname:D.S
主机名:"显示号".“屏幕号”

where:
说明:

hostname is the name of the computer where the X server runs. An omitted hostname means the localhost.
一个运行了X服务的计算机的名字是主机名。一个缺省的主机名是localhost。

D is a sequence number (usually 0). It can be varied if there are multiple displays connected to one computer.
D 是一个通常为0的序列号。它可以区分这个有多少个“显示”连接到了这个计算机。

S is the screen number. A display can actually have multiple screens. Usually there's only one screen though where 0 is the default.
S 是一个屏幕号。一个“显示“能够有多个屏幕。通常,一个计算机有一个屏幕,其序号默认是0。

hostname:D.S means screen S on display D of host hostname; the X server for this display is listening at TCP port 6000+D.
hostname:D.S这种格式的定义是:“显示D”显示到一个主机为hostname的屏幕上。X服务对于这个“显示”是通过监听TCP端口6000+D 这个端口号实现的。(如:localhost:4.0,  对于这个显示实例,Xserver监听的就是6004这个端口.)

host/unix:D.S means screen S on display D of host host; the X server for this display is listening at UNIX domain socket /tmp/.X11-unix/XD (so it's only reachable from host).
host/unix:D.S这种格式的定义是:“显示D”显示到一个主机地址为host的屏幕上。X服务对于这个“显示”是通过监听UNIX本地socket实现的。因此host必须是可以连接的。

:D.S is equivalent to host/unix:D.S, where host is the local hostname.
:D.S 和host/unix:D.S是一样的。这里是一种简写方式,host是本地的主机名,如localhost.

以上翻译可能不太准确,我翻译很屁的。

2019/09/26更新 ,补充xhost命令

今天再ubuntu 18.04上,切换root,运行/snap/bin/gnome-system-monitor程序,显示如下:
在这里插入图片描述
我首先说明,这里我已经设置了DISPLAY环境变量,但是发现我被拒绝连接了。于是查了查,和xhost命令有关,xhost简单来说就是控制其他用户或者其他ip是否可以访问当前用户启动的xserver。
于是我解除其他用户访问限制:
xhost +
在这里插入图片描述
然后再次root重新运行,可以正常打开了。
在这里插入图片描述

2020/03/13更新 用xshell,putty等ssh链接工具链接时,显示图形界面

在这里插入图片描述
在这里插入图片描述
勾选后,你再次进入shell(重连ssh),echo $DISPLAY 会发现变量已经被定义了。下面用xshell为例。

在这里插入图片描述

如果没有DISPLAY变量还是空,则配置sshd_config文件。如下图打开x11转发:
/etc/ssh/sshd_config文件 如果画框为no改为yes
在这里插入图片描述
sudo service ssh restart 重启sshd服务
再次通过xshell连接linux目标。就可得到如下的图:(如未得到,多检查,多学习)
在这里插入图片描述
图中画框的tcp就是转发出来的x11链接,你如果再开一个ssh链接,你会发现DISPLAY变量又变了:
在这里插入图片描述
这个时候你在xshell终端中输入任何一个gui 程序,会弹出如下框,安装好后,就可以正常显示GUI界面了。

在这里插入图片描述
xmanager是收钱的,我这里用另外一个MobaXterm但是道理都是一样的。
在这里插入图片描述
其实这里的更新内容,在我翻译的那段文字里面有,只是不知道多少人看了!!!!哎!!!

总结

一句话来说,对于桌面是由x服务的图形系统来说,只有设置了DISPLAY变量,才能够让GUI程序正常的显示起来。
对于我们经常进入的桌面,然后开一个terminal,你会发现,DISPLAY已经被自动设置了。所以才没有问题。而对于我们进的不是桌面terminal来说,DISPLAY变量是没有设置的。需要我们手动设置,GUI程序才能够正常启动。

2019/09/26更新,如果无法正常显示, xserver安全访问系统可能会阻止你访问xserver,当设置了正确的DISPLAY变量后无法显示,请尝试xhost 命令解除访问控制。

#PS:请尊重原创,不喜勿喷

#PS:要转载请注明出处,本人版权所有.

有问题请留言,看到后我会第一时间回复

  • 16
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 29
    评论
### 回答1: 这个错误提示通常出现在使用Qt进行图形界面编程时,Qt无法连接显示器上的X11服务器。导致该错误的原因可能有以下几种: 1. 没有正确设置DISPLAY环境变量:X11服务器使用DISPLAY环境变量来指定要连接显示器。如果没有正确设置DISPLAY环境变量,Qt无法找到要连接显示器。你可以通过在命令行输入"echo $DISPLAY"来检查DISPLAY环境变量是否设置正确。 2. X11服务器未启动:Qt需要连接到X11服务器才能创建图形界面。如果X11服务器未启动,Qt无法连接显示器并创建图形界面。你可以尝试在命令行输入"xhost +"来启动X11服务器。 3. 没有权限连接到X11服务器:如果当前用户没有权限连接到X11服务器,Qt将无法连接显示器。你可以尝试以root权限运行你的程序,或者将当前用户添加到X11服务器的访问权限列表中。 4. X11服务器配置问题:有时X11服务器的配置可能会导致Qt无法连接显示器。你可以尝试重新配置X11服务器,或者查看X11服务器的日志以获取更多详细的错误信息。 要解决这个错误,你可以先检查DISPLAY环境变量是否正确设置,确保X11服务器已启动并且当前用户有权限连接到X11服务器。如果问题仍然存在,可以尝试重新配置X11服务器或查看相关的日志文件来获得更多的信息。 ### 回答2: 这个错误信息通常出现在运行基于Qt框架的程序时,它意味着程序无法连接显示器的显示设备。 在Ubuntu操作系统上,Qt通过X Window System进行图形显示的,而":0"表示连接显示器的第一个设备。当出现"could not connect to display :0"的错误提示时,可能有以下几种原因和解决方法: 1. X服务器未正常启动:可以尝试重新启动X服务器,或重启整个系统。 2. 缺少X11的运行环境:如果在命令行中运行的程序,可能需要安装运行Qt基于X11的应用程序所需的库,可以使用以下命令安装: ``` sudo apt-get install libx11-dev ``` 3. 没有正确设置环境变量:确保DISPLAY环境变量已经设置为正确的值,可以使用以下命令进行检查: ``` echo $DISPLAY ``` 如果显示为空或不是":0",可以通过以下命令进行设置: ``` export DISPLAY=:0 ``` 4. 使用SSH远程连接:如果通过SSH远程连接到Ubuntu,需要启用X11转发选项("-X"或"-Y"),例如: ``` ssh -X user@hostname ``` 确保远程服务器已经启用X11转发选项。 如果上述方法仍然无法解决问题,可能是其他更复杂的原因导致,比如驱动问题或硬件兼容性问题。可以尝试在其他的Ubuntu系统上运行程序,或者查阅相关文档、社区或论坛寻找更多的解决方案。 ### 回答3: 该错误信息是由于在 Ubuntu 上启动 Qt 应用时,没有连接显示器导致的。 在 Linux 系统上,图形界面通常使用 X11 展示。而当你在终端(没有图形界面)中执行 Qt 应用程序时,它会尝试连接到默认显示器 :0,但由于没有显示器,连接失败,因此会发生此错误。 要解决此问题,有几个可能的方式: 1. 使用 ssh -X 连接到远程主机:如果你是在通过 ssh 连接到远程主机,并且想在远程主机上运行 Qt 应用程序并将它的界面显示在你的本地主机上,你需要使用 ssh -X 命令进行连接。这样,你就能够在本地主机上显示 Qt 应用程序的界面了。 2. 检查 DISPLAY 变量的设置:确保在执行 Qt 应用程序之前,在终端中设置了正确的 DISPLAY 环境变量。你可以通过运行 echo $DISPLAY 命令来检查它的值。如果它没有设置为 :0,那么可以执行 export DISPLAY=:0 来设置它。 3. 使用虚拟桌面:如果你在没有显示器的环境中工作,可以尝试使用虚拟桌面来解决问题。一些工具如 Xvfb(X Virtual Framebuffer)可以让你在没有物理显示器的情况下模拟一个虚拟的 X11 显示器。你可以按照相关教程使用这些工具来创建和配置虚拟桌面,并设置 DISPLAY 环境变量连接到该虚拟显示器。 总结起来,该错误是由于 Qt 应用程序无法连接显示器导致的。解决方法包括使用 ssh -X 进行远程连接,检查 DISPLAY 环境变量的设置,以及使用虚拟桌面来模拟显示器。
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值