launchd tampaknya mengabaikan StartCalendarInterval di Yosemite

9

Saya mencoba memperbarui Homebrew tepat waktu dengan launchd. File plist saya disajikan di sini:

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

Entah bagaimana cara kerjanya: Saya dapat menjalankan launchctl start ms.liu.homebrew.updatesecara manual untuk memperbarui Homebrew saya. Namun, launchd tidak menjalankan layanan ini secara berkala: perubahan terakhir pada file yang diarahkan ulang adalah dua hari yang lalu.

Saya mencoba mendapatkan info tentang layanan ini tetapi tidak mendapat apa-apa:

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

Sepertinya saya belum berhasil memuat layanan saya. Bagaimana? Saya menggunakan launchctl loadtetapi tampaknya sudah usang. Halaman manual merekomendasikan bootstrap sebagai gantinya:

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

Apa yang harus saya lakukan? Bagaimana cara menggunakan launchctl bootstrapdan launchctl print?

Saya menjalankan OS X Yosemite GM Calon 1 di MacBookPro dengan tampilan Retina (2013).

Minsheng Liu
sumber

Jawaban:

2

Saya baru saja mulai mengerjakan hal ini, jadi jawaban ini tentatif - tapi saya harap ini lebih membantu daripada tidak menjawab sama sekali. (Aku akan meninggalkannya sebagai komentar jika aku punya cukup perwakilan.)

Apakah daftar ini ada di ~/Library/LaunchAgentsdirektori Anda ? Tampaknya ini bootstrap ke guidomain Anda , bukan userdomain Anda . Jadi kamu bisa melakukan:

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

dan itu harus bekerja. (Melakukannya?)

Mungkin alasan Anda tidak dapat mem-bootstrap ke userdomain adalah karena itu sudah di-bootstrap ke guidomain.

Robin Houston
sumber