MySQL でストリーミングクエリを使用してデータ OOM を回避する

MySQL でストリーミングクエリを使用してデータ OOM を回避する

1. はじめに

プログラムがMySQLデータベースにアクセスするときに、クエリされるデータの量が特に大きい場合、データベース ドライバーは読み込まれたすべてのデータをメモリにロードし、メモリ オーバーフロー (OOM) が発生する可能性があります。

実際、 MySQLデータベースはストリーミング クエリを提供しており、これにより、修飾されたデータをバッチでメモリにロードできるため、OOM を効果的に回避できます。この記事では、主にストリーミング クエリの使用方法を紹介し、パフォーマンス テストで通常のクエリと比較します。

2. JDBCはストリーミングクエリを実装する

ストリーミング クエリは、JDBC のPreparedStatement/StatementsetFetchSizeメソッドをInteger.MIN_VALUEに設定するか、 Statement.enableStreamingResults()メソッドを使用することで実装できます。ResultSet.next ResultSet.next()メソッドが実行されると、データベース接続を通じて 1 つずつ返されるため、大量のクライアント メモリを占有することはありません。

パブリック int execute(String sql, boolean isStreamQuery) は SQLException をスローします {
 接続 conn = null;
 PreparedStatement stmt = null;
 結果セット rs = null;
 整数カウント = 0;
 試す {
  //データベース接続を取得します。conn = getConnection();
  if (isStreamQuery) {
   //ストリーミング クエリ パラメータを設定します。stmt = conn.prepareStatement(sql, ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
   stmt.setFetchSize(Integer.MIN_VALUE);
  } それ以外 {
   //通常のクエリ stmt = conn.prepareStatement(sql);
  }

  //クエリを実行して結果を取得します。rs = stmt.executeQuery();
  // 結果を走査します while (rs.next ()) {
   System.out.println(rs.getString(1));
   カウント++;
  }
 } キャッチ (SQLException e) {
  e.printStackTrace();
 ついに
  閉じる(stmt、rs、conn);
 }
 カウントを返します。
}

「PS」: 上記の例では、パラメーターisStreamQuery使用して、次のテスト比較で「ストリーミング クエリ」「通常のクエリ」を切り替えます。

3. パフォーマンステスト

テスト用にテストテーブルmy_testが作成されます。データの総量は27wです。テストには次の 4 つのテストケースが使用されます。

  • 大容量データ一般クエリ(270,000件)
  • 大容量データストリーミングクエリ(270,000レコード)
  • 小容量データ一般クエリ(10件)
  • 小容量データストリーミングクエリ(10項目)

3.1. 大容量データの一般クエリをテストする

@テスト
パブリック void testCommonBigData() は SQLException をスローします {
 文字列 sql = "select * from my_test";
 テスト実行(sql, false);
}

3.1.1. クエリ時間

27wのデータ量は38秒かかります

3.1.2. メモリ使用量

約1Gのメモリを使用

3.2. 大容量データストリーミングクエリのテスト

@テスト
パブリック void testStreamBigData() は SQLException をスローします {
 文字列 sql = "select * from my_test";
 テストを実行します(sql, true);
}

3.2.1. クエリ時間

27wのデータ量は37秒かかります

3.2.2. メモリ使用量

バッチで取得されるため、メモリは30〜270mの間で変動します。

3.3. 少量データに対する通常のクエリのテスト

@テスト
パブリック void testCommonSmallData() は SQLException をスローします {
 文字列 sql = "select * from my_test limit 100000, 10";
 テスト実行(sql, false);
}

3.3.1. クエリ時間

10個のデータには1秒かかります

3.4. 少量のデータでストリーミングクエリをテストする

@テスト
パブリック void testStreamSmallData() は SQLException をスローします {
 文字列 sql = "select * from my_test limit 100000, 10";
 テストを実行します(sql, true);
}

3.4.1. クエリ時間

10個のデータには1秒かかります

IV. 結論

MySQL ストリーミング クエリはメモリ使用量に明らかな最適化効果をもたらしますが、クエリ速度にはほとんど影響しません。主に、大量のデータをクエリするときにメモリ使用量が高くなるシナリオを解決するために使用されます。

「デモアドレス」: https://github.com/zlt2000/mysql-stream-query

これで、MySQL でストリーミング クエリを使用してデータ OOM を回避する方法に関するこの記事は終了です。MySQL ストリーミング クエリに関するより関連性の高いコンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL OOM (メモリオーバーフロー) の解決策
  • MySQL スレーブが oom-killer をトリガーする問題の解決方法
  • MySQL OOM シリーズ 3: MySQL が殺されるという不運から逃れる
  • MySQL OOM システム 2 OOM キラー
  • MySQL OOM シリーズ 1 Linux メモリ割り当て

<<:  Docker環境を構築する簡単な方法

>>:  ログインボックスのメールプロンプトを実装するネイティブJS

推薦する

CSSのoutline-offsetプロパティを使用してプラス記号を実装する

次のような初期コードがあると仮定します。 <!DOCTYPE html> <htm...

Nginx 構成 SSL および WSS 手順の紹介

目次序文1. Nginxのインストール1. Nginxをダウンロードする2. 依存関係をインストール...

SQL文の最適化の一般的な手順の詳細な説明

序文この記事では主に、SQL ステートメントの最適化の一般的な手順について説明します。これは、参考と...

簡潔なReactコンポーネントを書くためのヒント

目次スプレッド演算子を使用してプロパティを渡すのは避けてください関数パラメータをオブジェクトにカプセ...

Linux で大きなファイルの指定された内容を見つける方法

大きなことも小さなことも考えて、方向転換しましょう。 Linux では非常に大きなファイルに遭遇する...

MYSQL row_number() および over() 関数の詳細な使用方法

構文フォーマット: row_number() over(partition by grouping ...

MySQL max_allowed_pa​​cket 設定

max_allowed_pa​​cket は、受け入れるパケットのサイズを設定するために使用される ...

CentOS8 デプロイメント LNMP 環境で mysql8.0.29 をコンパイルしてインストールする方法の詳細なチュートリアル

1. 前提条件何度かインストールしているので、エラーについてはこれ以上説明しません。ちょっとわかりに...

Vueシャトルボックスは上下の動きを実現します

この記事の例では、vueシャトルボックスを上下に動かすための具体的なコードを参考までに共有しています...

Linux 環境に nginx をインストールするチュートリアル

目次1. 必要な環境をインストールする //gccをインストールする yum で gcc-c++ を...

カルーセル例の JS 実装

この記事では、カルーセルチャートの小さなケースを実装するためのJSの具体的なコードを参考までに共有し...

Centos7 に mysql 8.0.13 (rpm) をインストールする詳細なチュートリアル

yum か rpm か? yum によるインストール方法は非常に便利ですが、公式サイトから MySQ...

MySQLでよく使われる4つのストレージエンジンについて簡単に説明します。

よく使われる4つのMySQLエンジンの紹介(1):MyISAMストレージエンジン:トランザクションや...

Dockerコンテナのネットワーク管理とネットワーク分離の実装

1. Dockerネットワーク管理1. Dockerコンテナ方式1) Dockerが外部ネットワーク...

MySQL PHP 構文の簡単な分析

まずcharAt関数の基本的な構文を見てみましょう文字 = str.charAt(インデックス) c...