
PostgreSQLのパフォーマンスについて質問です。
INSERTを大量に行う処理の速度が遅いので、高速化をはかるため、INSERTを20個ずつまとめる修正を行いました。
基本的に速度は速くなったのですが、あるデータだけ逆に遅くなってしまいました。
その遅くなったデータはレコード数が膨大なのですが、まとめてINSERTをおこなうSQLを連続で発行したら、処理速度が遅くなることはあるのでしょうか?
なお、INSERTは下記のように行っています。
INSERT INTO テーブル名 (列名群) VALUES (挿入データ群),(挿入データ群),・・・,(挿入データ群);
また、すべてのテーブルにインデックスはついておらず、プライマリキーと外部キーが設定されています。
マシンスペックはCore2 Duo 2.53GHz、メモリ2GB、OSはWindows XPです。
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
物理メモリーは何メガバイト積んでいるのでしょうか.1GB未満は問題がありますね。
postgres.confの設定はどうなっていますか?
#ディスクアクセスの高速化設定
fsync = off
wal_sync_method = open_sync
の設定はしていますか.
#物理メモリー使用量の設定
shared_buffers = 2048
sort_mem = 1345
vacuum_mem = 8192
※上記のサイズは、128KByte単位です。
この設定だと、Postgresの物理シェアードメモリーバッファサイズが256MBになります。
でも、8万行程度のインサートは10秒ぐらいで終わると思います。
Postgresは、メモリーをいっぱい積んで、設定を正しく行えば、高速に動作しますよ.
但し、Ver 8.3以降ですが。
YkazubonYさん回答ありがとうございます。
PostgreSQL8.3を使用しており、物理メモリは2GB積んでいます。(実運用環境のサーバは4GBです)
postgres.confの設定はshared_buffersを800MB、work_memを32MB、checkpoint_segmentsを64に変更しています。
checkpoint_segmentsはネットで最高で64と書いてあったので64に設定したのですが、ログファイルにもっと増すようにと注意が書かれるのですが、弊害がおこりそうで怖くて増やせません。
ディスクアクセスの高速化設定早速明日試してみたいと思います。
sort_mem、vacuum_memも増やしてみたいと思うのですが、今のshared_buffers=800MBという設定は大きすぎでしょうか?
ちなみに実運用環境では最大150コネクションになることがあります。
よろしくお願いします。
No.1
- 回答日時:
まず、PostgreSQLのバージョンは何ですか?
例えば、PostgreSQL 8.3と8.4でも、大きな機能追加などかなり違ったりします。
>あるデータだけ逆に遅くなってしまいました。
>その遅くなったデータはレコード数が膨大
もっと具体的に提示するようにしてください。
再現性、つまり一旦、表の削除、再定義してそのinsertを実行すると、同じような結果になりますか?
SQLをどこからどういう方法で投げているのか不明ですが、通信とかどこがボトルネックになっているのか絞り込まないと。
chukenkenkouさん回答ありがとうございます。
説明不足で申し訳ありません。
PostgreSQLのバージョンは8.3です。
また、表の再定義を行ったあとも同じ結果になりました。
なお、SQLはC++で作成したプログラムから発行しています。
表は全部で24個あり、修正前はそのうち3個の表のINSERTを20個ずつまとめてINSERTしていたのですが、修正後はほとんどのテーブルで20個ずつまとめてINSERTするようにしました。
PostgreSQLのconfの設定でSQLのログを出すようにして検証を行ったところ、INSERTを1件ずつ行った場合は1秒間に約400個のINSERTが行えており、修正前にINSERTを20件ずつ行った場合は1秒間に約200個のINSERTが行えていました。
修正後ははじめは修正前と同様に1秒間に約200個のINSERTが行えていたのですが、徐々に数が減り、最終的には1秒間に25個のINSERTしか行えていませんでした。
また、ローカルのマシンにPostgreSQLを入れて行ったテストでは修正後は修正前の約3倍の速度になりました。スペックの高いサーバにPostgreSQLを入れてネットワーク越しに行ったテストでは約1.3倍の速度になりました。
ちなみに修正前は約30000件、修正後は約5000件のSQLを発行しています。
何か思い当たる点がありましたらよろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- ドライブ・ストレージ USBメモリの転送速度が異常に遅い... 5 2022/05/03 17:49
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- PHP プログラムコードを入力する場合改行してもいいですか? 2 2022/10/02 16:05
- その他(IT・Webサービス) 高速処理可能な表計算ソフトについて ExcelやGoogleスプレッドシートのような表計算ソフトで、 2 2023/04/29 16:06
- MySQL 次の時間帯の勝率の合計を求めるSQL文 1 2023/07/04 17:12
- SQL Server AccessのInsertクエリのあとつづけてDeleteクエリを行いたいがSQLでどう書いたらいい 3 2023/05/27 14:12
- MySQL mysqlで INSERT と SELECTの用途は 1 2022/04/01 00:45
- MySQL 下の画像はSQLの4大命令の性質をまとめたものであるらしいです UPDATE INSERT DELE 1 2023/06/07 15:36
- その他(プログラミング・Web制作) プログラミング 処理速度 1 2022/11/25 11:05
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Accessでデータシートに同じデ...
-
このISAMでは、リンクテーブル・・
-
マテリアライズドビューとスナ...
-
Accessでの稼働日数計算の方法
-
アクセス レコードセットを更...
-
テーブルで一番古いレコードだ...
-
Access昇順レコードを、5分割...
-
VBAでSQLServerへのODBC接続
-
1つのSQL文で文字列を置換する...
-
ビューのソートについて
-
テーブル作成時の行数の設定
-
SQLでの前検索・後検索
-
PostgreSQLでテーブル構成を変える
-
Access VBAからエクセルに出力...
-
MySQLの容量の削減の仕方
-
テーブルの設計はとりあえず文...
-
住所のDBテーブル、マスターの...
-
Excel→Access→Oracleでインポー...
-
MYSQLでコード番号を自動でつけ...
-
access 特定のレコード数までエ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Accessでデータシートに同じデ...
-
Oracleで上書きImportはできま...
-
ビューのソートについて
-
Accessのテーブルデータを一気...
-
テーブルで一番古いレコードだ...
-
アクセス レコードセットを更...
-
マテリアライズドビューとスナ...
-
ORA-01401が表示され、データが...
-
このISAMでは、リンクテーブル・・
-
accessでレコード更新直後の反...
-
結合テーブルでINSERTする方法...
-
ERROR1062:Duplicate entry.......
-
IF NOT EXISTを使用するINSERT文
-
削除したテーブルを元に戻すこ...
-
「クリップボードにコピーされ...
-
left joinなどで結合対象のレコ...
-
ACCESS2010の最適化が中断される
-
ODBC接続で新しいレコードを追...
-
構文エラー : 演算子がありませ...
-
処理の途中で停止させ、再開さ...
おすすめ情報