设置Node.js脚本开机自启动

起因

自己经常用Typora写东西做记录,有时候想在下班或周末接着写,但是Typora并没有远程同步的功能,所以想写个小工具帮自己做上传同步:服务开机自启动并拉取内容,监听工作库目录有变动则同步到远端。

如果想使用脚本或者快捷命令打开其他软件可以参考推荐一个工作区管理小工具中关于open 命令的描述。

Windows 设置开机自启

可以参考 Windows设置自己的程序开机自动启动

MacOS 设置服务开机自启动
方法1:设置登录项

进入系统偏好设置 -> 用户与群组(账户) -> 登录项

点击下方的+就可以添加登录项,会在开机后自动运行,设置了的开机自启项也会在这里管理。

要注意的是如果使用Node.js脚本作为启动项,需要删除文件后缀并添加可执行权限(否则开机后会使用编辑器打开,而不是执行脚本)。

image-20220116101559735

方法2:扩展坞设置登录打开

扩展坞 -> 选项 -> 登录时打开,但是只能针对安装的应用程序。

方法3: Launchd配置

LaunchdMac下用于初始化操作系统的关键进程。通过启动硬盘指定目录下的配置文件,来完成启动任务。

目录描述
~/Library/LaunchAgents当前用户登陆后启动的服务
/Library/LaunchAgents由管理员定义的用户登陆后启动的服务
/Library/LaunchDaemons由管理员定义的守护进程任务项
/System/Library/LaunchAgentsMacOS系统定义的用户任务项
/System/Library/LaunchDaemonsMacOS系统定义的守护进程任务项
plist 配置

比较有用的配置关键字:

标签必填说明
Label标识符,用来表示该任务的唯一性
Program程序名称,用来说明运行哪个程序、脚本
ProgramArguments同上,与Program二选一或一起使用,只是可以运行多个程序、可带参数
WatchPaths监控路径,当路径文件有变化是运行程序,也是数组
RunAtLoad是否在加载的同时启动
StartCalendarInterval运行的时间,单个时间点使用dict,多个时间点使用 array -> dict
StartInterval时间间隔,与StartCalendarInterval使用其一,单位为秒
StandardInPath、StandardOutPath、StandardErrorPath标准的输入输出错误文件,这里建议不要使用.log作为后缀,会打不开里面的信息
PM2设置开机自启

pm2的startup 命令可以设置nodejs脚本开机自启动。pm2的对不同操作系统进行了不同处理:

startup代码

其中对于MacOS的处理也是通过launchd来实现的,会在用户主目录下的Library/LaunchAgents/文件夹中新增一个plist文件:

switch(platform) {
    ...
    case 'macos':
    case 'darwin':
    case 'launchd':
      template = getTemplate('launchd');
      destination = path.join(process.env.HOME, 'Library/LaunchAgents/' + launchd_service_name + '.plist');
      commands = [
        'launchctl load -w ' + destination
      ]
      break;
    default:
      throw new Error('Unknown platform / init system name');
    }

pm2 startup使用的plist模板

欢迎关注微信公众号"混沌前端"

参考:

利用 Launchd 定制 Mac 启动任务

Mac下用Launchd实现使用rc.local执行开机启动命令

Mac Launchd 启动任务

Windows设置自己的程序开机自动启动

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一颗小行星!

恰饭ing

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值