wydany wydaje się ignorować StartCalendarInterval na Yosemite

9

Próbowałem zaktualizować Homebrew na czas z uruchomieniem. Mój plik Plist znajduje się tutaj:

<?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>

Działa jakoś: mogę wykonać launchctl start ms.liu.homebrew.updateręcznie, aby zaktualizować swój Homebrew. Jednak uruchomione nie uruchamia tej usługi okresowo: ostatnie zmiany w pliku, do którego przekierowuje standardowe wyjście, to dwa dni temu.

Próbowałem uzyskać informacje o tej usłudze, ale nic nie dostałem:

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

Wygląda na to, że nie udało mi się załadować mojej usługi. W jaki sposób? Użyłem, launchctl loadale wygląda na to, że był przestarzały. Zamiast tego strona podręcznika zaleca bootstrap:

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

Co powinienem zrobić? Jak prawidłowo używać launchctl bootstrapi launchctl print?

Używam OS X Yosemite GM Candidate 1 na MacBookPro z wyświetlaczem Retina (2013).

Minsheng Liu
źródło

Odpowiedzi:

2

Dopiero zaczynam to rozwiązywać, więc ta odpowiedź jest niepewna - ale mam nadzieję, że jest bardziej pomocna niż brak odpowiedzi. (Pozostawiłbym to jako komentarz, gdybym miał wystarczająco dużo przedstawicieli).

Czy ten plist jest w twoim ~/Library/LaunchAgentskatalogu? Wygląda na to, że są one ładowane do twojej guidomeny, a nie twojej userdomeny. Możesz więc zrobić:

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

i powinno działać. (Czy to?)

Prawdopodobnie powodem, dla którego nie można go załadować do userdomeny, jest to, że jest już załadowany do guidomeny.

Robin Houston
źródło