1. 最近想简单的进行数据库的备份工作, 因为现在数据库主要是用的pg数据库 , 所以想到用文本的方式进行, 有清理了一下日志表的数据 这里一起记录一下.
先记录一下查看比较大的表的信息.
从网上找了下资料, 使用子查询的方式来查询表信息.
来源网页: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 / 恢复即可,