web-dev-qa-db-ja.com

nginx maxオープンファイルを設定する方法?

私は次の設定を行い、サーバーを再起動しましたが:

# head /etc/security/limits.conf -n2
www-data soft nofile -1
www-data hard nofile -1
# /sbin/sysctl fs.file-max
fs.file-max = 201558

特定のプロセスのオープンファイルの制限は、依然として1024/4096です。

# ps aux | grep nginx
root       983  0.0  0.0  85872  1348 ?        Ss   15:42   0:00 nginx: master process /usr/sbin/nginx
www-data   984  0.0  0.2  89780  6000 ?        S    15:42   0:00 nginx: worker process
www-data   985  0.0  0.2  89780  5472 ?        S    15:42   0:00 nginx: worker process
root      1247  0.0  0.0  11744   916 pts/0    S+   15:47   0:00 grep --color=auto nginx
# cat /proc/984/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             15845                15845                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       15845                15845                signals
Max msgqueue size         819200               819200               bytes
Max Nice priority         0                    0
Max realtime priority     0                    0
Max realtime timeout      unlimited            unlimited            us

私はググリングからすべての可能な解決策を試しましたが、無駄でした。どの設定を見逃しましたか?

20
Jian Weihang

CentOS(7.xでテスト済み):

次の内容のファイル/etc/systemd/system/nginx.service.d/override.confを作成します。

[Service]
LimitNOFILE=65536

Systemdデーモンを次のようにリロードします:

systemctl daemon-reload

これをNginx構成ファイルに追加します。

worker_rlimit_nofile 16384; (has to be smaller or equal to LimitNOFILE set above)

そして最後にNginxを再起動します:

systemctl restart nginx

cat /proc/<nginx-pid>/limitsで動作することを確認できます。

33
sickill

この質問を投稿してから数分で答えが見つかりました...

# cat /etc/default/nginx
# Note: You may want to look at the following page before setting the ULIMIT.
#  http://wiki.nginx.org/CoreModule#worker_rlimit_nofile
# Set the ulimit variable if you need defaults to change.
#  Example: ULIMIT="-n 4096"
ULIMIT="-n 15000"

/etc/security/limit.confはPAMで使用されるため、www-data(nologinユーザー)とは何の関係もありません。

10
Jian Weihang