「Xinit」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(→‎xserverrc: 仮想コンソールに修正)
 
(2人の利用者による、間の12版が非表示)
5行目: 5行目:
 
[[es:Xinit]]
 
[[es:Xinit]]
 
[[fr:Xinit]]
 
[[fr:Xinit]]
[[it:Xinit]]
 
 
[[pt:Xinit]]
 
[[pt:Xinit]]
 
[[ru:Xinit]]
 
[[ru:Xinit]]
13行目: 12行目:
 
{{Related|Xorg}}
 
{{Related|Xorg}}
 
{{Related|xprofile}}
 
{{Related|xprofile}}
{{Related|X resources}}
+
{{Related|Xresources}}
 
{{Related articles end}}
 
{{Related articles end}}
  +
[[Wikipedia:xinit|Wikipedia]] から:
  +
:'''xinit''' プログラムにより、ユーザが [[Xorg]] ディスプレイサーバを手動で起動することが可能になります。{{man|1|startx}} スクリプトは {{man|1|xinit}} のフロントエンドです。
   
  +
通常、''xinit'' は[[ウィンドウマネージャ]]や[[デスクトップ環境]]を起動するために使用されます。''xinit'' を使うことでウィンドウマネージャ無しで GUI アプリケーションを実行することができますが、多くのグラフィカルアプリケーションは [[Wikipedia:ja:Extended Window Manager Hints|EWMH]] に準拠したウィンドウマネージャを期待します。[[ディスプレイマネージャ]]は [[Xorg]] を起動し、一般的に [[xprofile]] を読み込みます。
{{ic|~/.xinitrc}} ファイルは {{ic|xinit}} や {{ic|startx}} によって読み込まれるシェルスクリプトです。主として、X サーバーが起動した時に[[デスクトップ環境]]や[[ウィンドウマネージャ]]などのプログラムを起動するのに使われます (デーモンの起動や環境変数のセットなど)。{{ic|xinit}} と {{ic|startx}} プログラムは [[Xorg|X Window System]] を起動させ、X を直接 {{ic|/etc/init}} から起動できないシステムや複数のウィンドウシステムを使っている環境で、一番最初のクライアントプログラムとして動作します。
 
 
{{ic|~/.xinitrc}} の主要な仕事の一つは、{{ic|/usr/bin/startx}} や {{ic|/usr/bin/xinit}} プログラムが実行されたときに X Window System のためにどのクライアントを呼び出すか指定することです。様々な追加の記述やコマンドが存在しており、それらを {{ic|~/.xinitrc}} に追加して、その後のシステムのカスタマイズも行えます。
 
 
ほとんどの DM は xinit の前に同じようなファイルである [[xprofile]] も読み込みます。
 
   
 
== インストール ==
 
== インストール ==
28行目: 25行目:
 
== 設定 ==
 
== 設定 ==
   
''xinit'' と ''startx'' はオプションでクライアントプログラムの引数を取ります。[[#Override xinitrc]] を参照してください。もし、引数を与えなければ、クライアントプロラムを起動するシェルスクリプトとして、{{ic|~/.xinitrc}} を探します。
+
''xinit'' と ''startx'' は任意でクライアントプログラムの引数を受け取ります。[[#xinitrc をオーバーライドする]] を参照してください。もし、引数を与えなければ、クライアントプロラムを起動するシェルスクリプトとして、{{ic|~/.xinitrc}} を探します。
   
 
=== xinitrc ===
 
=== xinitrc ===
   
{{ic|~/.xinitrc}} は X に応じてプログラムを実行し、X サーバの起動時に環境変数を設定するのに便利です。ユーザのホームディレクトリに存在する場合、''startx'' と ''xinit'' 実行します。それ以外の場合、''startx'' はデフォルトの {{ic|/etc/X11/xinit/xinitrc}} を実行します。
+
{{ic|~/.xinitrc}} はX に依存するプログラムを実行し、X サーバの起動時に環境変数を設定するのに便利です。このファイルがユーザのホームディレクトリに存在する場合、''startx'' と ''xinit'' はこのファイルを実行します。それ以外の場合、''startx'' はデフォルトの {{ic|/etc/X11/xinit/xinitrc}} を実行します。
   
{{note|''Xinit'' には、ファイルを実行する代わりに独自のデフォルトの動作があります。詳細については、{{man|1|xinit}} を参照してください。}}
+
{{note|''Xinit'' には、このファイルを実行する以外に独自のデフォルトの動作があります。詳細については、{{man|1|xinit}} を参照してください。}}
   
デフォルトの xinitrc は [[Twm]] と, {{Pkg|xorg-xclock}}, [[Xterm]] とで基本的な環境をスタートします必要なパッケージインストールされているとして。そのため、別のウィンドウマネージャやデスクトップ環境を始めるには、まずデフォルトの {{ic|xinitrc}} のコピーをホームディレクトリに作成します
+
デフォルトの xinitrc は[[Twm]]{{Pkg|xorg-xclock}}、そして [[Xterm]] を起動した基本的な環境を開始します (このファイルは、必要なパッケージインストールされていると仮定しています)。そのため、別のウィンドウマネージャやデスクトップ環境を始めるには、まずデフォルトの {{ic|xinitrc}} のコピーをホームディレクトリに作成します:
   
 
$ cp /etc/X11/xinit/xinitrc ~/.xinitrc
 
$ cp /etc/X11/xinit/xinitrc ~/.xinitrc
   
それからそのファイルを編集して、デフォルトのプログラムを必要なコマンドに置き換えます {{ic|exec}} で実行するコマンドに続く行は無視されることを覚えておいてください。たとえば、{{ic|xscreensaver}} をバックグラウンドで開始してから [[Openbox#Standalone|openbox]] を開始するには、以下のように記述します:
+
それからそのファイルを[[テキスト編集|編集]]して、デフォルトのプログラムを好きなコマンドに置き換えてください。{{ic|exec}} を使用するコマンド以降の行は無視されることを覚えておいてください。たとえば、{{ic|xscreensaver}} をバックグラウンドで開始してから [[Openbox#スタンドアロン|openbox]] を開始するには、以下のように記述します:
   
 
{{hc|~/.xinitrc|
 
{{hc|~/.xinitrc|
47行目: 44行目:
 
exec openbox-session}}
 
exec openbox-session}}
   
{{Note|最低限、{{ic|/etc/X11/xinit/xinitrc}} にある最後の {{ic|if}} ブロックが、あなたの {{ic|~/.xinitrc}} ファイルにあることを確認してください。これにより、 {{ic|/etc/X11/xinit/xinitrc.d}} にあるスクリプトが読み込まれることを確認できます。}}
+
{{Note|最低限、{{ic|/etc/X11/xinit/xinitrc}} にある最後の {{ic|if}} ブロックが、あなたの {{ic|~/.xinitrc}} ファイルにあることを確認してください。これにより、 {{ic|/etc/X11/xinit/xinitrc.d}} にあるスクリプトが読み込まれることを保証できます。}}
   
スクリーンセーバーや壁紙アプリケーションといった、長く実行されるプログラムがウィンドウマネージャの前に開始される場合、それらをフォークするか {{ic|&}} 記号をつけてバックグラウンドで実行しなければなりません。そうしないと、スクリプトはウィンドウマネージャやデスクトップ環境を実行する前に停止し、それらのプログラムが終了するのを待ちます。いくつかのプログラムは、 [[xrdb]] のように、レースバグを回避するためフォークしないでください。{{ic|exec}} を前につけることで、スクリプトプロセスをウィンドウマネージャプロセスへ入れ替えることができます。これにより、たとえこのプロセスがバックグランドへフォークされても X が終了しないようにできます。
+
スクリーンセーバーや壁紙アプリケーションといった、長く実行されるプログラムがウィンドウマネージャの前に開始される場合、それらをフォークするか {{ic|&}} 記号をつけてバックグラウンドで実行しなければなりません。そうしないと、スクリプトはウィンドウマネージャやデスクトップ環境を実行する前に停止し、それらのプログラムが終了するのを待ちます。いくつかのプログラムは、 [[xrdb]] のように、競合バグを回避するためフォークしないでください。{{ic|exec}} を前につけることで、スクリプトプロセスをウィンドウマネージャプロセスへ入れ替えることができます。これにより、たとえこのプロセスがバックグランドへフォークされても X が終了しないようにできます。
   
 
=== xserverrc ===
 
=== xserverrc ===
   
{{ic|xserverrc}} ファイルは、X サーバの起動を担当するシェルスクリプトです。''startx'' と ''xinit'' はどちらも {{ic|~/.xserverrc}} が存在すればそれを実行し、 ''startx'' はそうでなければ {{ic|/etc/X11/xinit/xserverrc}} を使用します。
+
{{ic|xserverrc}} ファイルは、X サーバの起動を担当するシェルスクリプトです。''startx'' と ''xinit'' はどちらも {{ic|~/.xserverrc}} が存在すればそれを実行し、存在しなければ ''startx'' は {{ic|/etc/X11/xinit/xserverrc}} を使用します。
   
{{ic|logind}} で [[一般的なトラブルシューティング#セッションのパーミッション|セッションのパーミッション]] を維持し、端末を切り替えてスクリーンロッカーを回避するのを防ぐために、ログインたのと同じ仮想コンソールで [[Xorg]] を起動しなければなりません [http://blog.falconindy.com/articles/back-to-basics-with-x-and-systemd.html]。そのため、{{ic|~/.xserverrc}} ファイルで {{ic|vt$XDG_VTNR}} を指定することが推奨されます
+
[[一般的なトラブルシューティング#セッションのパーミッション|認証されたセッション]]を {{ic|logind}} で維持できるようにし、かつ、ターミナルを切り替えることで画面ロッカーをバイパスできないようにするために、ログインが行われたのと同じ仮想コンソールで [[Xorg]] を起動しなければなりません [http://blog.falconindy.com/articles/back-to-basics-with-x-and-systemd.html]。そのため、{{ic|~/.xserverrc}} ファイルで {{ic|vt$XDG_VTNR}} を指定することが推奨されます:
   
 
{{hc|~/.xserverrc|
 
{{hc|~/.xserverrc|
65行目: 62行目:
 
全てのコマンドラインオプションの一覧は {{man|1|Xserver}} を参照してください。
 
全てのコマンドラインオプションの一覧は {{man|1|Xserver}} を参照してください。
   
{{Tip|{{ic|-nolisten local}} を {{ic|-nolisten tcp}} の後に追加すると、X11 の抽象ソケットを無効にして分離を助けることができます。 これが X11 のセキュリティにどのよう影響るかについては、[https://tstarling.com/blog/2016/06/x11-security-isolation/ quick background] があります。}}
+
{{Tip|{{ic|-nolisten local}} を {{ic|-nolisten tcp}} の後に追加すると、X11 の抽象ソケットを無効でき、X の分離に役立ちます。これが X11 のセキュリティにどのよう影響を及ぼしうかについて[https://tstarling.com/blog/2016/06/x11-security-isolation/ 簡単な説明]があります。}}
   
また、サーバを起動するコンソールとは別のコンソールで X を表示させたい場合は、 {{ic|/usr/lib/systemd/systemd-multi-seat-x}} が提供する X サーバラッパーを使って表示させることも可能です。便なように、 ''xinit'' と ''startx'' は {{ic|~/.xserverrc}} を修正することでこのラッパーを使うようにセットアップすることができます。
+
あるいは、サーバを起動するコンソールとは別のコンソールで X を表示させたい場合は、 {{ic|/usr/lib/systemd/systemd-multi-seat-x}} が提供する X サーバラッパーを使って表示させることも可能です。利便性のために、''xinit'' と ''startx'' は {{ic|~/.xserverrc}} を修正することでこのラッパーを使うようにセットアップすることができます。
   
 
{{Note|X セッションから Xorg ログファイルへの出力のリダイレクトを再び有効にするには、{{ic|-keeptty}} オプションを追加してください。詳しくは [[Xorg#セッションログのリダイレクト]] を見て下さい。}}
 
{{Note|X セッションから Xorg ログファイルへの出力のリダイレクトを再び有効にするには、{{ic|-keeptty}} オプションを追加してください。詳しくは [[Xorg#セッションログのリダイレクト]] を見て下さい。}}
73行目: 70行目:
 
== 使用方法 ==
 
== 使用方法 ==
   
Xorg を通常のユーザとして実行するには、次のように実行します
+
Xorg を通常のユーザとして実行するには、次のように実行します:
   
 
$ startx
 
$ startx
81行目: 78行目:
 
$ xinit -- :1
 
$ xinit -- :1
   
{{Note|''xinit'' は他の X サーバがすでに起動している場合は、複数の表示を処理しません。その場合、{{ic|-- :''display_number''}} ({{ic|''display_number''}} は {{ic|1}} 以上) を付けてディスプレイを指定してください。}}
+
{{Note|''xinit'' は他の X サーバがすでに起動している場合は、複数のディスプレイを処理しません。その場合、{{ic|-- :''display_number''}} ({{ic|''display_number''}} は {{ic|1}} 以上) を付けてディスプレイを指定しなければなりません。}}
   
 
これでお好みのウィンドウマネージャー(またはデスクトップ環境)が正しく起動するはずです。
 
これでお好みのウィンドウマネージャー(またはデスクトップ環境)が正しく起動するはずです。
   
X を終了するには、ウィンドウマネージャーの exit 関数を実行してください(exit 関数があれば)。そのような機能がない場合は次のように実行します
+
X を終了するには、ウィンドウマネージャーの exit 関数を実行してください (exit 関数があると仮定します)。そのような機能がない場合は次のように実行します:
   
 
$ pkill -15 Xorg
 
$ pkill -15 Xorg
   
{{Note|''pkill'' は実行中の X インスタンスを全て kill します。現在の仮想端末上のウィンドウマネージャーを kill するには、次のように実行します:
+
{{Note|''pkill'' は実行中の X インスタンスを全て kill します。現在の仮想コンソール上のウィンドウマネージャーを kill するには、次のように実行します:
   
 
$ pkill -15 -t tty"$XDG_VTNR" Xorg
 
$ pkill -15 -t tty"$XDG_VTNR" Xorg
98行目: 95行目:
 
== ヒントとテクニック ==
 
== ヒントとテクニック ==
   
=== コマンドラインから xinitrc を上書きする ===
+
=== xinitrc をオーバーライドする ===
   
{{ic|~/.xinitrc}} は既に記述しているが、他の WM/DE を試してみたい場合、ウィンドウマネージャのパスを加えて {{ic|startx}} を実行することができます:
+
すでに {{ic|~/.xinitrc}} があるが、他のウィンドウマネージャやデスクトップ環境を試してみたい場合、ウィンドウマネージャのパスを付け加えて ''startx'' を実行することで、ウィンドウマネージャを起動させることができます。例えば:
   
$ startx /full/path/to/window-manager
+
$ startx /usr/bin/i3
   
  +
ウィンドウマネージャのバイナリが引数を取る場合、引数全体が ''startx'' の第1パラメータとして認識されるようにするために引数を引用符で囲む必要があります:
フルパスが必要なので注意してください。
 
   
  +
$ startx "/usr/bin/''application'' --''key value''"
ウィンドウマネージャに引数を指定する場合、''startx'' のパラメータとしてクォートで囲う必要があります:
 
$ startx "/full/path/to/window-manager --key value"
 
   
また、{{ic|--}}後にカスタムオプションを指定して (デフォルトの X サーバーオプションが入っている) {{ic|/etc/X11/xinit/xserverrc}} を上書きすることできます。例:
+
完全なパスが '''必要である''' ことに注意してください。また、[[#xserverrc]] スクリプトのカスタムオプションは、{{ic|--}} 記号のあとに付け加えることで指定できます:
   
$ startx /usr/bin/enlightenment -- -nolisten tcp -br +bs -dpi 96 vt$XDG_VTNR
+
$ startx /usr/bin/enlightenment -- -br +bs -dpi 96
   
  +
{{man|1|startx}} も参照してください。
または:
 
   
  +
{{Note|1={{ic|/etc/X11/xinit/xinitrc.d/}} にあるスクリプトはスキップされるので、環境変数 {{ic|DISPLAY}} を設定する必要があるかもしれません。次のように実行することで、''i3'' を好きなディスプレイに表示させてみることができます: {{ic|1=DISPLAY=:''display_number'' startx /usr/bin/i3}}。}}
$ xinit /usr/bin/enlightenment -- -nolisten tcp -br +bs -dpi 96 vt$XDG_VTNR
 
   
  +
{{Tip|これにより通常の GUI プログラムを開始できますが、基本的なウィンドウマネージャの機能はありません。[[#ウィンドウマネージャを使わずにアプリケーションを起動する]] と [[ゲーム#別の X サーバーでゲームを起動する]] を参照してください。}}
{{ic|man startx}} を参照してください。
 
 
{{Tip|通常の GUI プログラムを起動するのに使うこともできます。[[#ウィンドウマネージャを使わずにアプリケーションを起動]] や [[ゲーム#別の X サーバーでゲームを起動する]] を参照。}}
 
   
 
=== ログイン時に X を自動起動 ===
 
=== ログイン時に X を自動起動 ===
   
''startx'' が正しく [[xinit#設定|設定]] されていることを確認します
+
''startx'' が適切に[[#設定|設定されている]]ことを確認してください
   
[[コマンドラインシェル#ログインシェル|ログインシェル]] の初期化ファイル (例: [[Bash]] の場合は {{ic|~/.bash_profile}}, [[Zsh]] の場合は {{ic|~/.zprofile}}) に以下の内容を記述してください
+
以下を[[ログインシェル]]の初期化ファイル (例: [[Bash]] の場合は {{ic|~/.bash_profile}}[[Zsh]] の場合は {{ic|~/.zprofile}}) に記述してください:
   
 
{{bc|1=<nowiki>
 
{{bc|1=<nowiki>
133行目: 127行目:
 
</nowiki>}}
 
</nowiki>}}
   
複数の仮想コンソールでグラフィカルログインを使用したい場合は、{{ic|-eq}} 比較を {{ic|-le 3}} (vt1 から vt3 まで) のようなものに置き換えること可能です。
+
複数の仮想コンソールでグラフィカルログインを使用したい場合は、{{ic|-eq}} 比較演算子を {{ic|-le 3}} (vt1 から vt3 まで) のようなものに置き換えること可能です。
   
仮想コンソールを検出別の条件として{{ic|<nowiki>"$(tty)" = "/dev/tty1"</nowiki>}} は {{ic|-le}} との比較が出来ません、 {{ic|<nowiki>"$(fgconsole 2>/dev/null || echo -1)" -eq 1</nowiki>}} は [[シリアルコンソール]] では機能しないことが挙げられ
+
仮想コンソールを検出できる条件として {{ic|<nowiki>"$(tty)" = "/dev/tty1"</nowiki>}} もありますが、これは {{ic|-le}} を使って比較することできません。また、{{ic|<nowiki>"$(fgconsole 2>/dev/null || echo -1)" -eq 1</nowiki>}} という書き方もありますが、こっちは[[シリアルコンソール]]では動きせん
   
X セッションが終了してもログインしたままにしたい場合は、{{ic|exec}} をてください。
+
{{ic|exec}} コマンドは、X サーバが終了、クラッシュ、または攻撃者によって kill されたときに、ユーザがログアウトすることを保証します。リスクを犯して、X セッションが終了したときにログイン状態を維持したい場合は、{{ic|exec}} を取りてください。
   
  +
[[Fish#ログイン時に X を起動]] と [[systemd/ユーザー#ディスプレイマネージャを使わずに Xorg に自動ログイン]] も参照してください。
{{Warning|{{ic|exec}} がなければ、X を Kill することができます、これであなたのホームディレクトリのシェルとファイルへのアクセスを取得することができます。このことがあなたにとって重要かどうか、上記のことを実行する前に判断してください}}
 
   
[[Fish# ログイ X を起|ログイン時に X を起動]] と [[systemd/ユザー#ディスプレイマネージャを使わずに Xorg に自動ログイン]] も参照してください
+
{{Tip|この方法は [[getty#仮想コソール動ログイン|仮想コンソに自動ログイン]] と組み合わせることができます}}
   
  +
=== デスクトップ環境/ウィンドウマネージャを切り替える ===
{{Tip|この方法は [[getty#仮想コンソールに自動ログイン|仮想コンソールに自動ログイン]] と組み合わせることができます}}
 
   
  +
様々なデスクトップ環境やウィンドウマネージャを頻繁に切り替える場合、[[ディスプレイマネージャ]]を使うか、{{ic|~/.xinitrc}} を拡張して切り替えを可能にすると便利です。
=== DE/WM の選択 ===
 
   
様々な DE/WM を頻繁に切り替えて使っている場合、[[ディスプレイマネージャ]]を使うか、以下のコードを {{ic|.xinitrc}} に追加することを推奨します。引数を使って起動したいデスクトップ環境やウィンドウマネージャをロードします:
+
以下の例では、特定のデスクトップ環境やウィンドウマネージャを引数付きで起動する方法を示ています:
   
 
{{hc|~/.xinitrc|<nowiki>
 
{{hc|~/.xinitrc|<nowiki>
 
...
 
...
   
  +
# ここで Xfce をデフォルトとしています
# Here Xfce is kept as default
 
 
session=${1:-xfce}
 
session=${1:-xfce}
   
 
case $session in
 
case $session in
awesome ) exec awesome;;
 
bspwm ) exec bspwm;;
 
catwm ) exec catwm;;
 
cinnamon ) exec cinnamon-session;;
 
dwm ) exec dwm;;
 
enlightenment ) exec enlightenment_start;;
 
ede ) exec startede;;
 
fluxbox ) exec startfluxbox;;
 
gnome ) exec gnome-session;;
 
gnome-classic ) exec gnome-session --session=gnome-classic;;
 
 
i3|i3wm ) exec i3;;
 
i3|i3wm ) exec i3;;
icewm ) exec icewm-session;;
+
kde ) exec startplasma-x11;;
jwm ) exec jwm;;
 
kde ) exec startkde;;
 
mate ) exec mate-session;;
 
monster|monsterwm ) exec monsterwm;;
 
notion ) exec notion;;
 
openbox ) exec openbox-session;;
 
unity ) exec unity;;
 
 
xfce|xfce4 ) exec startxfce4;;
 
xfce|xfce4 ) exec startxfce4;;
  +
# 既知のセッションではないので、引数をコマンドとして実行してみる
xmonad ) exec xmonad;;
 
# No known session, try to run it as command
+
* ) exec $1;;
*) exec $1;;
 
 
esac
 
esac
 
</nowiki>}}
 
</nowiki>}}
   
  +
''session'' 引数を渡すには:
{{ic|/etc/X11/xinit/xserverrc}} ファイルをホームディレクトリにコピーしてください:
 
   
$ cp /etc/X11/xinit/xserverrc ~/.xserverrc
+
$ xinit ''session''
   
  +
あるいは
その後、引数を指定して特定の DE/WM を起動することができます:
 
   
  +
$ startx ~/.xinitrc ''session''
$ xinit
 
$ xinit gnome
 
$ xinit kde
 
$ xinit wmaker
 
 
または:
 
 
$ startx
 
$ startx ~/.xinitrc gnome
 
$ startx ~/.xinitrc kde
 
$ startx ~/.xinitrc wmaker
 
   
 
=== ウィンドウマネージャを使わずにアプリケーションを起動 ===
 
=== ウィンドウマネージャを使わずにアプリケーションを起動 ===
210行目: 176行目:
 
}}
 
}}
   
  +
あるいは、[[#xinitrc をオーバーライドする]] で説明されているように、コマンドプロンプトからバイナリを直接実行することもできます。
この方法を使うときはアプリケーションのウィンドウの配置を、アプリケーションの設定ファイルで設定しておく必要があります。
 
  +
  +
この方法を使うときはアプリケーションのウィンドウの配置を、アプリケーションの設定ファイルで設定しておく必要があります (可能な限り)。
  +
  +
{{Tip|コンポジタのオーバーヘッドを取り除くことでゲームのパフォーマンスが向上するのであれば、この方法でグラフィカルなゲームを起動すると便利かもしれません。}}
   
  +
[[ディスプレイマネージャ#ウィンドウマネージャを使わずにアプリケーションを起動]] も見て下さい。
{{Tip|この方法を使ってグラフィカルなゲームを起動することも可能です。特に、ウィンドウマネージャやデスクトップ環境、またはデスクトップアクセサリといったアプリケーションによるメモリと CPU の消費を抑えて、ゲームの実行パフォーマンスを底上げすることができます。}}
 
   
  +
=== startx を使って出力をリダイレクトする ===
[[ディスプレイマネージャ#ウィンドウマネージャを使わずにアプリケーションを起動]]も見て下さい。
 
   
=== startx 使用時の出力のリダイレクト ===
+
詳細は [[Xorg#セッションログのリダイレクト]] を見てください。
   
  +
{{TranslationStatus|xinit|2023-06-20|771773}}
詳細は、[[Xorg#Session log redirection]] を参照してください。
 

2023年6月20日 (火) 07:22時点における最新版

関連記事

Wikipedia から:

xinit プログラムにより、ユーザが Xorg ディスプレイサーバを手動で起動することが可能になります。startx(1) スクリプトは xinit(1) のフロントエンドです。

通常、xinitウィンドウマネージャデスクトップ環境を起動するために使用されます。xinit を使うことでウィンドウマネージャ無しで GUI アプリケーションを実行することができますが、多くのグラフィカルアプリケーションは EWMH に準拠したウィンドウマネージャを期待します。ディスプレイマネージャXorg を起動し、一般的に xprofile を読み込みます。

インストール

xorg-xinitインストールしてください。

設定

xinitstartx は任意でクライアントプログラムの引数を受け取ります。#xinitrc をオーバーライドする を参照してください。もし、引数を与えなければ、クライアントプロラムを起動するシェルスクリプトとして、~/.xinitrc を探します。

xinitrc

~/.xinitrc は、X に依存するプログラムを実行し、X サーバの起動時に環境変数を設定するのに便利です。このファイルがユーザのホームディレクトリに存在する場合、startxxinit はこのファイルを実行します。それ以外の場合、startx はデフォルトの /etc/X11/xinit/xinitrc を実行します。

ノート: Xinit には、このファイルを実行する以外に独自のデフォルトの動作があります。詳細については、xinit(1) を参照してください。

デフォルトの xinitrc は、Twmxorg-xclock、そして Xterm を起動した基本的な環境を開始します (このファイルは、必要なパッケージがインストールされていると仮定しています)。そのため、別のウィンドウマネージャやデスクトップ環境を始めるには、まずデフォルトの xinitrc のコピーをホームディレクトリに作成します:

$ cp /etc/X11/xinit/xinitrc ~/.xinitrc

それからそのファイルを編集して、デフォルトのプログラムを好きなコマンドに置き換えてください。exec を使用するコマンド以降の行は無視されることを覚えておいてください。たとえば、xscreensaver をバックグラウンドで開始してから openbox を開始するには、以下のように記述します:

~/.xinitrc
...
xscreensaver &
exec openbox-session
ノート: 最低限、/etc/X11/xinit/xinitrc にある最後の if ブロックが、あなたの ~/.xinitrc ファイルにあることを確認してください。これにより、 /etc/X11/xinit/xinitrc.d にあるスクリプトが読み込まれることを保証できます。

スクリーンセーバーや壁紙アプリケーションといった、長く実行されるプログラムがウィンドウマネージャの前に開始される場合、それらをフォークするか & 記号をつけてバックグラウンドで実行しなければなりません。そうしないと、スクリプトはウィンドウマネージャやデスクトップ環境を実行する前に停止し、それらのプログラムが終了するのを待ちます。いくつかのプログラムは、 xrdb のように、競合バグを回避するためフォークしないでください。exec を前につけることで、スクリプトプロセスをウィンドウマネージャプロセスへ入れ替えることができます。これにより、たとえこのプロセスがバックグランドへフォークされても X が終了しないようにできます。

xserverrc

xserverrc ファイルは、X サーバの起動を担当するシェルスクリプトです。startxxinit はどちらも ~/.xserverrc が存在すればそれを実行し、存在しなければ startx/etc/X11/xinit/xserverrc を使用します。

認証されたセッションlogind で維持できるようにし、かつ、ターミナルを切り替えることで画面ロッカーをバイパスできないようにするために、ログインが行われたのと同じ仮想コンソールで Xorg を起動しなければなりません [1]。そのため、~/.xserverrc ファイルで vt$XDG_VTNR を指定することが推奨されます:

~/.xserverrc
#!/bin/sh

exec /usr/bin/Xorg -nolisten tcp "$@" vt$XDG_VTNR

全てのコマンドラインオプションの一覧は Xserver(1) を参照してください。

ヒント: -nolisten local-nolisten tcp の後に追加すると、X11 の抽象ソケットを無効でき、X の分離に役立ちます。これが X11 のセキュリティにどのような影響を及ぼしうるのかについての簡単な説明があります。

あるいは、サーバを起動するコンソールとは別のコンソールで X を表示させたい場合は、 /usr/lib/systemd/systemd-multi-seat-x が提供する X サーバラッパーを使って表示させることも可能です。利便性のために、xinitstartx~/.xserverrc を修正することでこのラッパーを使うようにセットアップすることができます。

ノート: X セッションから Xorg ログファイルへの出力のリダイレクトを再び有効にするには、-keeptty オプションを追加してください。詳しくは Xorg#セッションログのリダイレクト を見て下さい。

使用方法

Xorg を通常のユーザとして実行するには、次のように実行します:

$ startx

または、#xserverrc が設定されている場合は:

$ xinit -- :1
ノート: xinit は、他の X サーバがすでに起動している場合は、複数のディスプレイを処理しません。その場合、-- :display_number (display_number1 以上) を付けてディスプレイを指定しなければなりません。

これでお好みのウィンドウマネージャー(またはデスクトップ環境)が正しく起動するはずです。

X を終了するには、ウィンドウマネージャーの exit 関数を実行してください (exit 関数があると仮定します)。そのような機能がない場合は次のように実行します:

$ pkill -15 Xorg
ノート: pkill は実行中の X インスタンスを全て kill します。現在の仮想コンソール上のウィンドウマネージャーを kill するには、次のように実行します:
$ pkill -15 -t tty"$XDG_VTNR" Xorg

signal(7) も参照してください。

ヒントとテクニック

xinitrc をオーバーライドする

すでに ~/.xinitrc があるが、他のウィンドウマネージャやデスクトップ環境を試してみたい場合、ウィンドウマネージャへのパスを付け加えて startx を実行することで、ウィンドウマネージャを起動させることができます。例えば:

$ startx /usr/bin/i3

ウィンドウマネージャのバイナリが引数を取る場合、引数全体が startx の第1パラメータとして認識されるようにするために引数を引用符で囲む必要があります:

$ startx "/usr/bin/application --key value"

完全なパスが 必要である ことに注意してください。また、#xserverrc スクリプトのカスタムオプションは、-- 記号のあとに付け加えることで指定できます:

$ startx /usr/bin/enlightenment -- -br +bs -dpi 96

startx(1) も参照してください。

ノート: /etc/X11/xinit/xinitrc.d/ にあるスクリプトはスキップされるので、環境変数 DISPLAY を設定する必要があるかもしれません。次のように実行することで、i3 を好きなディスプレイに表示させてみることができます: DISPLAY=:display_number startx /usr/bin/i3
ヒント: これにより通常の GUI プログラムを開始できますが、基本的なウィンドウマネージャの機能はありません。#ウィンドウマネージャを使わずにアプリケーションを起動するゲーム#別の X サーバーでゲームを起動する を参照してください。

ログイン時に X を自動起動

startx が適切に設定されていることを確認してください。

以下をログインシェルの初期化ファイル (例: Bash の場合は ~/.bash_profileZsh の場合は ~/.zprofile) に記述してください:

if [ -z "${DISPLAY}" ] && [ "${XDG_VTNR}" -eq 1 ]; then
  exec startx
fi

複数の仮想コンソールでグラフィカルログインを使用したい場合は、-eq 比較演算子を -le 3 (vt1 から vt3 まで) のようなものに置き換えることで可能です。

仮想コンソールを検出できる条件式として "$(tty)" = "/dev/tty1" もありますが、これは -le を使って比較することができません。また、"$(fgconsole 2>/dev/null || echo -1)" -eq 1 という書き方もありますが、こっちはシリアルコンソールでは動きません。

exec コマンドは、X サーバが終了、クラッシュ、または攻撃者によって kill されたときに、ユーザがログアウトすることを保証します。リスクを犯して、X セッションが終了したときにログイン状態を維持したい場合は、exec を取り除いてください。

Fish#ログイン時に X を起動systemd/ユーザー#ディスプレイマネージャを使わずに Xorg に自動ログイン も参照してください。

ヒント: この方法は 仮想コンソールに自動ログイン と組み合わせることができます。

デスクトップ環境/ウィンドウマネージャを切り替える

様々なデスクトップ環境やウィンドウマネージャを頻繁に切り替える場合、ディスプレイマネージャを使うか、~/.xinitrc を拡張して切り替えを可能にすると便利です。

以下の例では、特定のデスクトップ環境やウィンドウマネージャを引数付きで起動する方法を示しています:

~/.xinitrc
...

# ここで Xfce をデフォルトとしています
session=${1:-xfce}

case $session in
    i3|i3wm           ) exec i3;;
    kde               ) exec startplasma-x11;;
    xfce|xfce4        ) exec startxfce4;;
    # 既知のセッションではないので、引数をコマンドとして実行してみる
    *                 ) exec $1;;
esac

session 引数を渡すには:

$ xinit session

あるいは

$ startx ~/.xinitrc session

ウィンドウマネージャを使わずにアプリケーションを起動

ウィンドウマネージャを使わずに特定のアプリケーションだけを起動することも可能です。フルスクリーンモードで何か一つのアプリケーションを表示したいときに有用です。例:

~/.xinitrc
...

exec chromium

あるいは、#xinitrc をオーバーライドする で説明されているように、コマンドプロンプトからバイナリを直接実行することもできます。

この方法を使うときはアプリケーションのウィンドウの配置を、アプリケーションの設定ファイルで設定しておく必要があります (可能な限り)。

ヒント: コンポジタのオーバーヘッドを取り除くことでゲームのパフォーマンスが向上するのであれば、この方法でグラフィカルなゲームを起動すると便利かもしれません。

ディスプレイマネージャ#ウィンドウマネージャを使わずにアプリケーションを起動 も見て下さい。

startx を使って出力をリダイレクトする

詳細は Xorg#セッションログのリダイレクト を見てください。

翻訳ステータス: このページは en:xinit の翻訳バージョンです。最後の翻訳日は 2023-06-20 です。もし英語版に 変更 があれば、翻訳の同期を手伝うことができます。