我正在尝试设置Yaws(通过Homebrew安装)使用以下PLIST在OS X Yosemite下自动启动:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>ca.seidlitz.yaws</string>
<key>ProgramArguments</key>
<array>
<string>sh</string>
<string>-c</string>
<string>/usr/local/Cellar/yaws/1.98/bin/yaws --daemon --conf /usr/local/Cellar/yaws/1.98/etc/yaws/yaws.conf</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>WorkingDirectory</key>
<string>/usr/local/opt/yaws</string>
<key>StandardOutPath</key>
<string>/tmp/yaws.log</string>
<key>StandardErrorPath</key>
<string>/tmp/yaws_err.log</string>
</dict>
</plist>
我尝试使用sudo launchctl load /Library/LaunchDaemons/ca.seidlitz.yaws.plist
来加载此plist
但没有运气。我在/var/system.log中没有收到任何错误,而/tmp/yaws.log包含此错误:&#34; 1&gt; ***终止erlang(nonode @ nohost)&#34;
我也尝试将其作为守护进程运行并以交互模式运行。守护进程不会在日志文件中生成任何错误,但是Yaws没有运行。
任何人都可以发现plist的任何问题吗?
答案 0 :(得分:1)
如果/usr/local/Cellar/yaws/1.98/bin/yaws
脚本已经不可执行,则应该使sh -c
脚本可以执行,删除yaws
调用,并将<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>ca.seidlitz.yaws</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/Cellar/yaws/1.98/bin/yaws</string>
<string>--daemon</string>
<string>--conf</string>
<string>/usr/local/Cellar/yaws/1.98/etc/yaws/yaws.conf</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>WorkingDirectory</key>
<string>/tmp</string>
<key>StandardOutPath</key>
<string>/tmp/yaws.log</string>
<key>StandardErrorPath</key>
<string>/tmp/yaws_err.log</string>
</dict>
</plist>
脚本及其参数正确地声明为单独的字符串,都是这样的:
{{1}}