シェルスクリプトを実行するためのシンプルな systemd サービス

シェルスクリプトを実行するためのシンプルな systemd サービス

単純な.shファイルを起動しようとすると、Failed at step EXEC spawning /etc/start.sh: No such file or directory

内容gnome.service

[Unit]
Description=Description for sample script goes here
After=network.target
RequiresMountsFor=/etc/

[Service]
Type=simple
ExecStart=/etc/start.sh
TimeoutStartSec=0

[Install]
WantedBy=default.target

の内容start.sh

#!/bin/bash
echo "This is a sample script to test auto run during boot" > /root/Documents/script.txt
echo "The time the script run was -->  `date`" >> /root/Documents/script.txt

出力systemctl status gnome -l

● gnome.service - Description for sample script goes here
   Loaded: loaded (/etc/systemd/system/gnome.service; enabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since Thu 2019-06-06 18:25:32 CEST; 3s ago
  Process: 11713 ExecStart=/etc/start.sh (code=exited, status=203/EXEC)
 Main PID: 11713 (code=exited, status=203/EXEC)

Jun 06 18:25:32 some.server.adress systemd[1]: Started Description for sample script goes here.
Jun 06 18:25:32 some.server.adress systemd[11713]: Failed at step EXEC spawning /etc/start.sh: No such file or directory
Jun 06 18:25:32 some.server.adress systemd[1]: gnome.service: main process exited, code=exited, status=203/EXEC
Jun 06 18:25:32 some.server.adress systemd[1]: Unit gnome.service entered failed state.
Jun 06 18:25:32 some.server.adress systemd[1]: gnome.service failed.

出力ls -l /etc/start.sh

-rwxr-xr-x 1 root root 179 Jun  6 18:19 /etc/start.sh

出力/etc/start.sh

-bash: /etc/start.sh: /bin/bash^M: bad interpreter: No such file or directory

答え1

私はWindowsでNotepad++を使用していたので、

sed -i -e 's/\r$//' /etc/start.sh

Windows の行末を置き換えます。

^M は復帰文字です。Linux では行末を示すために改行文字を使用しますが、Windows では 2 文字のシーケンス CR LF を使用します。ファイルには Windows の行末文字が含まれているため、Linux が混乱しています。

回答スレッド: https://askubuntu.com/questions/304999/sh-file-bin-bashm-bad-interpreter を実行できません

関連情報