launchd, кажется, игнорирует StartCalendarInterval на Yosemite

9

Я попытался обновить Homebrew вовремя с помощью launchd. Мой файл 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>Label</key>
  <string>ms.liu.homebrew.update</string>
  <key>UserName</key>
  <string>LiuMS</string>
  <key>ProcessType</key>
  <string>Background</string>
  <key>EnvironmentVariables</key>
  <key>ProgramArguments</key>
  <array>
    <string>/usr/local/bin/brew</string>
    <string>update</string>
  </array>
  <key>StartCalendarInterval</key>
  <dict>
    <key>Hour</key>
    <integer>20</integer>
    <key>Minute</key>
    <integer>0</integer>
  </dict>
  <key>StandardOutPath</key>
  <string>/usr/local/logs/ms.liu.homebrew.update.out</string>
  <key>StandardErrorPath</key>
  <string>/usr/local/logs/ms.liu.homebrew.update.err</string>
</dict>
</plist>

Это работает как-то: я могу выполнить launchctl start ms.liu.homebrew.updateвручную, чтобы обновить мой Homebrew. Однако launchd не выполняет эту службу периодически: последние изменения в файле, на который перенаправляется стандартный вывод, произошли два дня назад.

Я пытался получить информацию об этой услуге, но ничего не получил:

> launchctl print user/%MyPID%/ms.liu.homebrew.update`` 
Could not find service "ms.liu.homebrew.update" in domain for uid: %MyPID%

Похоже, я не загрузил свой сервис. Как? Я использовал, launchctl loadно кажется, что это устарело. Страница Man вместо этого рекомендует начальную загрузку:

> launchctl bootstrap user/%MyPID% %Path-to-plist%
> %Path-to-plist%: Service cannot load in requested session

Что мне делать? Как правильно использовать launchctl bootstrapи launchctl print?

Я использую OS X Yosemite GM Candidate 1 на MacBookPro с дисплеем Retina (2013).

Миншен Лю
источник

Ответы:

2

Я только начинаю разбираться с этим, так что этот ответ является предварительным - но я надеюсь, что он более полезен, чем вообще никакого ответа. (Я бы оставил это как комментарий, если бы у меня было достаточно представителя.)

Этот список в вашем ~/Library/LaunchAgentsкаталоге? Кажется, что они загружаются в ваш guiдомен, а не в ваш userдомен. Так что вы можете сделать:

launchctl print gui/%UID%/ms.liu.homebrew.update

и это должно работать. (Является ли?)

Предположительно, причина, по которой вы не можете загрузить его в userдомен, заключается в том, что он уже загружен в guiдомен.

Робин Хьюстон
источник