ディスクに空き容量がありません(PostgreSQL)

ディスクに空き容量がありません(PostgreSQL)

データベースに55 GBのSQLファイルを書き込もうとしています。毎回クラッシュが発生しました。ログを削除してクリーンアップ操作を実行してサーバーを実行しましたが、トランザクションは完了していません。後で書いていたすべてのテーブルを空にしましたが(バックアップがありました)、その後もSQLファイルに書き込もうとすると、一連の成功した挿入後にこのエラーが発生しました。ファイルを書き込めません。 "オフセット 106496 の pg_subtrans" /14C6": デバイスに余分なスペースがありません。

この問題を解決する方法はありますか?クリーンアップする必要があるPGSQL関連のログがありますか? pg_xlogを移動することが役に立つかもしれないことを読んだ。これを試してみるべきですか?

どんな助けでも大変感謝します。

ありがとうございます!

df -h読みやすくするために、コメント出力形式を再指定しました。

Filesystem                      Size  Used Avail Use% Mounted on
/dev/mapper/vg_zarkin-lv_root   574G  540G 4.3G  100% /
/dev/sda1                       194M  35M  150M  19%  /boot
tmpfs                           5.9G  928K 5.9G  1%   /dev/shm
/dev/mapper/smeidc0-smeisky0    7.2T  5.2T 2.0T  73%  /smeidc/sky0
/dev/md0                        7.2T  6.5T 400G  95%  /smeidc/backup

答え1

データベースに55 GBのSQLファイルを書き込もうとしています。 [...] デバイスに余分なスペースがありません。この問題を解決する方法はありますか?

いいえ。

ロードする前に、アプリケーションに十分な量のデータを提供する必要があります。

この回答が少し簡潔であることがわかっているので、以下に初心者レベルのヒントを追加してください。

私のディスクスペースはどこに行きましたか?

Postgres テーブルで使用されるディスク容量の合計は、次を含む物理モデルの結果です。

  • テーブル行を含むテーブルブロック
  • インデックスブロック(インデックス付きの場合)
  • トランザクションログ(別名WALまたはxlog、しばらくすると消えます)

テーブル行の物理サイズは、データ型とデータ圧縮の程度によって異なります。約あります。行ごとに22バイトのオーバーヘッドがあるため、約100バイトの生の圧縮データがある場合、行は約122バイトを占めます。

インデックスの物理サイズは予測が難しく、インデックスフィールドとインデックスタイプによって異なります。

一括更新中にディスク使用量を減らすには?

ディスクのオーバーヘッドを最小限に抑えるには、PostgreSQLのドキュメントの公式パフォーマンスのヒントに従ってください。

一括更新後にディスク使用量を減らすには?

以下は、PostgreSQLデータベースのサイズを縮小するのに役立ついくつかのヒントです。

  • テーブル全体を消去したい場合は、SQLを参照してください。DELETEファイルが常にクリーンアップされるわけではありません。使用TRUNCATEDELETE、テーブルの内容を完全に削除しないでください。

  • テーブルを完全に消去できず、行の大きなサブセット(50%以上)を削除する必要がある場合は、次のコマンドを実行すると便利です。VACUUM FULLまたは CLUSTERDELETE 以降のコマンドは、テーブルを縮小するために使用されます。

  • トランザクションログ(pg_xlogディレクトリ)に保持されるデータ量は、次のように制御できます。Postgresサーバーの設定

  • 未使用のデータベース、テーブル、およびインデックスは、次のコマンドを使用して検出できます。システムビュー(pg_stat_database, pg_stat_user_tables, pg_stat_user_indexes)

関連情報