Mac设置开机启动

本文针对命令行使用的开发工具或自己编写的脚本设置开机启动,图形化界面的程序仅需要设置->用户与群组->登录项中即可配置。

相比于Linux开机启动设置的简单方便--配置rc.local文件即可,mac设置开机启动略显麻烦。如果是使用homebrew安装软件自然不用考虑开机启动这回事,但有时候想执行自己的脚本或者有特殊需求,就不得不自己处理开机启动了。

1. 使用登录项添加可执行脚本(推荐)

在用户的家目录编写一个sh脚本,例如:
test.sh

#!/bin/bash
在用户的家目录创建一个文件
touch ~/haha.txt

添加可执行权限

chmod 755 test.sh

进入设置->用户与群组->登录项,点 + 号,选择test.sh文件即可。

重启电脑,验证是否新建了文件,如存在说明配置成功,修改该文件内容为你想要的配置。

该文件将会在开机时执行,可在命令行中执行的开机启动项均可在此文件中配置。

PS: 开机后会显示一个“进程已结束”的终端,不太爽,需要进入终端的偏好设置->shell选项卡->当shell退出时,选择“关闭窗口”。这样开机时就不会出现一个终端了
2. launchctl加载plist文件

macOS开机启动一般使用launchctl加载plist文件

plist文件放置处:
~/Library/LaunchAgents由用户自己定义的任务项
/Library/LaunchAgents由管理员为用户定义的任务项
/Library/LaunchDaemons由管理员定义的守护进程任务项
/System/Library/LaunchAgents由Mac OS X为用户定义的任务项
/System/Library/LaunchDaemons由Mac OS X定义的守护进程任务项
建议放在~/Library/LaunchAgents下面。

下面再来理解几个基础概念:
/System/Library/Library~/Library目录的区别?
/System/Library目录是存放Apple自己开发的软件。
/Library目录是系统管理员存放的第三方软件。
~/Library是用户自己存放的第三方软件。

LaunchDaemons和LaunchAgents的区别?
LaunchDaemons是用户未登陆前就启动的服务(守护进程)。
LaunchAgents是用户登陆后启动的服务(守护进程)。

plist文件示例

<?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>KeepAlive</key>
    <true/>
    <key>Label</key>
    <string>top.kyzy.frp</string>
    <key>RunAtLoad</key>
    <true/>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/zhangsan/frp_0.37.0_darwin_amd64/frpc</string>
        <string>-c</string>
        <string>/Users/zhangsan/frp_0.37.0_darwin_amd64/frpc.ini</string>
    </array>
    <key>StandardErrorPath</key>
    <string>/Users/zhangsan/Library/Logs/frpc.log</string>
    <key>StandardOutPath</key>
    <string>/Users/zhangsan/Library/Logs/frpc.log</string>
  </dict>
</plist>

launchd.plist的部分键值说明

Label 必须
该项服务的名称

ProgramArguments
指定可执行文件路径及其参数,比如执行ls -a,对应到该配置中,应该写作:

<key>ProgramArguments</key>
<array>
     <string>ls</string>
     <string>-a</string>
</array>

RunAtLoad 可选
标识launchd在加载完该项服务之后立即启动路径指定的可执行文件。默认值为 false,设置为 true 即可实现开机运行脚本文件。

StartCalendarInterval 可选
该关键字可以用来设置定时执行可执行程序,可使用 Month, Day, Hour, Minute, Second等子关键字,它可以指定脚本在多少月,天,小时,分钟,秒,星期几等时间上执行,若缺少某个关键字则表示任意该时间点,类似于 Unix 的 Crontab 计划任务的设置方式,比如在该例子中设置为每小时的20分的时候执行该命令。

KeepAlive(可选)
是否保持持续运行

所有key关键字详细使用说明可以在Mac OS X终端下使用命令man launchd.plist查询

检查plist语法是否正确

plutil ~/Library/LaunchAgents/example.plist

载入配置, 使配置生效

launchctl load ~/Library/LaunchAgents/example.plist

卸载配置

launchctl unload ~/Library/LaunchAgents/example.plist

查看服务运行状态

launchctl list

其他命令

launchctl remove:从launchd中异步删除任务,在返回之前它不会等待作业实际停止,因此不会对任何错误做处理
launchctl unload :停止并卸载任务,但该任务仍将在下次登录/重新启动时重新启动
launchctl unload -w <路径> :停止并卸载和禁用任务。该任务将不会在下次登录/重新启动时重新启动。

launchctl stop:停止任务。如果将任务已经是运行状态,则作业可能会立即重新启动。
launchctl load <路径> :只要未“禁用”该任务,就加载并启动任务。
launchctl load -w <路径> :加载并启动任务,同时还将任务标记为“未禁用”。任务将在下次登录/重新启动时重新启动。