Edited at

Macの「Too many open files」エラーを解消

More than 1 year has passed since last update.

「Too many open files」と出てで、ファイルが保存できないことがあった。

Railsを起動して、Gulpも起動してほげほげしてるとよく起こる。

Sublime Textでこのエラーが出ると設定も何もかも保存されないし、HotExitも効かないし、ファイルは開けないし詰む。

Atomでも起こるしOSのエラーと気づけた。

どうやらMacのファイルの上限に引っかかってしまっている模様。


確認する(初期)

$ 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 256 unlimited

maxfiles256になっている。


設定ファイルを作成する

/Library/LaunchDaemons/limit.maxfiles.plistに設定ファイルを作成する。初期ではファイルはないはず。

$sudo vi /Library/LaunchDaemons/limit.maxfiles.plist

viでもnanoでもsublでも。


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>


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

maxfiles524288になった。

「Too many open files」のエラーも出なくなった。

よかったよかった。