検索
ホームページバックエンド開発PHPチュートリアルシステム再起動後に ngix リロードが有効にならない理由の分析_PHP チュートリアル

システムの再起動後にngixのリロードが有効にならない理由の分析

システムの再起動後にngixのリロードが有効にならない理由の分析

これは、長い間私を悩ませてきた比較的まれな問題ですこの問題は非常に単純ですが、時間が経っても根本原因を見つけるのはまだ困難です。その分析プロセスを次のように共有します。

前提条件: Linux システムの起動プロセス、Nginx プロセスの起動プロセス、プロセス追跡について一定の理解を持っている必要があります。




1. Nginx リロード プロセスの分析:
公式 Web サイトのドキュメントを確認し、Nginx ソース コードを分析した結果、リロード プロセスは次の操作を実行したと大まかに結論付けることができます。


1、設定が正しいか確認
nginx -tに相当
2、ログファイルを開く
nginx -sopenに相当
ログファイルが多いため複数のファイルを開く必要がある
3、再ソケットをリッスンします
nginx の場合は同等です
このステップでは多くのものが初期化され、ハッシュ テーブルに焦点を当てます
4、古いワーカー プロセスを閉じます
nginx -s quit と同等です




2 番目、nginx プロセス分析
1 、まず nginx の 2 つのプロセスを理解します
マスター プロセス、root ユーザーによって開かれ、シグナルを受信し、ワーカー プロセスを管理します
ワーカー プロセス、nginx ユーザーによって開かれ、ワーカー プロセス、http リクエストの処理を担当します


2、starce はメイン プロセスを追跡しますnginx -s reloadが実行されている間に、チェックでスタックしていることがわかります。 リロードプロセスはnginxメインプロセスにHUPシグナルを送信するシステムであるため、ログファイルはメインプロセスによって追跡されます
# starce -p 2298
...
open("/data/wwwlogs/access.xxx.xxx.xxx .log", O_WRONLY|O_CREAT|O_APPEND, 0644) = -1 EMFILE (開いているファイルが多すぎます)
write(808 , "2016/02/17 09:50:22 [emerg] 2298"..., 124) = 124
....


3、プロンプトに従ってプロセスのシステム制限ファイルを見つけます


マスタープロセス制限
# cat /proc/2398/limits
ソフトリミットハードリミットユニットを制限
最大CPU時間無制限無制限秒
最大ファイルサイズ無制限無制限バイト
最大データサイズ無制限無制限バイト
最大スタックサイズ10485760無制限バイト
最大コアファイルサイズ 0 無制限バイト
最大常駐セット数 無制限 無制限バイト
最大プロセス数 127015 127015 プロセス
最大オープンファイル数 1024 4096 ファイル
最大ロックメモリ 65536 65536 バイト
最大アドレス空間 無制限 無制限バイト
最大ファイルロック数 無制限 無制限ロック数
最大保留中のシグナル127015 127015信号
マックスMSGQUEUEサイズ819200バイト819200バイト
マックスマックスマックス優先度0 0ハードリミットユニットの制限
最大 CPU 時間 無制限 無制限秒数
最大ファイル サイズ 無制限 無制限バイト
最大データ サイズ 無制限 無制限バイト
最大スタック サイズ 10485760 無制限バイト
最大コア ファイル サイズ 0 無制限バイト
最大常駐セット数 無制限 無制限バイト
最大プロセス数127015 127015 プロセス
最大オープンファイル数 409600 409600 ファイル
最大ロックメモリ数 65536 65536 バイト
最大アドレススペース無制限無制限バイト
最大ファイルロック数無制限無制限ロック
最大保留シグナル数 127015 127015 シグナル
最大メッセージキューサイズ 8 19200 819200 バイト
最大素敵優先度 0 0
最大リアルタイム優先度 0 0
最大リアルタイムタイムアウト 無制限 無制限 us




補足エラーログ:
2 016/02/ 17 10:48:05 [notice] 47386#0: signal process開始
2016/02/ 17 10:48:05 [emerg] 2298#0: open() "/data/wwwlogs/access_xxx.xxx.xxx.log " が失敗しました (24: 開いているファイルが多すぎます)




3、解決策
1、制限を変更します
一般的には、次の 3 つの側面から調整します。
最初: nginx.conf パラメーターの計画と設定
worker_rlimit_nofile: 単一のジョブを制限する
プロセスによって開かれるファイルの最大数:
オンライン構成に問題はありません
worker_rlimit_nofile 409600;


2番目: システムレベルの検査と設定
つまり、/etc/security/limits.confの構成と変更については、Linuxシステムリソース制限の概要を参照してください
オンライン構成に問題はありません
*ソフト nofile 655350
* ハード nofile 655350


3 番目: カーネルレベルのチェックと設定:
fs.file-max 値のサイズ設定:
オンライン構成は比較的大きいです
file-max = 6553600
注: デフォルト。 file-max の値はシステム メモリの約 10% (システム メモリは kb 単位で計算されます)




2、検証が有効になります
初期段階では上記の設定になっていることが分かりましたが、サーバーを再起動するとメインプロセスの制限が変更されていないことがわかりますが、サーバーにログインした後に表示されるかどうかはわかりません。ターミナルで ulimit -n を実行するか、nginx メインプロセスを閉じた後に nginx を再起動すると、効果が現れます。このことから、問題は Linux システムの起動プロセスにある可能性があります。つまり、nginx メインプロセスの起動時に、上記の制限設定は有効になりません。後で情報を調べたところ、limits.conf 設定はシステム起動後にログインが実行されるまで有効にならないため、順序を調整する必要があることがわかりました。
実際の状況に基づく、システムの起動プロセスは次のとおりです。
1. /etc/inittab を読み取り、デフォルトのレベルを読み取ります。
2. 初期化システム スクリプトを実行します。 .d/rc.sysinit を使用してスクリプトを初期化します
3. 次に、/etc/rc.d/rc スクリプトを実行します
4. このスクリプトは、最後のスクリプトです。起動プロセス中に開始されます。
最後に/bin/loginが実行されてユーザーがログインします。この時点でシステムの起動処理は完了しており、/etc/profile、~/.bash_profile、~/.bashrc 等はログイン後にのみ実行されます。このときの ulimit -n で求められる値は、 nginxプロセスが開始されたときの値。
デフォルトでは、limits.conf 設定ファイルはユーザーがログインしたときに有効になります。これは nginx プロセスの開始よりも後で有効になります。これより前に設定を有効にするには、次のように設定を補足する必要があります:
cat /etc/rc.local
ulimit -HSn 655350 (nginx の開始前に実行されることに注意してください)
/usr/local/nginx/sbin/nginx






4 番目の補足的な最適化


には、主に関連するパラメーター。
1. カーネルの最適化
iptable 自体がカーネルのパフォーマンスに影響を与えるため、Net.ipv4.tcp_max_tw_buckets を大きく変更する必要があります
# ss -an |awk '{print $1}'|sort |uniq -c |sort -rn
15415 ESTAB
12979 TIME-WAIT
1961 FIN-WAIT-2
501 FIN-WAIT-1
234 LAST-ACK
32 SYN-RECV
11 リッスン
3 クローズ
1 SYN-SENT
1 州
1 CLOSE-WAIT


オンライン構成の変更は次のとおりです:
net.ipv4.tcp_max_tw_buckets = 18000


2、nginx の最適化
主にハッシュ テーブル、その他の構成は最適化されており、ハッシュ テーブルには次のタイプがあります
server_names_hash を追加できます
map_hash は追加できます
types_hash を追加するだけで十分です
リクエストヘッダーは考慮されません
variables_hash で十分です


オンライン設定は次のとおりです:
server_names_hash_max_size 512000;
server_names_hash_bucket_size 64; )
map_hash_max_size 204800 ;
map_hash_bucket_size 64 ; (デフォルト)


http://www.bkjia.com/PHPjc/1103189.htmlwww.bkjia.com本当http://www.bkjia.com/PHPjc/1103189.html技術記事システムの再起動後に ngix のリロードが有効にならない理由の分析 システムの再起動後に ngix のリロードが有効にならない理由の分析 この問題は比較的まれですが、私を悩ませてきました。とてもシンプルです...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
如何在 iPhone 和 Android 上关闭蓝色警报如何在 iPhone 和 Android 上关闭蓝色警报Feb 29, 2024 pm 10:10 PM

根据美国司法部的解释,蓝色警报旨在提供关于可能对执法人员构成直接和紧急威胁的个人的重要信息。这种警报的目的是及时通知公众,并让他们了解与这些罪犯相关的潜在危险。通过这种主动的方式,蓝色警报有助于增强社区的安全意识,促使人们采取必要的预防措施以保护自己和周围的人。这种警报系统的建立旨在提高对潜在威胁的警觉性,并加强执法机构与公众之间的沟通,以共尽管这些紧急通知对我们社会至关重要,但有时可能会对日常生活造成干扰,尤其是在午夜或重要活动时收到通知时。为了确保安全,我们建议您保持这些通知功能开启,但如果

如何在Android中实现按下返回键再次退出的功能?如何在Android中实现按下返回键再次退出的功能?Aug 30, 2023 am 08:05 AM

为了提升用户体验并防止数据或进度丢失,Android应用程序开发者必须避免意外退出。他们可以通过加入“再次按返回退出”功能来实现这一点,该功能要求用户在特定时间内连续按两次返回按钮才能退出应用程序。这种实现显著提升了用户参与度和满意度,确保他们不会意外丢失任何重要信息Thisguideexaminesthepracticalstepstoadd"PressBackAgaintoExit"capabilityinAndroid.Itpresentsasystematicguid

在Android中实现轮询的方法是什么?在Android中实现轮询的方法是什么?Sep 21, 2023 pm 08:33 PM

Android中的轮询是一项关键技术,它允许应用程序定期从服务器或数据源检索和更新信息。通过实施轮询,开发人员可以确保实时数据同步并向用户提供最新的内容。它涉及定期向服务器或数据源发送请求并获取最新信息。Android提供了定时器、线程、后台服务等多种机制来高效地完成轮询。这使开发人员能够设计与远程数据源保持同步的响应式动态应用程序。本文探讨了如何在Android中实现轮询。它涵盖了实现此功能所涉及的关键注意事项和步骤。轮询定期检查更新并从服务器或源检索数据的过程在Android中称为轮询。通过

Android逆向中smali复杂类实例分析Android逆向中smali复杂类实例分析May 12, 2023 pm 04:22 PM

1.java复杂类如果有什么地方不懂,请看:JAVA总纲或者构造方法这里贴代码,很简单没有难度。2.smali代码我们要把java代码转为smali代码,可以参考java转smali我们还是分模块来看。2.1第一个模块——信息模块这个模块就是基本信息,说明了类名等,知道就好对分析帮助不大。2.2第二个模块——构造方法我们来一句一句解析,如果有之前解析重复的地方就不再重复了。但是会提供链接。.methodpublicconstructor(Ljava/lang/String;I)V这一句话分为.m

如何在2023年将 WhatsApp 从安卓迁移到 iPhone 15?如何在2023年将 WhatsApp 从安卓迁移到 iPhone 15?Sep 22, 2023 pm 02:37 PM

如何将WhatsApp聊天从Android转移到iPhone?你已经拿到了新的iPhone15,并且你正在从Android跳跃?如果是这种情况,您可能还对将WhatsApp从Android转移到iPhone感到好奇。但是,老实说,这有点棘手,因为Android和iPhone的操作系统不兼容。但不要失去希望。这不是什么不可能完成的任务。让我们在本文中讨论几种将WhatsApp从Android转移到iPhone15的方法。因此,坚持到最后以彻底学习解决方案。如何在不删除数据的情况下将WhatsApp

同样基于linux为什么安卓效率低同样基于linux为什么安卓效率低Mar 15, 2023 pm 07:16 PM

原因:1、安卓系统上设置了一个JAVA虚拟机来支持Java应用程序的运行,而这种虚拟机对硬件的消耗是非常大的;2、手机生产厂商对安卓系统的定制与开发,增加了安卓系统的负担,拖慢其运行速度影响其流畅性;3、应用软件太臃肿,同质化严重,在一定程度上拖慢安卓手机的运行速度。

Android中动态导出dex文件的方法是什么Android中动态导出dex文件的方法是什么May 30, 2023 pm 04:52 PM

1.启动ida端口监听1.1启动Android_server服务1.2端口转发1.3软件进入调试模式2.ida下断2.1attach附加进程2.2断三项2.3选择进程2.4打开Modules搜索artPS:小知识Android4.4版本之前系统函数在libdvm.soAndroid5.0之后系统函数在libart.so2.5打开Openmemory()函数在libart.so中搜索Openmemory函数并且跟进去。PS:小知识一般来说,系统dex都会在这个函数中进行加载,但是会出现一个问题,后

Android APP测试流程和常见问题是什么Android APP测试流程和常见问题是什么May 13, 2023 pm 09:58 PM

1.自动化测试自动化测试主要包括几个部分,UI功能的自动化测试、接口的自动化测试、其他专项的自动化测试。1.1UI功能自动化测试UI功能的自动化测试,也就是大家常说的自动化测试,主要是基于UI界面进行的自动化测试,通过脚本实现UI功能的点击,替代人工进行自动化测试。这个测试的优势在于对高度重复的界面特性功能测试的测试人力进行有效的释放,利用脚本的执行,实现功能的快速高效回归。但这种测试的不足之处也是显而易见的,主要包括维护成本高,易发生误判,兼容性不足等。因为是基于界面操作,界面的稳定程度便成了

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境