Nginx 急ぎ購入 電流制限構成 実装分析

Nginx 急ぎ購入 電流制限構成 実装分析

ビジネス上のニーズにより、急ぎの購入が発生することが多いため、ロード バランシング フロント エンドでのエラーの流れを制限する必要があります。この記事は、CC の防止にも適用されます。

  limit_req_zone $server_name zone=sname:10m rate=1r/s; #サーバーへのアクセスを1秒あたり1回のみに制限します #limit_req_zone $binary_remote_addr zone=one:3m rate=1r/s; #IPを制限し、1秒あたり1回のアクセスのみに制限します #limit_req_zone $binary_remote_addr $uri zone=two:3m rate=1r/s; #パラメータなしでIPとパスを制限します
    #limit_req_zone $binary_remote_addr $request_uri zone=thre:3m rate=1r/s; #パラメータでIPとパスを制限する server {
    聞く 80;
    サーバー名 www.abc.com;
    位置 / {
        host/proxy.cnf をインクルードします。
        proxy_pass http://backend;
    }
    場所 /api/createOrder {
        limit_req zone=sname; #バーストなし、通常のリクエストは1つだけ limit_req_status 503; #返されるステータスコードを503に設定する
        #limit_req zone=sname burst=5 nodelay; #最大同時実行数は 5 で、リアルタイム処理には host/proxy.cnf が含まれます。
        proxy_pass http://backend;
        error_page 503 =200 /50x.html; #これは非常に重要です。エラーステータスコードを503に設定し、結果を200として返すことができます。
    }
    場所 = /50x.html {
        $http_user_agent の場合、"モバイル|android|iPhone|iphone|ios|iOS"){
            #default_type アプリケーション/json;
            return 200 '{"msg": "イベントは人気が高すぎます。後でもう一度お試しください!","data": {},"code": -1}'; #モバイル端末にエラーメッセージ表示を返すように設定します}
        root html; #PCの場合はHTMLページを返す}
    }

ポイント: 通常の状況では、現在の制限が設定されている場合、返されるステータス コードは 503 です。モバイル端末の場合、JSON データを返してもクライアントはそれを認識しません。このとき、error_page 403 =200 /50x.html; を通じてステータス コードを巧みに 200 に設定できます。

上記では ngx_limit_req_module のみを使用していますが、ngx_limit_conn_module モジュールも使用できます。

参考: https://gist.github.com/simlegate/75b18359316cc33d8e20

特に、コンサルティングサイトの一部がクローラーのターゲットになっている場合、サーバーがクローラーによって強制終了される可能性があります(これは小規模なウェブサイトの場合に当てはまります)
では何ができるでしょうか?変数を使って

# グローバル設定 limit_req_zone $spider zone=spider:60m rate=200r/m; # クローラーの実行を 1 分間に 200 回に制限します # サーバー内 limit_req zone=spider burst=5 nodelay;
$http_user_agent の場合、"スパイダー|ボット" になります {
  set $spider $http_user_agent; #変数を設定し、ここに入力すると速度を制限します}

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Nginxの現在の制限設定の詳細な説明
  • ネットワークセグメント内の IP アドレスに対する Nginx の接続制限設定の詳細な説明
  • Nginx の現在の制限と構成管理の実践記録

<<:  Vue はコンポーネント間の通信をどのように実装しますか?

>>:  MySQL テーブルを削除する際の I/O エラーの原因分析と解決方法

推薦する

Mysqlはマスタースレーブ構成とマルチマスターマルチスレーブ構成を実装します

現在シミュレーションしているのは、マスター スレーブ システム (ホスト 1 台とスレーブ 1 台)...

MySQL/MariaDB でピボット テーブルを実装する方法のサンプル コード

前回の記事では、Oracle でピボット テーブルを実装するいくつかの方法を紹介しました。今日は、同...

MySQL 8.0はJSONを扱えるようになりました

目次1. 概要2. JSON基本ツール3. JSONパス式4. JSONを検索して変更する序文:長い...

表の最初の行と最初の列を固定し、適応型ウィンドウを実現するための CSS の例コード

今日のキャンパス採用筆記試験では、固定された最初の行と最初の列を実装し、幅をウィンドウの変更に適応さ...

シェル スクリプトを使用してワンクリックで MySQL 5.7.29 をインストールする方法

この記事は51CTOブログの著者wjw555の作品を参照しています。スクリプトの内容: vim イン...

VMware ESXi のインストールと使用記録(ダウンロード付き)

目次1. ESXiをインストールする2. ESXiをセットアップする3. ESXiを起動するESXi...

React の 3 つの主要属性における Ref の使用に関する詳細な説明

目次クラスコンポーネント機能コンポーネントインタビューのよくある質問: React における ref...

フォームのデフォルトの送信方法を変更する方法

htmlのデフォルトの送信方法は、postではなくgetです。postに変更したい場合は、 meth...

Win10環境にMysql5.7.23をインストールする際の問題点と落とし穴

たくさんのチュートリアルを読みましたが、うまくインストールできませんでした。しばらく試行錯誤した後、...

Dockerコンテナシェルスクリプトの実行ステータスを監視する方法

シナリオ会社のプロジェクトはDockerでデプロイされています。原因不明ですが、コンテナが時々停止し...

Linux echo テキスト処理コマンドの使用法と例

Linux ヘルプ ドキュメントでの echo の説明は、Python や Java などのプログラ...

Spark と Scala を使用して Apache アクセス ログを分析する方法

インストールまず、Java と Scala をインストールし、次に Spark をダウンロードしてイ...

HTMLヘッダータグの使用に関する詳細な説明

HTMLはヘッドとボディの2つの部分で構成されています** ヘッド内のタグはヘッドタグです** タイ...

MySQLのexplain型の詳細な説明

導入:多くの場合、さまざまな選択ステートメントを使用して必要なデータを照会した後、多くの人は作業が正...

CSSでフレックス配置を表示する(レイアウトツール)

display: flex レイアウトに関しては、深く理解している人もいますし、私も他の人の作業か...