diff --git a/pages.zh/osx/launchctl.md b/pages.zh/osx/launchctl.md new file mode 100644 index 0000000000..017b75380d --- /dev/null +++ b/pages.zh/osx/launchctl.md @@ -0,0 +1,32 @@ +# launchctl + +> 用于启动守护程序(系统范围的服务)和启动代理程序(每个用户程序)的命令行界面,该界面指向苹果的`launchd` 管理工具. +> `launchd`加载放置在适当位置的基于XML的`*.plist`文件,并根据其定义的计划运行相应的命令. + +- 每当用户登录时,自动将plist文件加载到 `launchd` : + +`launchctl load ~/Library/LaunchAgents/{{我的脚本}}.plist` + +- 激活需要root权限才能运行和/或在任何用户登录时都应加载的脚本(注意路径中不能有`~`): + +`sudo launchctl load /Library/LaunchAgents/{{root脚本}}.plist` + +- 激活一个系统范围的守护程序,以便在系统启动时加载(即使没有用户登录也会加载): + +`sudo launchctl load /Library/LaunchDaemons/{{系统脚本}}.plist` + +- 显示所有加载的代理/守护进程,如果它们指定的进程当前正在运行,则显示pid,如果停止那么返回了它们上次运行的时间和退出代码: + +`launchctl list` + +- 卸载当前加载的脚本,例如进行更改(注意:重新启动和/或登录后,plist文件将自动加载到`launchd`): + +`launchctl unload ~/Library/LaunchAgents/{{我的脚本}}.plist` + +- 手动运行一个已知的(已加载的)脚本/守护进程,即使它不是正确的时间(注意:此命令使用脚本的标签,而不是文件名): + +`launchctl start {{我的脚本}}` + +- 手动终止与已知脚本/守护进程关联的进程(如果该进程正在运行): + +`launchctl stop {{我的脚本}}`