起動時にユーザー(rootではない)としてログインする前にtmuxセッションを作成します。

起動時にユーザー(rootではない)としてログインする前にtmuxセッションを作成します。

私は自宅で友人のために小さな Minecraft サーバーをホストしていますが、作業を簡単にするために、サーバーとして使用している PC の電源を入れると Minecraft サーバーが自動的に起動するようにしたいと考えました。必要な場合にサーバーを管理できるように tmux を使用しています。そのために、次のスクリプトを用意しました。

#!/bin/bash

SESSION="server"
SESSIONEXISTS=$(tmux list-sessions | grep -w "$SESSION")

if [ "$SESSIONEXISTS" = "" ]
then

  tmux new-session -d -s "$SESSION" -d -x "$(tput cols)" -y "$(tput lines)"

  tmux rename-window -t 0 'mc'
  tmux send-keys -t 'mc' 'cd magma-1.18.2-40.2.10 && ./run.sh && sudo shutdown now' C-m
  tmux splitw -v

  tmux send-keys -t 'mc' 'glances' C-m
  tmux select-pane -t 0
  tmux splitw -h

  tmux send-keys -t 'mc' 'ngrok start --all' C-m

  tmux select-pane -t 0

fi

tmux attach-session -t "$SESSION":0

cron を使用しようとしましたが、成功しませんでした。

@reboot bash /home/fpp/startup.sh

tmux セッションが開始されません。

systemdユニットでも試してみました: [Unit]

Description=mcnrelated.service

After=default.target

[Service]

ExecStart=bash /home/fpp/startup.sh

[Install]

WantedBy=default.target

しかし、起動時にエラーのためサービスが開始されなかったことがわかりました。

最後の選択肢として、rc.local を使用しようとしました。

#!/bin/bash
sudo su -c "./home/fpp/startup.sh" -s /bin/sh fpp
exit 0

しかし、やはり tmux セッションは開始されませんでした。

この問題は tmux に関連しているのでしょうか? それとも私が何か間違っているのでしょうか?

編集: systemd を使用するのが最善です。

ChatGPT とたくさんチャットした後、私は自分のスクリプトで、tputターミナルの行と列を取得するために を使用していることを突き止めることができました。その問題は、サービスとして実行したときに、ターミナルで実行されていないため、値を返さず、スクリプトが失敗するという点です。そのため、 .tmux.conf ファイルに切り替えて、 を呼び出すだけで済むようにしtmux -t .tmux.conf、 の使用を回避しましたtput

また、ChatGPT の推奨に従って、ユーザー レベルの systemd ユニットを使用しています。

[Unit]
Description=Launch Minecraft Server and Related Services
After=network.target

[Service]
Type=oneshot
ExecStart=/usr/bin/tmux -u -f /home/fpp/tmux-config/tmux.conf
RemainAfterExit=true

[Install]
WantedBy=default.target

現在の問題は、tmux が開くターミナルがないとエラーを報告していることです。

fpp@fpp-server:~$ systemctl --user status mcnrelated.service
× mcnrelated.service - Launch Minecraft Server and Related Services
     Loaded: loaded (/home/fpp/.config/systemd/user/mcnrelated.service; enabled; preset: enabled)
     Active: failed (Result: exit-code) since Thu 2023-09-21 11:42:09 -03; 8min ago
    Process: 1319 ExecStart=/usr/bin/tmux -u -f /home/fpp/.tmux.conf (code=exited, status=1/FAILURE)
   Main PID: 1319 (code=exited, status=1/FAILURE)
        CPU: 37ms

sep 21 11:42:09 fpp-server systemd[550]: Starting mcnrelated.service - Launch Minecraft Server and Related Services...
sep 21 11:42:09 fpp-server tmux[1319]: open terminal failed: not a terminal
sep 21 11:42:09 fpp-server systemd[550]: mcnrelated.service: Main process exited, code=exited, status=1/FAILURE
sep 21 11:42:09 fpp-server systemd[550]: mcnrelated.service: Failed with result 'exit-code'.
sep 21 11:42:09 fpp-server systemd[550]: Failed to start mcnrelated.service - Launch Minecraft Server and Related Services.

そして今、私はそこにいます。使用してみました-uが、成功しませんでした。

問題は今のところ tmux に関するものです。サービスが正常に開始できたら、起動時に自動的に開始されるかどうかを確認します。

関連情報