MySQLデータベースのSYNフラッディング問題を解決する

MySQLデータベースのSYNフラッディング問題を解決する

Syn 攻撃は、最も一般的で最も簡単に悪用される攻撃方法です。TCP プロトコルの欠陥を利用して、偽造された TCP 接続要求を大量に送信します。多くの場合、偽の IP を使用して大量の SYN パケットが送信されます。攻撃を受けたサーバーは SYN+ACK で応答します。相手は偽の IP であるため、パケットを受信することはなく、応答しません。その結果、攻撃を受けたサーバーは SYN_RECV 状態で大量のセミ接続を維持し、デフォルトの 5 つの応答ハンドシェイク パケットを再試行し、TCP 待機接続キューをいっぱいにしてリソースを使い果たし、通常のビジネス要求が接続できなくなります。

Syn 攻撃はアプリケーション サーバーでよく発生し、データベース サーバーはイントラネット内にあるため、同様の攻撃に遭遇する可能性は低いです。ただし、アプリケーションがデータベースに正しく接続されていない場合、データベース側で Syn 攻撃とみなされ、接続が拒否されることがあります。

[問題の説明]

データベースが突然接続を拒否し、アプリケーションがエラーを報告します。問題が発生したとき、データベース サーバーのオペレーティング システム ログ (/var/log/messages) に次のエラー メッセージが表示されます。

カーネル: ポート 3306 で SYN フラッディングの可能性があります。Cookie を送信しています。

【問題分析】

問題が発生した時点で、データベース監視インジケーターから判断すると、Threads Connected インジケーターが増加しました。これも非常に明白です。データベースの場合、Syn Flooding は、アプリケーションが突然データベースへの接続を開始し、オペレーティング システムがそれを処理できないため、Syn Flooding を報告することを意味します。データベースのパフォーマンス インジケーターの観点から見ると、接続数は間違いなく急増します。解決策は、これらの突然の増加がどこから来ているのかを分析し、ピークを平滑化し、谷を埋めて、接続をより安定させることです。

【解決】

データベース サーバー側で、次の調整を行います。この調整は、TCP ハーフ接続バッファを増やすことを意味します。デフォルト値は 2048 ですが、突然の負荷に耐えるシステムの能力を高めるために 8192 に調整します。 Tcp_syn_retires と Tcp_synack_retires のデフォルト値は 5 です。これは、再試行を終了する前にサーバーが 5 つのパケットを送信する必要があることを意味します。このパラメータを 2 に調整します。再試行は 1 回だけなので、エラー パケットをできるだけ早く解決して、キャッシュされた接続の数を減らすことができます。

エコー 8192 > /proc/sys/net/ipv4/tcp_max_syn_backlog
エコー 2 > /proc/sys/net/ipv4/tcp_syn_retries
エコー 2 > /proc/sys/net/ipv4/tcp_synack_retries

このパラメータ調整は再起動せずにすぐに有効になります。もちろん、サーバーを再起動すると、これらのパラメータはデフォルト値に戻ります。この調整により、データベースのストレス耐性は強化されましたが、問題は完全に解決されませんでした。

クライアント側でも対応する調整を行います。

データベース接続数への負荷を軽減するために、通常は接続プールを次のように構成することをお勧めします。

testWhileIdle="false"。アイドル時に接続文字列の健全性をチェックしない
minIdle="0"。接続プール内のアイドル接続の最小数
maxAge="30000"です。リンクは一定のミリ秒数後にリサイクルできます。
初期サイズ="1"。接続プール内の初期接続の最小数
timeBetweenEvictionRunsMillis="5000"。リサイクルスレッドの実行間隔(ミリ秒)

現在のシナリオでは、minIdle パラメータを 0 から 5 に増やすことをお勧めします。接続プールには通常 5 つのアイドル接続があるようにします。このようにして、データベースへの要求が開始されると、これらの 5 つのアイドル接続が最初に使用されます。山を削り谷を埋める効果を実現します。もちろん、副作用としてデータベース接続の数が増加します。適切な調整量は、実際のデータベース接続負荷に基づいて決定する必要があります。 .NET プログラムの場合、調整可能な対応する接続​​プール パラメータもあります。minPoolSize パラメータは適切に変更でき、5 に調整することもできます。

この調整を行うと、基本的にデータベースの Syn Flooding 問題の大部分は解決できます。

もちろん、これらはシステムをわずかに改善できるだけのチューニング方法にすぎません。ストレス耐性を向上させます。最終的な分析は、接続圧力がどこから発生するかによって異なります。そして、データベースへの大量の接続をバースト的に確立する必要がある理由。このような緊急事態にデータベースを使用することは適切でしょうか?別の方法としては、Redis を前面のバッファとして使用することです。データベースへの突然の接続要求を避けてください。これにはアプリケーションの変換が含まれます。

要約する

上記は、MySQL データベースの Syn Flooding の問題を解決するための編集者による紹介です。皆様のお役に立てれば幸いです。ご質問がある場合は、メッセージを残していただければ、すぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。
この記事が役に立ったと思われた方は、ぜひ転載していただき、出典を明記してください。ありがとうございます!

以下もご興味があるかもしれません:
  • bitronix を使用して MySQL に接続するときの MySQLSyntaxErrorException の解決方法
  • Linux corosync+pacemaker+drbd+mysql の詳細なインストール
  • MySQL エラー: type=InnoDB ソリューションの近くで使用する正しい構文の MySQL サーバー バージョン
  • MySQL 5.7 拡張エディション セミ同期レプリケーション パフォーマンスの最適化
  • Coolcode から SyntaxHighlighter および MySQL 正規表現実装分析

<<:  Vue Element-ui フォーム検証ルールの実装

>>:  Linux の一般的な基本コマンドと使用方法

推薦する

Linux の crontab タスク スケジューリングの簡単な分析

1. スケジュールタスクを作成する命令crontab -eは現在のユーザーの編集インターフェースに入...

iframe ページパラメータの文字化けの問題について議論

非常に珍しいパラメータ文字化けの問題に遭遇しました。まずページを見てみましょう写真に示すように、月次...

【HTML要素】画像の埋め込み方法

img 要素を使用すると、HTML ドキュメントに画像を埋め込むことができます。画像を埋め込むには、...

スタイル属性 (element.style) で定義されたインライン スタイルを削除する方法

Magento を頻繁に変更する場合、element.style に遭遇することがあります。 これは...

HTMLテーブルで、各セルに異なる色と幅を設定します

設定が有効にならない場合が多いため、幅や高さなどをテーブル内で直接設定しないことをお勧めします。スタ...

MySQL シリーズ 8 MySQL サーバー変数

チュートリアルシリーズMySQL シリーズ: MySQL リレーショナル データベースの基本概念My...

流れと動的なライン効果を実現する純粋なCSSコード

アイデア:外側のボックスは背景を設定し、内側のボックスは背景の幅と高さを設定し、ボックスを動かすアニ...

js を使用してシンプルなスイッチ ライト コードを実装する

体の部位: <button>ライトのオン/オフを切り替える</button>...

詳細なLinuxインストールチュートリアル

(Win7 システム) VMware 仮想マシンのインストール チュートリアルVMware は仮想マ...

Docker が占有するディスク領域をクリーンアップする方法

Docker は多くのスペースを占有します。コンテナを実行したり、イメージを取得したり、アプリケー...

Vue-cli を使用して Vue プロジェクトを構築する手順の詳細な説明

まず、Vue-cli をインストールする必要があります。 npm インストール -g vue-cli...

CSS 水平方向の中央揃えと最大幅の制限

CSS レイアウトとスタイルに関する質問: 水平方向の中央揃えと最大幅の制限のバランスをとる方法最近...

Docker Compose のインストールと使用手順

目次1. Docker Compose とは何ですか? 2. Docker Composeのインスト...

mysql の認証、起動、およびサービスの起動のための一般的なコマンド

1. 4つの起動方法: 1.mysqld MySQL サーバーを起動します: ./mysqld --...

uniapp 要素ノードスタイルの動的変更の詳細な説明

目次1. スタイル属性をバインドして変更するhtml:対応するjs:達成された効果:次に、refを使...