単純な.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 を実行できません