コマンドはターミナルでは動作しますが、Ubuntu 18.04 サーバーのシステム サービスとしては動作しません

コマンドはターミナルでは動作しますが、Ubuntu 18.04 サーバーのシステム サービスとしては動作しません

ターミナルと ./go.sh の両方が動作していることを何度も確認しましたが、サービスとして起動できません。間違っていることはわかっていますが、何が間違っているのかわかりません。

/root/go.sh

#!/usr/bin/env bash
export PATH=/sbin:/usr/sbin:/bin:/usr/bin

/root/goweb/bin/echoip -t=/root/goweb/bin/index.html

そして


/lib/systemd/system/goweb.service

[Unit]
Description=goweb

[Service]
Type=forking
Restart=always
RestartSec=5s
ExecStart=/root/go.sh

[Install]
WantedBy=multi-user.target

何が起こっているのか分かりません。サービスが開始したり停止したり、また開始したり停止したりしています

Here is the status

goweb.service - goweb
   Loaded: loaded (/lib/systemd/system/goweb.service; enabled; vendor preset: en
   Active: activating (start) since Sun 2020-01-19 19:39:52 UTC; 36s ago
Cntrl PID: 1259 (bash)
    Tasks: 6 (limit: 1151)
   CGroup: /system.slice/goweb.service
           ├─1259 bash /root/go.sh
           └─1268 /root/goweb/bin/echoip -t=/root/goweb/bin/index.html

Jan 19 19:39:52 ip systemd[1]: goweb.service: Service hold-off time over, schedu
Jan 19 19:39:52 ip systemd[1]: goweb.service: Scheduled restart job, restart cou
Jan 19 19:39:52 ip systemd[1]: Stopped goweb.
Jan 19 19:39:52 ip systemd[1]: Starting goweb...
Jan 19 19:39:52 ip go.sh[1259]: echoip: Listening on http://0.0.0.0:8080

答え1

スクリプトgo.shの先頭に追加します

export PATH=/sbin:/usr/sbin:/bin:/usr/bin

さらに必要なパスがある場合は、上にそれらを追加するか、スクリプトで実行するスクリプトまたはコマンドへの完全なパスを追加します。

関連情報