
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値をコメント解除して変更します。
例: ファイルの最大数 = 150000
ファイルを保存してアスタリスクを再起動します。
完璧
答え2
あなたのシステムが無視を使用しているようです。代わりに/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は設定に従って公式のサービスファイルを自動的に強化します。