ディレクトリ
ABツール
全体の最適化のアイデアを
具体的な最適化のアイデアは、
スクリプトが完了し、書き込みの割り当てを最適化するための
パフォーマンス統計ツール
ヒントの
概要を
ABツール
AB -c 10000 -n 200000のhttp://localhost/index.html
[root@study02 ~]# ab -c 10000 -n 100000 http://192.168.0.217/index.html
This is ApacheBench, Version 2.3 <$Revision: 1430300 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking 192.168.0.217 (be patient)
socket: Too many open files (24)
全体の最適化のアイデア
- より多くのソケット接続が確立される許可
- より多くの開いているファイルを許可します
具体的な最適化のアイデア
図1に示すように、ソケット・レベル
- システムレベル
- ない洪水に対する
- 最大接続数SOMAXCONN
- TCP接続回復recyleをスピードアップ
- 空のTCP接続がリサイクル再利用することが許可されています
- nginxの
- それぞれの子プロセスはオープン接続(work_connections)を可能に
- HTTP接続を加速、迅速な決算、keepalive_timeout 0
2、ファイルレベル
- nginxのレベル
- Worker_rlimit_nofile子プロセスはファイルを開くことができます
- システムレベル
- 10000 -nのulimit(比較的大きな値が開いているファイルを許可、提供されます)
特定の設定
図1に示すように、システム構成
オープン接続の最大数を許可するようにシステムを見ます
more /proc/sys/net/core/somaxconn
echo 50000 > /proc/sys/net/core/somaxconn
クイック接続システムの復旧を開きます。
cat /proc/sys/net/ipv4/tcp_tw_recycle
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle
空のオープンTCP接続は、リサイクルすることができます
cat /proc/sys/net/ipv4/tcp_tw_reuse
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
ない洪水に対する
cat /proc/sys/net/ipv4/tcp_syncookies
echo 0 > /proc/sys/net/ipv4/tcp_syncookies
2、nginxの構成
- HTTP 1.0クライアントサーバ要求 - 応答 - OFF
- HTTP 1.1、頻繁に握手を防ぐためにnginxのセットkeepalive_timeout引数は、リクエストが完了した後、重大な注意が必要であるkeepalivedの、並行性の高いウェブサイトでのTCP接続の数を減らすために、長い接続するオプションを維持され、0に設定する必要はありません並行性を改善するために、接続を維持します
worker_rlimit_nofile 10000;
events {
worker_connections 10000;
}
keepalive_timeout 0;
スクリプトの完全な同時最適配分
echo 50000 > /proc/sys/net/core/somaxconn
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
echo 0 > /proc/sys/net/ipv4/tcp_syncookies
この問題を解消します:
- dmesgの観測システム
- error.logファイルを観察するnginxの
dmesgの|尾
パフォーマンス統計ツール
nginxのの状態を観察することが容易なインストールの統計モジュールhttp_stub_status_module、
- 1.モジュールをインストールすることができ、統計があるかどうかを見つけるために、nginxのインストールパッケージディレクトリに入る前に
削除選択したすべてのパッケージがインストールすることができます
root@STUDY3 nginx-1.14.2]# cat auto/options |grep YES
HTTP=YES
HTTP_CACHE=YES
HTTP_CHARSET=YES
HTTP_GZIP=YES
HTTP_SSI=YES
HTTP_ACCESS=YES
HTTP_AUTH_BASIC=YES
HTTP_MIRROR=YES
HTTP_USERID=YES
HTTP_AUTOINDEX=YES
HTTP_GEO=YES
HTTP_MAP=YES
HTTP_SPLIT_CLIENTS=YES
HTTP_REFERER=YES
HTTP_REWRITE=YES
HTTP_PROXY=YES
HTTP_FASTCGI=YES
HTTP_UWSGI=YES
HTTP_SCGI=YES
HTTP_GRPC=YES
HTTP_MEMCACHED=YES
HTTP_LIMIT_CONN=YES
HTTP_LIMIT_REQ=YES
HTTP_EMPTY_GIF=YES
HTTP_BROWSER=YES
HTTP_UPSTREAM_HASH=YES
HTTP_UPSTREAM_IP_HASH=YES
HTTP_UPSTREAM_LEAST_CONN=YES
HTTP_UPSTREAM_KEEPALIVE=YES
HTTP_UPSTREAM_ZONE=YES
MAIL_POP3=YES
MAIL_IMAP=YES
MAIL_SMTP=YES
STREAM_LIMIT_CONN=YES
STREAM_ACCESS=YES
STREAM_GEO=YES
STREAM_MAP=YES
STREAM_SPLIT_CLIENTS=YES
STREAM_RETURN=YES
STREAM_UPSTREAM_HASH=YES
STREAM_UPSTREAM_LEAST_CONN=YES
STREAM_UPSTREAM_ZONE=YES
--with-select_module) EVENT_SELECT=YES ;;
--with-poll_module) EVENT_POLL=YES ;;
--with-threads) USE_THREADS=YES ;;
--with-file-aio) NGX_FILE_AIO=YES ;;
--with-http_ssl_module) HTTP_SSL=YES ;;
--with-http_v2_module) HTTP_V2=YES ;;
--with-http_realip_module) HTTP_REALIP=YES ;;
--with-http_addition_module) HTTP_ADDITION=YES ;;
--with-http_xslt_module) HTTP_XSLT=YES ;;
--with-http_image_filter_module) HTTP_IMAGE_FILTER=YES ;;
--with-http_geoip_module) HTTP_GEOIP=YES ;;
--with-http_sub_module) HTTP_SUB=YES ;;
--with-http_dav_module) HTTP_DAV=YES ;;
--with-http_flv_module) HTTP_FLV=YES ;;
--with-http_mp4_module) HTTP_MP4=YES ;;
--with-http_gunzip_module) HTTP_GUNZIP=YES ;;
--with-http_gzip_static_module) HTTP_GZIP_STATIC=YES ;;
--with-http_auth_request_module) HTTP_AUTH_REQUEST=YES ;;
--with-http_random_index_module) HTTP_RANDOM_INDEX=YES ;;
--with-http_secure_link_module) HTTP_SECURE_LINK=YES ;;
--with-http_degradation_module) HTTP_DEGRADATION=YES ;;
--with-http_slice_module) HTTP_SLICE=YES ;;
--with-http_perl_module) HTTP_PERL=YES ;;
--with-http_stub_status_module) HTTP_STUB_STATUS=YES ;;
--with-mail) MAIL=YES ;;
--with-mail_ssl_module) MAIL_SSL=YES ;;
MAIL=YES
MAIL_SSL=YES
--with-stream) STREAM=YES ;;
--with-stream_ssl_module) STREAM_SSL=YES ;;
--with-stream_realip_module) STREAM_REALIP=YES ;;
--with-stream_geoip_module) STREAM_GEOIP=YES ;;
STREAM_SSL_PREREAD=YES ;;
--with-google_perftools_module) NGX_GOOGLE_PERFTOOLS=YES ;;
--with-cpp_test_module) NGX_CPP_TEST=YES ;;
--with-compat) NGX_COMPAT=YES ;;
--with-debug) NGX_DEBUG=YES ;;
--with-pcre) USE_PCRE=YES ;;
--with-pcre-jit) PCRE_JIT=YES ;;
--with-libatomic) NGX_LIBATOMIC=YES ;;
--test-build-devpoll) NGX_TEST_BUILD_DEVPOLL=YES ;;
--test-build-eventport) NGX_TEST_BUILD_EVENTPORT=YES ;;
--test-build-epoll) NGX_TEST_BUILD_EPOLL=YES ;;
--test-build-solaris-sendfilev) NGX_TEST_BUILD_SOLARIS_SENDFILEV=YES ;;
そこhttp_stub_status_moduleモジュールかどうかを確認します
[root@STUDY3 nginx-1.14.2]# cat auto/options |grep YES|grep 'http_stub_status_module'
--with-http_stub_status_module) HTTP_STUB_STATUS=YES ;;
make && make install
- 2. nginxのパフォーマンス統計ツールをインストールします。
./configure --prefix=/usr/local/nginx/ --with-http_stub_status_module
- モジュールが正常にインストールされているかどうか3.チェック
[root@STUDY3 nginx-1.14.2]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC)
configure arguments: --prefix=/usr/local/nginx/ --with-http_stub_status_module
説明モジュールが正常にインストールされています
- 4. nginxのサーバー設定ツールのオープニングパフォーマンス統計内の次の設定項目を追加します。
location /nginx_status {
stub_status on;
access_log off;
allow 127.0.0.1;
}
- 5.ビュー、ステータスを表示するページへのアクセスを更新しhttp://192.168.0.217/nginx_status
Active connections: 2020
server accepts handled requests
897553 897553 442986
Reading: 0 Writing: 1 Waiting: 2019
- 6.abテスト
[root@study02 ~]# ab -c 10000 -n 200000 http://192.168.0.217/index.html
This is ApacheBench, Version 2.3 <$Revision: 1430300 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking 192.168.0.217 (be patient)
Completed 20000 requests
Completed 40000 requests
Completed 60000 requests
Completed 80000 requests
Completed 100000 requests
Completed 120000 requests
Completed 140000 requests
Completed 160000 requests
Completed 180000 requests
Completed 200000 requests
Finished 200000 requests
Server Software: nginx/1.14.2
Server Hostname: 192.168.0.217
Server Port: 80
Document Path: /index.html
Document Length: 612 bytes
Concurrency Level: 10000
Time taken for tests: 13.268 seconds
Complete requests: 200000
Failed requests: 345710
(Connect: 0, Receive: 0, Length: 174517, Exceptions: 171193)
Write errors: 0
Non-2xx responses: 21
Total transferred: 24276700 bytes
HTML transferred: 17581305 bytes
Requests per second: 15074.19 [#/sec] (mean)
Time per request: 663.386 [ms] (mean)
Time per request: 0.066 [ms] (mean, across all concurrent requests)
Transfer rate: 1786.87 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 322 85.2 324 1238
Processing: 69 322 108.4 315 692
Waiting: 0 38 103.0 0 503
Total: 373 643 97.8 625 1651
Percentage of the requests served within a certain time (ms)
50% 625
66% 640
75% 643
80% 646
90% 739
95% 883
98% 976
99% 1015
100% 1651 (longest request)
ヒント
- テスト機も大型デジタルはulimit -nを設定する必要があります
- 試験機を構成する必要がエコー50000>の/ proc / sysの/純/コア/ SOMAXCONN
概要
最初の試験開始nginxのは、ロジックのみではない、でもキャッシュではないデータベースの操作を行い、静的なHTMLページのテストが始まる実行することができたときに、サーバの導入時間を行う際には、まず、サーバーの構成やサーバーの限界を処理することができます理解する必要があります治療は、nginxのの最大容量をテストするために、CDNをしません。我々は、すべてのデータベースに接続し、PHPを、参加する場合は、データベースキャッシュがCDN写真はインパクトの同時実行性を持っているか、最大のパフォーマンスのプレスサーバ用に個別にデバッグと同じであるものの後に、対象の最適化が正しいことを知っています。