Não é possível iniciar o mongodb por launchctl no OS X Yosemite (10.10.2)

6

Eu instalei o mongodb 2.4 via homebrew:

brew install homebrew/versions/mongodb24

Então eu fiz um simlink para a configuração fornecida pelo homebrew:

ln -sfv /usr/local/opt/mongodb24/homebrew.mxcl.mongodb24.plist ~/Library/LaunchAgents

Este arquivo contém o seguinte:

<?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>homebrew.mxcl.mongodb24</string>
  <key>ProgramArguments</key>
  <array>
    <string>/usr/local/opt/mongodb24/bin/mongod</string>
    <string>--config</string>
    <string>/usr/local/etc/mongod.conf</string>
  </array>
  <key>RunAtLoad</key>
  <true/>
  <key>KeepAlive</key>
  <false/>
  <key>WorkingDirectory</key>
  <string>/usr/local</string>
  <key>StandardErrorPath</key>
  <string>/usr/local/var/log/mongodb/output.log</string>
  <key>StandardOutPath</key>
  <string>/usr/local/var/log/mongodb/output.log</string>
  <key>HardResourceLimits</key>
  <dict>
    <key>NumberOfFiles</key>
    <integer>1024</integer>
  </dict>
  <key>SoftResourceLimits</key>
  <dict>
    <key>NumberOfFiles</key>
    <integer>1024</integer>
  </dict>
</dict>
</plist>

E agora estou tentando iniciá-lo e receber um erro:

$ launchctl load ~/Library/LaunchAgents/homebrew.mxcl.mongodb24.plist
/usr/local/Cellar/mongodb24/2.4.12/homebrew.mxcl.mongodb24.plist: Operation not permitted

Parece que há algum problema com permissões. Mas eu não tenho certeza. Como posso consertar isso?

    
por schfkt 26.02.2015 / 16:14

1 resposta

11

Eu resolvi o problema usando serviços de preparação de alimentos . Remova o link simbólico primeiro:

$ rm ~/Library/LaunchAgents/homebrew.mxcl.mongodb24.plist

Instale serviços de cerveja:

$ brew tap gapple/services

Iniciar o mongodb:

$ brew services start mongodb24
==> Successfully started 'mongodb24' (label: homebrew.mxcl.mongodb24)

É isso aí!

ATUALIZAÇÃO:

Na verdade, isso acontece por causa do tmux. Quando você faz isso dentro de uma sessão do tmux:

$ brew services start redis
/Users/schfkt/Library/LaunchAgents/homebrew.mxcl.redis.plist: Operation not permitted
==> Successfully started 'redis' (label: homebrew.mxcl.redis)

$ brew services list
Warning: No user-space services controlled by 'brew services' running...

Você obtém o mesmo resultado: "Operação não permitida". E redis, claro, não é iniciado.

Mas tudo funciona bem quando você executa os mesmos comandos não dentro de uma sessão do tmux:

$ brew services start redis
==> Successfully started 'redis' (label: homebrew.mxcl.redis)

$ brew services list
redis      started    82912 /Users/schfkt/Library/LaunchAgents/homebrew.mxcl.redis.plist
    
por 26.02.2015 / 23:02