使用具有以下 plist 的 LaunchDaemon:
<?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.test.testing</string>
<key>ProgramArguments</key>
<array>
<string>python3</string>
<string>/Users/my-name/python-daemon/python_daemon_test.py</string>
</array>
<key>StandardErrorPath</key>
<string>/var/log/test-Error.log</string>
<key>StandardOutPath</key>
<string>/var/log/test.log</string>
<key>RunAtLoad</key>
<true/>
</dict>
</plist>
要启动的脚本在哪里
#!/usr/bin/env python3
import sys
print(sys.version)
print(sys.path)
我有我不理解的行为。
当我在终端中运行脚本时(which python3
结果为/Users/my-name/opt/anaconda3/bin/python3
),我收到以下输出:
3.7.4 (default, Aug 13 2019, 15:17:50)
[Clang 4.0.1 (tags/RELEASE_401/final)]
['/Users/my-name/python-daemon', '/Users/my-name/opt/anaconda3/lib/python37.zip',
'/Users/my-name/opt/anaconda3/lib/python3.7',
'/Users/my-name/opt/anaconda3/lib/python3.7/lib-dynload',
'/Users/my-name/.local/lib/python3.7/site-packages',
'/Users/my-name/opt/anaconda3/lib/python3.7/site-packages',
'/Users/my-name/opt/anaconda3/lib/python3.7/site-packages/aeosa']
这是所希望的,因为我希望运行的实际(非玩具)脚本使用我在 Anaconda 中安装的 PyObjc 包。
但是,当脚本由 LaunchDaemon 运行时,我在test.log
文件中得到以下内容:
3.7.3 (default, Mar 6 2020, 22:34:30)
[Clang 11.0.3 (clang-1103.0.32.29)]
['/Users/my-name/python-daemon',
'/Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.7/lib/python37.zip',
'/Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.7/lib/python3.7',
'/Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.7/lib/python3.7/lib-dynload',
'/Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.7/lib/python3.7/site-packages']
这是一个问题,因为我希望运行的实际脚本取决于 Anaconda 中的一个包。我曾预计,因为脚本中的第一个程序参数是python3
它会以与python3
终端相同的方式运行,但我错了。
为什么脚本会这样?我认为这可能是因为它将脚本运行为sudo
,但sudo which python3
也返回了 Anaconda 的路径。
我该如何解决这个问题?我确信一个简单的解决方案是在 Python3 的 Xcode 版本中的某个位置安装我想要的包。但是,我实际上不确定该怎么做。这也会让人感到有点不满意,因为我想知道 LaunchDaemons 为什么会这样。