我有一个脚本,它运行一个 mysqldump,然后从 bash 插入一个 mysql。它在终端上运行良好,即使作为 root (我相信 LaunchD 运行)但它不会从 launchd 运行 mysql insert,但会运行 mysqldump。
脚本是:
#!/bin/bash
mysqldump -u root -pmypass my_db | gzip -9 > /path/to/dump.sql.gz
mysql -u root -pmypass my_db2 < /path/to/insert.sql
和我的 com.me.BackupThing.plist(来自 /Library/LaunchAgents),它运行并执行除 mysql 命令之外的所有命令:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>com.me.BackupThing</string>
<key>ProgramArguments</key>
<array>
<string>/full/path/to/above/script.sh</string>
</array>
<key>QueueDirectories</key>
<array/>
<key>StartCalendarInterval</key>
<dict>
<key>Hour</key>
<integer>01</integer>
<key>Minute</key>
<integer>00</integer>
</dict>
<key>WatchPaths</key>
<array/>
<key>UserName</key>
<string>administrator</string>
</dict>
</plist>
全部从终端以 root 身份运行,并且 mysql 的 bin 在 root 命令路径上导出。
为什么它会忽略launchd中的mysql命令?
编辑
感谢arco444的解决方案,由于某种原因,mysql需要完整路径,新脚本是:
#!/bin/bash
mysqldump -u root -pmypass my_db | gzip -9 > /path/to/dump.sql.gz
/path/to/mysql/bin/mysql -u root -pmypass my_db2 < /path/to/insert.sql