web-dev-qa-db-ja.com

2つの画面と2つのx11vncサーバー(各画面に1つ)を備えたXvfb:最初の1つだけが機能します

Archx86_64にCentOS7およびx11vncバージョン0.9.13(リリース11.el7)を使用しています。

次のような2つの画面(:10.0と:10.1)でXvfbを作成します。

Sudo Xvfb :10 -screen 0 1366x768x24+32 -screen 1 1066x768x24+32 -br +bs -ac &

最初の画面で1つのx11vncを起動します。

Sudo x11vnc -display :10.0 -ncache 0 -rfbport 9999 -shared -forever -debug_ncache &

VNCサーバーを使用してその画面を使用できます。それは機能します。たとえば、Firefoxを開きます。

そのx11vncを強制終了し、別のx11vncを開始しますが、2番目の画面では次のようになります。

Sudo x11vnc -display :10.1 -ncache 0 -rfbport 10000 -shared -forever -debug_ncache &

VNCサーバーを使用してその画面を使用できます。動作します。たとえば、Chromeを開きます。

ここで、x11vncを再度強制終了し、最初の画面から始めて2番目の画面から始めて、両方のサーバーを起動します。

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ウィンドウが表示されます。
しかし、2番目の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サーバーを逆の順序で起動しましょう。最初に2番目の画面、次に最初の画面です。

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(2番目の画面、ただし最初のx11vncが起動)に到達しようとすると、機能します。Chromeウィンドウが表示されます。
しかし、画面:10.0(最後にx11vncが起動された)に接続しようとすると、x11vncが上記と同じトレースでクラッシュします(最初のx11vncサーバーはそのままで、正常に動作しています)。

注:クライアントとしてWindowsでRealVNCとTightVNCを使用しました。
どちらも2番目のサーバーをクラッシュさせます。

注2:ディスプレイ:10と:11でそれぞれ1つの画面(0)のみで2つの別々のXvfbを実行し、2つのx11vncサーバーを:10と:11にポイントすると、同じクラッシュが発生します。

注3:ルートとしてXvfbとx11vncの両方を実行しました。それらを通常のユーザーとして実行すると、同じクラッシュが発生します。

私は何を間違えましたか?
両方のX11画面に2つのポートを備えた1つのx11vncサーバーのみを起動する方法はありますか?
x11vncのバグですか?

1
Sebien

私のシステムにインストールされているlibvncserverのバージョンにバグがあるようです。
しかし、それは最新バージョンです。

x11vncは、独自のlibvncserverを使用するようにコンパイルできます。
x11vncからlibvncserverのソースを読み取りました。クラッシュの原因となるメソッドが含まれていません。
したがって、gcc、すべての-develライブラリをインストールし、x11vncを再コンパイルし、インストールするなどすると、機能すると思います。
恐らく。

代わりに、別のソリューションを使用しました。
Xvncは、メモリ内のXサーバーとVNCサーバーの両方を同時に実行できます。
そしてそれはクラッシュしません。
それで、私は今この構成を使用しています。

1
Sebien