zoukankan      html  css  js  c++  java
  • Postgresql 数据库设置备份以及简单清理磁盘空间和wal日志的方法

    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 / 
    
    恢复即可,
  • 相关阅读:
    SpringMVC:JSON讲解
    SpringMVC:文件上传和下载
    字符串的使用
    python中的作用域与名称空间
    深、浅copy
    代码块与小数据池之间的关系
    关于敏感字符的筛选替换
    列表的增、删、改、查
    最简三级菜单
    python2.x与python3.x的区别
  • 原文地址:https://www.cnblogs.com/jinanxiaolaohu/p/12341103.html
Copyright © 2011-2022 走看看