「Too many open files」と出てで、ファイルが保存できないことがあった。
Railsを起動して、Gulpも起動してほげほげしてるとよく起こる。
Sublime Textでこのエラーが出ると設定も何もかも保存されないし、HotExitも効かないし、ファイルは開けないし詰む。
Atomでも起こるしOSのエラーと気づけた。
どうやらMacのファイルの上限に引っかかってしまっている模様。
確認する(初期)
コマンドで現在の上限数を確認。
$ launchctl limit
cpu unlimited unlimited
filesize unlimited unlimited
data unlimited unlimited
stack 8388608 67104768
core 0 unlimited
rss unlimited unlimited
memlock unlimited unlimited
maxproc 709 1064
maxfiles 256 unlimited
maxfiles
が256
になっている。これが上限に達しているらしい。
設定ファイルを作成する
/Library/LaunchDaemons/limit.maxfiles.plist
に設定ファイルを作成する。初期ではファイルはないはず。
$sudo vi /Library/LaunchDaemons/limit.maxfiles.plist
vi
でもnano
でもcode
でもお好きなエディタのコマンドで下記コードをコピペ。
limit.maxfiles.plist
<?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>limit.maxfiles</string>
<key>ProgramArguments</key>
<array>
<string>launchctl</string>
<string>limit</string>
<string>maxfiles</string>
<string>524288</string>
<string>524288</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>ServiceIPC</key>
<false/>
</dict>
</plist>
524288
としてますが、よしなな数値で構いません。
plistファイルを読み込んで適用させる
$ sudo launchctl load -w /Library/LaunchDaemons/limit.maxfiles.plist
再起動でもできるっぽい。
適用を確認する
$ sudo launchctl limit
cpu unlimited unlimited
filesize unlimited unlimited
data unlimited unlimited
stack 8388608 67104768
core 0 unlimited
rss unlimited unlimited
memlock unlimited unlimited
maxproc 709 1064
maxfiles 524288 524288
maxfiles
が524288
になった。
「Too many open files」のエラーも出なくなった。
よかったよかった。