Prety F2E

We tell browsers how to do better

0%

Mac 设置开机启动

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

相比于 Linux 开机启动设置的简单方便–配置 rc.local 文件即可,macOS 设置开机启动略显麻烦

如果是使用 homebrew 安装软件自然不用考虑开机启动这回事,但有时候想执行自己的脚本或者有特殊需求,就不得不自己处理开机启动了

使用登录项添加可执行脚本

在用户主目录编写一个 sh 脚本,例如

tesh.sh 文件内容

1
2
3
4
#!/bin/bash

# 在用户主目录创建一个文件
touch ~/test.txt

添加可执行权限

1
chmod 755

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

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

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

launchctl 加载 plist 文件

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

plist 文件放置处

1
2
3
4
5
~/Library/LaunchAgents          由用户自己定义的任务项
/Library/LaunchAgents 由管理员为用户定义的任务项
/Library/LaunchDaemons 由管理员定义的守护进程任务项
/System/Library/LaunchAgents 由 macOS 为用户定义的任务项
/System/Library/LaunchDaemons 由 macOS 定义的守护进程任务项

建议放在 ~/Library/LaunchAgents 下面

下面再来理解几个基础概念

/System/Library 和 /Library和~/Library 目录的区别

1
2
3
/System/Library     存放 Apple 自己开发的软件
/Library 系统管理员存放的第三方软件
~/Library 用户自己存放的第三方软件

LaunchDaemons 和 LaunchAgents 的区别

1
2
LaunchDaemons    用户未登陆前就启动的服务(守护进程)
LaunchAgents 用户登陆后启动的服务(守护进程)

plist 文件示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC -//Apple Computer//DTD PLIST 1.0//EN>
<plist version="1.0">
<dict>
<key>Label</key>
<string>com.example.exampled</string>
<key>ProgramArguments</key>
<array>
<string>exampled</string>
</array>
<key>KeepAlive</key>
<true/>
<key>RunAtLoad</key>
<true/>
</dict>
</plist>

launchd.plist 的部分键值说明

Label(必须)

该项服务的名称

ProgramArguments

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

1
2
3
4
5
<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 关键字详细使用说明可以在 macOS 终端下使用命令 man launchd.plist 查询

检查 plist 语法是否正确

1
plutil ~/Library/LaunchAgents/example.plist

载入配置,使配置生效

1
launchctl load ~/Library/LaunchAgents/example.plist

卸载配置

1
launchctl unload ~/Library/LaunchAgents/example.plist

查看服务运行状态

1
launchctl list