今回はボクが何かを開発するにあたって度々必要になったことがあるタイトルの内容を自分メモも含めてまとめたいと思います。
要するにこういうことを実現する
遠隔でLinuxマシンに繋げた際に何かの実行結果にGUIの表示が必要な場合などに使えます。ん?リモートデスクトップでつないで直接使えばいいんじゃないん?という話になるかもですがヘッドレス化させてる個体だったりとにかく処理をダイエットさせたいケースとかに使えるかなと。実際色んな応用に使えると思うので覚えておいて損は無いと思います。あとなんかカッコいいことしてる感が無駄にでます。もう使う理由はこれが全て。
今回はWindows側でGUIの表示までを書いていきたいと思います。そこまでできればPythonか何かでカメラ映像を表示させるところまではきっとワケはないはず。
概要偏
X Window System
まずUnixやLinuxがどうGUIを実現させているのか。こやつらは X Window System というシステムの上でなりたっております。ほとんどのUNIX系システムで標準採用されており、いろーんな呼び方がありますがX11とかX Window Systemとかが良く見かけるそう。略して X とだけ呼ぶみたいです。略しすぎ。
クライアントとサーバー
1. キーボード等の入力端末からの情報
2. サーバーからクライアントへ入力データを送信
3. 受け取ったデータを元に処理結果をサーバーへ送信
4. 結果をディスプレイに表示
普段ボクたちが頭の中でイメージできるクライアントとサーバーの関係とは逆のイメージになりますね。
クライアントは端末エミュレータ、つまり今回で言うsshで繋げる先のマシンがクライアントになります。
逆に、サーバーはユーザーが実際に操作している接続元のマシンがサーバーとなります。
つまりクライアントはサーバーから送られてくる入力情報を解釈して描画命令を発行、サーバーはクライアントから描画情報を解釈してディスプレイに表示させます。
ネットワーク上で動作可能
必ずしもクライアントとサーバーが同一マシン上で動作する必要はなく、ネットワーク越しでクライアント、サーバーに分かれて動作することが可能です。
これらの通信には X プロトコルというOSに依存しない通信規約を用いているので、ハードウェア、OSに依存せずに扱う事が出来ます。便利なもんだ。
ざっくりと前提知識を雰囲気で理解したところで実際に動かしてましょう。まずはインストール偏からどうぞ↓
インストール偏
Step1
UNIX系OSがインストールされている端末を用意するか、手持ちのWindowsにWSLをインストールしてください。今回の参考画像ではローカルのWindows内にWSLをインストールしてテストしていきます。
Step2
なにかしらの形で用意できたら、次に前述した X Window System をお持ちのWindows上に用意します
今回はWindows側がサーバーとなるので、そのX serverを用意する為に専用のソフトウェアをダウンロードしてインストールします。このソフトウェアがまどろっこしいことにいくつかあるんですが、今回はフリーで使える「VcXsrv」を使用します。
VcXsrv
https://sourceforge.net/projects/vcxsrv/
C:\Program Filesの中にVcXsrvフォルダが作成されているかと思います。この中にあるXLaunchというアプリケーションを使用します
設定偏
クライアント側
環境設定をするためにホームディレクトリ以下にある.profile、もしくは.bash_profileを編集します。
どれやねん!ってなった方は $~/.bash_profileを編集してください。無い場合は
$ touch ~/.bash_profile
で作成します。そして次のコードを入力していきます。
$ echo export DISPLAY=localhost:0.0 >> ~/.bash_profile
$ source ~/.bash_profile
最後に以下のコードで設定が反映されているか確認します。
$ echo $DISPLAY
これでさっき入力した localhost:0.0 がコンソールに出力されていれば成功です。
このDISPLAY環境変数で、Xサーバーの場所、つまり表示先を指定します。localhostがアドレスになっているので、もしローカル内にサーバーが無い場合は指定のIPをここに入力すればいいだけですね!簡単。ちなみにアドレスの後ろにある数字はディスプレイ番号を指定しています。接続先にディスプレイが複数ある場合に使用します。今回は0を指定しているので、デフォルトの画面が表示対象になります。
サーバー側
先ほどインストールしたアプリケーション xlaunch.exe を立ち上げるだけです。
もしクライアントとサーバーが同一マシン内で動作しない場合は、先ほどインストールした VcXsrv にちょっとした変更が必要です。
VcXsrvのフォルダ内にX0.hostsというファイルがあるのでこれに一行追記します。
追記内容は、クライアントのIPアドレスです。管理者権限でないと編集できないのでご注意を
クライアントのIPアドレスを追加
以上で準備は完了です
実践偏
では実際に動かしてみましょう。WSLでやっている場合はまだ何もインストールされていないので、Xサーバー対応のアプリケーションを以下のコマンドでインストールします。
$ sudo apt-get install -y x11-apps
これで簡単なGUIアプリケーションをインストールできたので早速試してみましょう。以下のコマンドでアプリケーションを実行します。
$ xeyes
謎の目玉が表示されれば成功です。正しく設定されていない場合はエラーが表示されますので、その際は先ほど編集した~/.bash_profileか、接続先のIPを確認してください。
たまに起動すると謎に安らぐ(疲れてるワケじゃないです)
他にも $ xclac で電卓を出せたりします。
お疲れさまでした
色んなところで幅広く使えそうですが、それ使わなくてもこれが~みたいな最適解はケースによっていくつか存在しそうなので、状況をみながら適材適所で役立てていきたいですね