Не удается запустить mongodb с помощью launchctl на OS X Yosemite (10.10.2)
Я установил mongodb 2.4 с помощью homebrew:
brew install homebrew/versions/mongodb24
Затем я сделал симлинк на конфиг, предоставленный homebrew:
ln -sfv /usr/local/opt/mongodb24/homebrew.mxcl.mongodb24.plist ~/Library/LaunchAgents
Этот файл содержит следующее:
<?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>
И теперь я пытаюсь запустить его и получить ошибку:
$ launchctl load ~/Library/LaunchAgents/homebrew.mxcl.mongodb24.plist
/usr/local/Cellar/mongodb24/2.4.12/homebrew.mxcl.mongodb24.plist: Operation not permitted
Похоже, что есть некоторые проблемы с разрешениями. Но я не уверен. Как я могу это исправить?
1 ответ
Решение
Я решил эту проблему с помощью услуг brew. Сначала удалите символическую ссылку:
$ rm ~/Library/LaunchAgents/homebrew.mxcl.mongodb24.plist
Установите услуги brew:
$ brew tap gapple/services
Начать mongodb:
$ brew services start mongodb24
==> Successfully started `mongodb24` (label: homebrew.mxcl.mongodb24)
Это оно!
ОБНОВИТЬ:
На самом деле это происходит из-за tmux. Когда вы делаете это внутри сессии 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...
Вы получаете тот же результат: "Операция не разрешена". И редис конечно не запускается.
Но все работает нормально, когда вы запускаете те же команды не в сеансе 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