launchd parece ignorar StartCalendarInterval no Yosemite

9

Eu tentei atualizar o Homebrew a tempo com o launchd. Meu arquivo plist é apresentado aqui:

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

Funciona de alguma forma: eu posso executar launchctl start ms.liu.homebrew.update manualmente para atualizar meu Homebrew. No entanto, o launchd não executa este serviço periodicamente: as últimas alterações no arquivo para as quais o stdout redireciona é de dois dias atrás.

Eu tentei obter informações sobre esse serviço, mas não consegui nada:

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

Parece que não carreguei meu serviço com sucesso. Como? Eu usei launchctl load , mas parece que foi preterido. A página man recomenda o bootstrap:

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

O que devo fazer? Como usar corretamente launchctl bootstrap e launchctl print ?

Estou executando o OS X Yosemite GM Candidate 1 no MacBookPro com tela Retina (2013).

    
por Minsheng Liu 08.10.2014 / 04:20

1 resposta

2

Estou apenas começando a trabalhar com essas coisas, portanto, essa resposta é provisória, mas espero que seja mais útil do que nenhuma resposta. (Eu teria deixado como um comentário se eu tivesse bastante rep.)

Este plist está no seu diretório ~/Library/LaunchAgents ? Parece que esses são bootstrapped em seu domínio gui , não em seu domínio user . Então você pode fazer:

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

e isso deve funcionar. (Faz?)

Presumivelmente, o motivo pelo qual você não pode fazer o bootstrap no domínio user é que ele já foi inicializado no domínio gui .

    
por 19.10.2014 / 01:13