質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

systemd

systemdは、Linuxの起動処理及びシステム管理を行う技術です。他にも多くのサービス管理機能を備えており、ユーザープロセスを並列に起動しシステムの起動処理に要する時間を短縮できるなどの特徴があります。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

Q&A

解決済

1回答

2033閲覧

systemctlに登録したUnitが正常にスタートしません

退会済みユーザー

退会済みユーザー

総合スコア0

bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

systemd

systemdは、Linuxの起動処理及びシステム管理を行う技術です。他にも多くのサービス管理機能を備えており、ユーザープロセスを並列に起動しシステムの起動処理に要する時間を短縮できるなどの特徴があります。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

0グッド

0クリップ

投稿2018/07/26 19:41

現在,Ubuntu18.04で構築したサーバー上で,minecraftサーバーを運用しようとしております.
minecraft自体は動作しており,外部から接続できる事が確認できているのですが,
systemctlのユニットとしてサービスを登録し,自動で起動できるようにしようとしているところで躓いています.

起動用のスクリプトは手動で叩くと問題無く起動ができるものとなっております.
以下がスクリプト(/opt/minecraft/start.sh)の内容です.

#!/bin/sh cd "${0%/*}" screen -AmS minecraft-server java -Xms1024M -Xmx1024M -jar server.jar nogui

これを自動で起動するために,下記のようなユニット(/opt/minecraft/minecraft.service)を作成しました./etc/systemd/system/配下にはこのファイルへのシンボリックリンクがおいてあります.

[Unit] Description = Minecraft Server [Service] ExecStart = /opt/minecraft/start.sh Restart = no [Install] WantedBy = multi-user.target

systemctl list-unit-files --type=serviceの出力にはminecraft.serviceが存在しているため,登録はできております.しかし,起動コマンドを叩くと,以下の通りステータスコード1で終了し,サービスを起動することができません.

● minecraft.service - Minecraft Server Loaded: loaded (/opt/minecraft/minecraft.service; enabled; vendor preset: enabled) Active: failed (Result: exit-code) since Fri 2018-07-27 04:38:01 JST; 19s ago Process: 29105 ExecStart=/opt/minecraft/start.sh (code=exited, status=1/FAILURE) Main PID: 29105 (code=exited, status=1/FAILURE) Jul 27 04:38:01 Suzuya systemd[1]: Started Minecraft Server. Jul 27 04:38:01 Suzuya start.sh[29105]: Must be connected to a terminal. Jul 27 04:38:01 Suzuya systemd[1]: minecraft.service: Main process exited, code=exited, status=1/FAILURE Jul 27 04:38:01 Suzuya systemd[1]: minecraft.service: Failed with result 'exit-code'.

どこが間違っているのかが分からない状態となっております.どなたかお力を化して頂ければ幸いです.よろしくお願いいたします.

使用しているソフトウェアのバージョンは以下の通りです.
Ubuntu18.04 LTS
Screen version 4.06.02 (GNU) 23-Oct-17
minecraft_server.1.13.jar

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/07/26 23:07

実行ユーザーがjavaを見つけれないんじゃ?
退会済みユーザー

退会済みユーザー

2018/07/27 03:46

systemctlによりスクリプトを実行するのはrootではないのでしょうか?であれば,動作確認はrootで行っているので問題ありません.
退会済みユーザー

退会済みユーザー

2018/07/27 06:10

/etc/profile.d/ は読み込まれないはずですけど root ですね。
退会済みユーザー

退会済みユーザー

2018/07/29 06:35

解決することができました!ご回答ありがとうございました!
guest

回答1

0

ベストアンサー

起動用のスクリプトは手動で叩くと問題無く起動ができるものとなっております.

その判断ですが、「手動で叩くと」は対話処理としての実行、かたや systemd から起動されるときは非対話状態なので、あてにはできませんよ。

その起動スクリプトで screen コマンドを実行していますが、これが当に対話処理を前提としているからです。
一応、-d オプション ( detach ) も指定すれば非対話でも実行できますが、それ以前に screen を使う意図は何か、考え直した方が良いと思います。
直接 java コマンドを実行すると何か問題があるでしょうか?

投稿2018/07/27 10:39

angel_p_57

総合スコア1672

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/07/28 01:57

ご回答ありがとうございます. 今回運用しようとしているminecraftサーバーが,起動することでターミナルを占有し,ログ吐き&コマンド待ちするようなものとなっております.デスので,必要に応じてscreenでアタッチしてコマンドを入力する場合があり,screenでの実行をしました. また,-dオプションを使用して行った場合でも起動に失敗し,こちらの場合は正常終了していますが,screenからmust be connected to a terminalと怒られておりました.
angel_p_57

2018/07/28 03:21

> screenからmust be connected to a terminalと怒られておりました むむ。-d ならそのエラーは出ないはずですが…? ``` $ screen -AmS hoge cat </dev/null Must be connected to a terminal. $ screen -ls No Sockets found in /var/run/screen/S-angel. $ screen -dAmS hoge cat </dev/null $ screen -ls There is a screen on: 87.hoge (07/28/2018 12:17:23 PM) (Detached) 1 Socket in /var/run/screen/S-angel. ``` なお、-d で detach した場合、screen は確かにすぐ終了 ( 正常終了 ) するので、systemd のユニット設定で、Type=forking の指定が必要です。
退会済みユーザー

退会済みユーザー

2018/07/29 06:34

Type=forkingに指定するとできました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問