Postgresqlデータベースのバックアップを設定し、ディスク領域とwalログを簡単にクリーンアップする方法
2051 ワード
1.最近は簡単にデータベースのバックアップをしたいと思っています.現在は主にpgデータベースを使っているので、テキストで行いたいと思っています.ログ表を整理したデータがあります.ここに一緒に記録しておきます.
まず、比較的大きなテーブルを表示する情報を記録します.
ネット上で資料を探して、サブクエリの方式を使って表の情報をクエリします.
ソースWebページ:https://www.cnblogs.com/ilifeilong/p/9244370.html
最大のテーブル情報を見つけたら、使用する必要があります.
truncate tableの方式は直接空間を整理することができて、さもなくば空間はやはり占有しています.
2.整理pg_walファイル内の情報
walはwrite ahead logの意味でoracleのredoの内容と似ていて、ファイルが多い場合は整理する必要があります.
方法
3.バックアップ・リカバリの実行方法
まず、比較的大きなテーブルを表示する情報を記録します.
ネット上で資料を探して、サブクエリの方式を使って表の情報をクエリします.
ソースWebページ:https://www.cnblogs.com/ilifeilong/p/9244370.html
SELECT
table_name,
pg_size_pretty(table_size) AS table_size,
pg_size_pretty(indexes_size) AS indexes_size,
pg_size_pretty(total_size) AS total_size
FROM (
SELECT
table_name,
pg_table_size(table_name) AS table_size,
pg_indexes_size(table_name) AS indexes_size,
pg_total_relation_size(table_name) AS total_size
FROM (
SELECT ('"' || table_schema || '"."' || table_name || '"') AS table_name
FROM information_schema.tables
) AS all_tables
ORDER BY total_size DESC
) AS pretty_sizes;
最大のテーブル情報を見つけたら、使用する必要があります.
truncate tableの方式は直接空間を整理することができて、さもなくば空間はやはり占有しています.
truncate table ****
/data/base
2.整理pg_walファイル内の情報
walはwrite ahead logの意味でoracleのredoの内容と似ていて、ファイルが多い場合は整理する必要があります.
方法
su - postgres
cd /usr/lib/yourpgbinpath
./pg_resetwal {PGDATA}
3.バックアップ・リカバリの実行方法
tar -czvf /pgdata.tar.gz /pgdatapath
tar -zxvf /pgdata.tar.gz /
,