
私は自宅で友人のために小さな 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 に関するものです。サービスが正常に開始できたら、起動時に自動的に開始されるかどうかを確認します。