我已经创建了脚本来控制Fedora28上git-守护进程的启动、停止等。我现在正在尝试将这些脚本链接到一个systemd服务,这样git-守护进程在重新启动后就可以使用了。
主脚本(gitT)是..。
#!/bin/bash
case "$1" in
'start')
echo "Starting git-daemon"
/home/git/scripts/start.sh >> /home/git/gitT.log
;;
'stop')
echo "Stopping git-daemon"
/home/git/scripts/stop.sh >> /home/git/gitT.log
;;
'restart')
echo "Bouncing git-daemon"
/home/git/scripts/bounce.sh >> /home/git/gitT.log
;;
'status')
echo "Status of git-daemon"
/home/git/scripts/status.sh
;;
*)
echo "`basename $0`: usage: `basename $0` { stop | start | restart | status }"
;;
esac
次要剧本是..。
start.sh
#!/bin/bash
# --------------------------
echo "---------------------"
/usr/bin/git daemon --export-all --enable=receive-pack --verbose --pid-file=/home/git/git-daemon.pid --base-path=/home/git/repos >> /home/git/git-daemon.out 2>> /home/git/git-daemon.err &
echo "---------------------"
echo "STARTED at `date`"
stop.sh
#!/bin/bash
# --------------------------
echo "---------------------"
pkill -F /home/git/git-daemon.pid
echo "---------------------"
echo "STOPPED at `date`"
bounce.sh
#!/bin/bash
# --------------------------
echo "====================="
/home/git/scripts/stop.sh
echo "====================="
sleep 5
echo "====================="
/home/git/scripts/start.sh
echo "====================="
echo "BOUNCED"
和status.sh
#!/bin/bash
# --------------------------
echo "====================="
ps -x --forest
echo "====================="
最后,我创建了一个服务文件(git-daemon.service).
[Unit]
Description=Git Daemon
Documentation=man:git-daemon(1)
ConditionPathExists=/home/git/repos
[Service]
Type=oneshot
ExecStart=/bin/bash /home/git/gitT start
ExecStop=/bin/bash /home/git/gitT stop
RemainAfterExit=yes
User=git
Group=git
[Install]
WantedBy=multi-user.target
然后我用这些命令设置它..。
cp /home/git/git-daemon.service /etc/systemd/system
systemctl enable git-daemon.service
现在,如果我以git用户的身份运行gitT start
,一切都会好起来。但是我把systemctl start git-daemon
作为根运行,这是错误.
fatal: base-path '/home/git/repos' does not exist or is not a directory
发布于 2018-05-19 09:10:53
致命: base-path '/home/git/repos‘不存在或不是目录
是由
ConditionPathExists=/home/git/repos
因为它认为目录不存在。的输出是什么?
ls -ld /home/git/repos
?
当手动运行它时,流程实际启动了吗?或者您只是在手动运行它时没有得到任何错误?因为有了脚本级别,您就有了回退和重定向输出,因此无论底层命令是否失败,脚本都会成功运行。您应该检查您创建的日志文件。
但你为什么一开始就有这么多文件?您可以通过以下方法将所有这些简化为一个服务文件:
[Unit]
Description=Git Daemon
Documentation=man:git-daemon(1)
ConditionPathExists=/home/git/repos
[Service]
ExecStart=/usr/bin/git daemon --export-all --enable=receive-pack --verbose --base-path=/home/git/repos
User=git
Group=git
[Install]
WantedBy=multi-user.target
然后,您可以使用journalctl -xfu git-daemon
查看所有日志,而不必担心必须跟踪PID文件。
https://serverfault.com/questions/912899
复制相似问题