我正在为 arch x86_64 使用 CentOS 7 和 x11vnc 版本 0.9.13(版本 11.el7)。
我创建带有两个屏幕(:10.0 和:10.1)的 Xvfb,如下所示:
sudo Xvfb :10 -screen 0 1366x768x24+32 -screen 1 1066x768x24+32 -br +bs -ac &
我为第一个屏幕启动一个 x11vnc:
sudo x11vnc -display :10.0 -ncache 0 -rfbport 9999 -shared -forever -debug_ncache &
我可以使用 VNC 服务器来使用该屏幕:它可以工作:例如,我在上面打开 Firefox。
我杀死 x11vnc 并启动另一个,但对于第二个屏幕:
sudo x11vnc -display :10.1 -ncache 0 -rfbport 10000 -shared -forever -debug_ncache &
我可以使用 VNC 服务器来使用该屏幕:它可以工作:例如,我在其上打开 Chrome。
现在,我再次杀死 x11vnc,然后启动两个服务器,从第一个屏幕开始,然后是第二个屏幕:
sudo x11vnc -display :10.0 -ncache 0 -rfbport 9999 -shared -forever -debug_ncache &
sudo x11vnc -display :10.1 -ncache 0 -rfbport 10000 -shared -forever -debug_ncache &
我可以使用 VNC 服务器来使用第一个屏幕:它可以工作,我可以看到 Firefox 窗口。
但是,尝试连接到第二个 VNC 会导致崩溃,并显示以下跟踪信息:
*** buffer overflow detected ***: x11vnc terminated
======= Backtrace: =========
/lib64/libc.so.6(__fortify_fail+0x37)[0x7fd434365597]
/lib64/libc.so.6(+0x10c750)[0x7fd434363750]
/lib64/libc.so.6(+0x10e507)[0x7fd434365507]
/lib64/libvncserver.so.0(rfbProcessNewConnection+0x114)[0x7fd436d01764]
/lib64/libvncserver.so.0(rfbCheckFds+0x3f8)[0x7fd436d01c98]
/lib64/libvncserver.so.0(rfbProcessEvents+0x1d)[0x7fd436cf8c3d]
x11vnc[0x4a0951]
x11vnc[0x463d8a]
x11vnc[0x410c0a]
/lib64/libc.so.6(__libc_start_main+0xf5)[0x7fd434278b15]
x11vnc[0x41b201]
======= Memory map: ========
00400000-00542000 r-xp 00000000 fd:00 14735 /usr/bin/x11vnc
00741000-00742000 r--p 00141000 fd:00 14735 /usr/bin/x11vnc
00742000-00788000 rw-p 00142000 fd:00 14735 /usr/bin/x11vnc
00788000-00ad0000 rw-p 00000000 00:00 0 [heap]
7fd42f627000-7fd42f63c000 r-xp 00000000 fd:00 38 /usr/lib64/libgcc_s-4.8.5-20150702.so.1
7fd42f63c000-7fd42f83b000 ---p 00015000 fd:00 38 /usr/lib64/libgcc_s-4.8.5-20150702.so.1
7fd42f83b000-7fd42f83c000 r--p 00014000 fd:00 38 /usr/lib64/libgcc_s-4.8.5-20150702.so.1
7fd42f83c000-7fd42f83d000 rw-p 00015000 fd:00 38 /usr/lib64/libgcc_s-4.8.5-20150702.so.1
7fd42f83d000-7fd42f868000 rw-s 00000000 00:04 913866832 /SYSV00000000 (deleted)
7fd42f868000-7fd42f892000 rw-s 00000000 00:04 913834063 /SYSV00000000 (deleted)
7fd42f892000-7fd42f8bb000 rw-s 00000000 00:04 913801294 /SYSV00000000 (deleted)
7fd42f8bb000-7fd42f8e3000 rw-s 00000000 00:04 913768525 /SYSV00000000 (deleted)
7fd42f8e3000-7fd42f90a000 rw-s 00000000 00:04 913735756 /SYSV00000000 (deleted)
7fd42f90a000-7fd42f930000 rw-s 00000000 00:04 913702987 /SYSV00000000 (deleted)
7fd42f930000-7fd42f955000 rw-s 00000000 00:04 913670218 /SYSV00000000 (deleted)
7fd42f955000-7fd42f979000 rw-s 00000000 00:04 913637449 /SYSV00000000 (deleted)
7fd42f979000-7fd42f99c000 rw-s 00000000 00:04 913604680 /SYSV00000000 (deleted)
7fd42f99c000-7fd42f9be000 rw-s 00000000 00:04 913571911 /SYSV00000000 (deleted)
7fd42f9be000-7fd42f9df000 rw-s 00000000 00:04 913539142 /SYSV00000000 (deleted)
7fd42f9df000-7fd42f9ff000 rw-s 00000000 00:04 913506373 /SYSV00000000 (deleted)
7fd42f9ff000-7fd42fa1e000 rw-s 00000000 00:04 913473604 /SYSV00000000 (deleted)
7fd42fa1e000-7fd42fe1f000 rw-p 00000000 00:00 0
7fd42fe1f000-7fd430220000 rw-s 00000000 00:04 912457765 /SYSV00000000 (deleted)
7fd430220000-7fd430244000 r-xp 00000000 fd:00 4260 /usr/lib64/liblzma.so.5.0.99
7fd430244000-7fd430443000 ---p 00024000 fd:00 4260 /usr/lib64/liblzma.so.5.0.99
7fd430443000-7fd430444000 r--p 00023000 fd:00 4260 /usr/lib64/liblzma.so.5.0.99
7fd430444000-7fd430445000 rw-p 00024000 fd:00 4260 /usr/lib64/liblzma.so.5.0.99
7fd430445000-7fd4304a5000 r-xp 00000000 fd:00 4288 /usr/lib64/libpcre.so.1.2.0
7fd4304a5000-7fd4306a4000 ---p 00060000 fd:00 4288 /usr/lib64/libpcre.so.1.2.0
7fd4306a4000-7fd4306a5000 r--p 0005f000 fd:00 4288 /usr/lib64/libpcre.so.1.2.0
7fd4306a5000-7fd4306a6000 rw-p 00060000 fd:00 4288 /usr/lib64/libpcre.so.1.2.0
7fd4306a6000-7fd4306c7000 r-xp 00000000 fd:00 4383 /usr/lib64/libselinux.so.1
7fd4306c7000-7fd4308c7000 ---p 00021000 fd:00 4383 /usr/lib64/libselinux.so.1
7fd4308c7000-7fd4308c8000 r--p 00021000 fd:00 4383 /usr/lib64/libselinux.so.1
7fd4308c8000-7fd4308c9000 rw-p 00022000 fd:00 4383 /usr/lib64/libselinux.so.1
7fd4308c9000-7fd4308cb000 rw-p 00000000 00:00 0
7fd4308cb000-7fd4308d2000 r-xp 00000000 fd:00 4597 /usr/lib64/libffi.so.6.0.1
7fd4308d2000-7fd430ad1000 ---p 00007000 fd:00 4597 /usr/lib64/libffi.so.6.0.1
7fd430ad1000-7fd430ad2000 r--p 00006000 fd:00 4597 /usr/lib64/libffi.so.6.0.1
7fd430ad2000-7fd430ad3000 rw-p 00007000 fd:00 4597 /usr/lib64/libffi.so.6.0.1
7fd430ad3000-7fd430ada000 r-xp 00000000 fd:00 11023 /usr/lib64/librt-2.17.so
7fd430ada000-7fd430cd9000 ---p 00007000 fd:00 11023 /usr/lib64/librt-2.17.so
7fd430cd9000-7fd430cda000 r--p 00006000 fd:00 11023 /usr/lib64/librt-2.17.so
7fd430cda000-7fd430cdb000 rw-p 00007000 fd:00 11023 /usr/lib64/librt-2.17.so
7fd430cdb000-7fd430cdd000 r-xp 00000000 fd:00 13338 /usr/lib64/libXau.so.6.0.0
7fd430cdd000-7fd430edd000 ---p 00002000 fd:00 13338 /usr/lib64/libXau.so.6.0.0
7fd430edd000-7fd430ede000 r--p 00002000 fd:00 13338 /usr/lib64/libXau.so.6.0.0
7fd430ede000-7fd430edf000 rw-p 00003000 fd:00 13338 /usr/lib64/libXau.so.6.0.0
7fd430edf000-7fd430ee2000 r-xp 00000000 fd:00 4978 /usr/lib64/libkeyutils.so.1.5
7fd430ee2000-7fd4310e1000 ---p 00003000 fd:00 4978 /usr/lib64/libkeyutils.so.1.5
7fd4310e1000-7fd4310e2000 r--p 00002000 fd:00 4978 /usr/lib64/libkeyutils.so.1.5
7fd4310e2000-7fd4310e3000 rw-p 00003000 fd:00 4978 /usr/lib64/libkeyutils.so.1.5
7fd4310e3000-7fd4310f0000 r-xp 00000000 fd:00 5356 /usr/lib64/libkrb5support.so.0.1
7fd4310f0000-7fd4312f0000 ---p 0000d000 fd:00 5356 /usr/lib64/libkrb5support.so.0.1
7fd4312f0000-7fd4312f1000 r--p 0000d000 fd:00 5356 /usr/lib64/libkrb5support.so.0.1
7fd4312f1000-7fd4312f2000 rw-p 0000e000 fd:00 5356 /usr/lib64/libkrb5support.so.0.1
7fd4312f2000-7fd431368000 r-xp 00000000 fd:00 4770 /usr/lib64/libgmp.so.10.2.0
7fd431368000-7fd431567000 ---p 00076000 fd:00 4770 /usr/lib64/libgmp.so.10.2.0caught signal: 6
11/10/2016 17:24:00 deleted 43 tile_row polling images.
现在,让我们以相反的顺序启动 x11vnc 服务器:先启动第二个屏幕,然后启动第一个屏幕:
sudo x11vnc -display :10.1 -ncache 0 -rfbport 10000 -shared -forever -debug_ncache &
sudo x11vnc -display :10.0 -ncache 0 -rfbport 9999 -shared -forever -debug_ncache &
当我尝试使用 VNC 到达屏幕:10.1(第二个屏幕,但启动了第一个 x11vnc)时,它起作用了:我看到了 Chrome 窗口。
但是,尝试连接到屏幕:10.0(最后一个 x11vnc 启动),x11vnc 崩溃,并具有与上面相同的跟踪(第一个 x11vnc 服务器仍然完好无损,运行良好)。
注意:我在 Windows 上使用 RealVNC 和 TightVNC 作为客户端。
他们都使第二台服务器崩溃。
注 2:在显示器 :10 和 :11 上运行两个单独的 Xvfb,每个显示器只有一个屏幕 (0),并将两个 x11vnc 服务器指向 :10 和 :11 会导致相同的崩溃。
注 3:我以 root 身份运行 Xvfb 和 x11vnc。以普通用户身份运行它们也会导致同样的崩溃。
我做错了什么?
有没有一种方法可以只启动一个 x11vnc 服务器,并为两个 X11 屏幕提供两个端口?
这是 x11vnc 的错误吗?
答案1
我的系统上安装的 libvncserver 版本似乎有问题。
但它是最新版本。
x11vnc 可以编译为使用它自己的 libvncserver。
我从 x11vnc 读取了 libvncserver 的源代码:它们不包含导致崩溃的方法。
所以我想如果我安装了gcc,所有-devel库,重新编译x11vnc,安装它等等,它就会起作用。
大概。
相反,我使用了另一种解决方案:
Xvnc 可以同时执行内存中 X 服务器和 VNC 服务器。
而且它不会崩溃。
所以我现在使用这个配置。