
Debian 8のAsterisk 13.11.2で、開いているファイルの制限に達するとクラッシュするという問題が発生しています。
bridge_channel.c: Can't create pipe! Try increasing max file descriptors with ulimit -n
私は、制限を65536から150000に増やすことができました。/etc/security/limits.conf
以下を追加しました:
root soft nofile 150000
root hard nofile 150000
* soft nofile 150000
* hard nofile 150000
の結果はulimit -n
150000になりました
アスタリスクプロセスの制限を確認しようとするとcat /proc/xxx/limits
まだ古い制限が適用されます!
Limit Soft Limit Hard Limit Units
Max cpu time unlimited unlimited seconds
Max file size unlimited unlimited bytes
Max data size unlimited unlimited bytes
Max stack size 8388608 unlimited bytes
Max core file size 0 unlimited bytes
Max resident set unlimited unlimited bytes
Max processes 31945 31945 processes
Max open files 1024 4096 files
Max locked memory 65536 65536 bytes
Max address space unlimited unlimited bytes
Max file locks unlimited unlimited locks
Max pending signals 31945 31945 signals
Max msgqueue size 819200 819200 bytes
Max nice priority 0 0
Max realtime priority 0 0
Max realtime timeout unlimited unlimited us
これをどうやって解決すればいいでしょうか?
答え1
/usr/sbin/safe_asteriskのMAXFILESのコメントを解除して値を変更します。
例: MAXFILES = 150000
ファイルを保存してアスタリスクを再起動する
終わり
答え2
あなたのシステムは を無視する systemd を使用しているのではないかと思います/etc/security/limits.conf
。代わりに、これらの制限をアスタリスクサービスファイル (/etc/systemd/system/asterisk.service
または/lib/systemd/system/asterisk.service
) で設定する必要があります。おそらく以下を追加する必要があるでしょう。
LimitNOFILE=150000
Asterisk に付属するファイルを編集することはおそらく望ましくないことに注意してください。次回の Asterisk アップデートで変更が上書きされるリスクがあるためです。代わりに、/etc/systemd/system/asterisk.d/10-file-descriptors.conf
上記の行を含むファイルを作成することをお勧めします。Systemd は、公式のサービス ファイルを設定に合わせて自動的に拡張します。