Macのファイルディスクリプタ上限を上げる
この設定のままSierraにアップデートしたけど、有効だった shokai.icon (2016/10/31) エラーメッセージ
ENFILE: file table overflow, open (~~~filename~~~)
あるいはfile table overflow
MacのOSバージョン毎に違ったりして、Sierraに上げたらまた設定するの面倒だなあとか思ってやってなかった 実際設定してみたら3分ぐらいでできた
現在のファイルディスクリプタ数
$ ulimit -a
code:result
-t: cpu time (seconds) unlimited
-f: file size (blocks) unlimited
-d: data seg size (kbytes) unlimited
-s: stack size (kbytes) 8192
-c: core file size (blocks) 0
-v: address space (kbytes) unlimited
-l: locked-in-memory size (kbytes) unlimited
-u: processes 709
-n: file descriptors 7168
7168だった
参考になる
同じ手順で設定してみる
/Library/LaunchDaemons/に2つplistファイルを置く code:limit.maxfiles.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN"
<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>
code:limit.maxproc.plist
<?xml version="1.0" encoding="UTF-8"?>
<plist version="1.0">
<dict>
<key>Label</key>
<string>limit.maxproc</string>
<key>ProgramArguments</key>
<array>
<string>launchctl</string>
<string>limit</string>
<string>maxproc</string>
<string>2048</string>
<string>2048</string>
</array>
<key>RunAtLoad</key>
<true />
<key>ServiceIPC</key>
<false />
</dict>
</plist>
ownerをrootにする
$ sudo chown root /Library/LaunchDaemons/limit.max*.plist
設定を有効にする
$ sudo launchctl load -w /Library/LaunchDaemons/limit.maxfiles.plist
$ sudo launchctl load -w /Library/LaunchDaemons/limit.maxproc.plist
リブートする
sudo rebootしたらフリーズしたので電源ボタン押して強制終了&再起動した
結果
$ ulimit -a
code:result
-t: cpu time (seconds) unlimited
-f: file size (blocks) unlimited
-d: data seg size (kbytes) unlimited
-s: stack size (kbytes) 8192
-c: core file size (blocks) 0
-v: address space (kbytes) unlimited
-l: locked-in-memory size (kbytes) unlimited
-u: processes 2048
-n: file descriptors 524288
file descriptors増えてた!