XDMCP

提供: ArchWiki
ナビゲーションに移動 検索に移動

Wikipedia: から

X ディスプレイマネージャーコントロールプロトコル (XDMCP) は UDP ポート 177 を使用します。X サーバーは、クエリパケットを送信してディスプレイマネージャーにセッションを開始するように要求します。ディスプレイマネージャーがその X サーバーへのアクセスを許可すると、ディスプレイマネージャーは Willing パケットを X サーバーに送り返すことで応答します。

これにより、X セッションをリモートで開くことができます。

警告: XDMCP は、Telnet と同様に、暗号化されていない認証を実行します。スヌーピングが可能である場合、システムは攻撃に対して脆弱になります。デフォルトでは無効になっており、X トラフィックには ssh トンネルを使用することが推奨されます。

グラフィカルログインの設定

XDM

/etc/X11/xdm/xdm-config を開いて以下をコメントアウトしてください:

DisplayManager.requestPort:    0

以下のようになります:

!DisplayManager.requestPort:    0

次に /etc/X11/xdm/Xaccess を編集して全てのホストでログインウィンドウを表示できるようにしてください。以下のようになっている行を見て下さい:

*             #any host can get a login window

行頭のハッシュ記号 '#' を削除してください。

ネットワークインターフェイスが複数ある場合は以下のように行を追加します:

LISTEN 192.168.0.10

192.168.0.10 はサーバーの IP アドレスに置き換えて下さい。

次に xdm.service再起動 して下さい。

GDM

設定ファイルで XDMCP を有効にします。

/etc/gdm/custom.conf
[xdmcp]
Enable=true
Port=177

次に gdm.service再起動 して下さい。

LightDM

設定ファイルで XDMCP サーバーを有効にします。

/etc/lightdm/lightdm.conf
[XDMCPServer]
enabled=true
port=177

ヘッドレスシステムでは、LightDM がバックグラウンドで実行できるように、1 つのシートの自動起動を無効にします。

[LightDM]
start-default-seat=false

次に lightdm.service再起動 して下さい。

LAN 上のリモートマシンから X にアクセス

以下のコマンドでネットワーク上の 192.168.0.10 のコンピュータのログインマネージャにアクセスすることができます。TCP と UDP ストリームが開きます。SSH 接続でログインマネージャにアクセスすることはできません。

# Xnest -query 192.168.0.10 -geometry 1280x1024 :1

もしくは、Xnest で描画が更新されない問題が起こる場合、Xephyr を使用:

# Xephyr -query 192.168.0.10 -screen 1280x1024 -br -reset -terminate :1

もしくは、ランレベル3の場合:

# X -query your_server_ip

Xserver がモニターを認識して適切な解像度が設定されるはずです。

ノート: リモートホストから XDMCP Direct/Query と Broadcast 接続を有効にすることでリモートホストで XDM を使ってローカル X サーバーを起動しなくてもよくなります。

上述のように XDMCP のアクセスを許可したら、/etc/X11/xdm/Xservers を編集して以下をコメントアウト:

#:0 local /usr/bin/X :0

root で XDM を起動して下さい。例: xdm -config /etc/X11/xdm/archlinux/xdm-config

シンクライアントの設定

dhcp と tftp サーバーを設定する必要があります。Dnsmasq が両方のサーバーの働きをします。ネットワークブートイメージは thinstation プロジェクトを見て下さい。ネットワークカードが PXE をサポートしていない場合、Etherboot を試すことができます。

GUI ベースのクライアント

トラブルシューティング

Session declined: Maximum Number of Sessions Reached

/etc/gdm/custom.conf を編集して MaxSessions を追加してください:

[xdmcp]
Enable=true
MaxSessions=X