• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    postgresql 如何查看pg_wal目录下xlog文件总大小

    当然如果你登录服务器所在主机,直接在$PGDAT/pg_wal下执行:

    du -h --max-depth=1 ./ 

    可以得到。

    #du -h --max-depth=1 ./
    4.0K  ./archive_status
    193M  ./

    如果通过客户端怎么做呢?

    答案:pg_ls_waldir()函数。pg_ls_waldir()是pg 10.0引入的函数,可以输出数据库WAL目录的所有文件。

    postgres=# select sum(size) from pg_ls_waldir();   
      sum  
    -----------
     201326592
    (1 row)

    单位是byte,所以当前pg_wal的xlog日志总大小为201326592/1024/1024=192M。

    也可以使用:

    postgres=# select count(*) from pg_ls_waldir();
     count 
    -------
      12
    (1 row)

    12表示wal日志文件个数,总大小12*16=192M。

    16表示单个wal日志文件大小,单位MB,WAL 日志文件大小默认为16MB。

    bonus:

    1、怎么调整单个wal日志文件大小?

    答:使用 initdb 调整WAL文件大小。

    2、pg_ls_logdir() 也是pg10.0版本引入的函数,输出数据库日志目录的所有文件。

    postgres=# select * from pg_ls_logdir();
            name        | size  |   modification   
    ----------------------------------+---------+------------------------
     postgresql-2020-04-28_092020.log | 2277343 | 2020-04-29 11:34:56+08
     postgresql-2020-04-28_092020.csv | 140050 | 2020-04-29 11:34:56+08

    3、如何列出/data文件夹中的文件?

    答:pg_ls_dir

    postgres=# select pg_ls_dir('/data');
       pg_ls_dir    
    ----------------------

    补充:postgresql 查看wal生成频率和大小

    –wal 文件生成数量

    –linux ls --full-time stat filename

    –pg_stat_file返回一个记录,其中包含

    – 1 size 文件尺寸

    – 2 access 最后访问时间戳(linux:最近访问) 、

    – 3 modification 最后修改时间戳(linux:最近更改–) 、

    – 4 change 最后文件状态改变时间戳(只支持 Unix 平台)(linux:最近改动) 、

    – 5 creation 文件创建时间戳(只支持 Windows)

    – 6 isdir 一个boolean指示它是否为目录 isdir

    – select * from pg_stat_file('/var/lib/postgresql/9.1/main/pg_xlog/0000000200000BBB000000A9');
    – /var/lib/postgresql/9.1/main/pg_xlog
    – /var/log/postgresql
    – /mnt/nas_dbbackup/archivelog
    with tmp_file as (
      select t1.file,
          t1.file_ls,
          (pg_stat_file(t1.file)).size as size,
          (pg_stat_file(t1.file)).access as access,
          (pg_stat_file(t1.file)).modification as last_update_time,
          (pg_stat_file(t1.file)).change as change,
          (pg_stat_file(t1.file)).creation as creation,
          (pg_stat_file(t1.file)).isdir as isdir
       from (select dir||'/'||pg_ls_dir(t0.dir) as file,
              pg_ls_dir(t0.dir) as file_ls
           from ( select '/var/lib/postgresql/9.1/main/pg_xlog'::text as dir
               --需要修改这个物理路径
               --select '/mnt/nas_dbbackup/archivelog'::text as dir
               --select setting as dir from pg_settings where name='log_directory'
              ) t0
          ) t1 
       where 1=1
       order by (pg_stat_file(file)).modification desc
    ) 
    select to_char(date_trunc('day',tf0.last_update_time),'yyyymmdd') as day_id,
        sum(case when date_part('hour',tf0.last_update_time) >=0 and date_part('hour',tf0.last_update_time) 24 then 1 else 0 end) as wal_num_all,
        sum(case when date_part('hour',tf0.last_update_time) >=0 and date_part('hour',tf0.last_update_time) 1 then 1 else 0 end) as wal_num_00_01,
        sum(case when date_part('hour',tf0.last_update_time) >=1 and date_part('hour',tf0.last_update_time) 2 then 1 else 0 end) as wal_num_01_02,
        sum(case when date_part('hour',tf0.last_update_time) >=2 and date_part('hour',tf0.last_update_time) 3 then 1 else 0 end) as wal_num_02_03,
        sum(case when date_part('hour',tf0.last_update_time) >=3 and date_part('hour',tf0.last_update_time) 4 then 1 else 0 end) as wal_num_03_04,
        sum(case when date_part('hour',tf0.last_update_time) >=4 and date_part('hour',tf0.last_update_time) 5 then 1 else 0 end) as wal_num_04_05,
        sum(case when date_part('hour',tf0.last_update_time) >=5 and date_part('hour',tf0.last_update_time) 6 then 1 else 0 end) as wal_num_05_06,
        sum(case when date_part('hour',tf0.last_update_time) >=6 and date_part('hour',tf0.last_update_time) 7 then 1 else 0 end) as wal_num_06_07,
        sum(case when date_part('hour',tf0.last_update_time) >=7 and date_part('hour',tf0.last_update_time) 8 then 1 else 0 end) as wal_num_07_08,
        sum(case when date_part('hour',tf0.last_update_time) >=8 and date_part('hour',tf0.last_update_time) 9 then 1 else 0 end) as wal_num_08_09,
        sum(case when date_part('hour',tf0.last_update_time) >=9 and date_part('hour',tf0.last_update_time) 10 then 1 else 0 end) as wal_num_09_10,
        sum(case when date_part('hour',tf0.last_update_time) >=10 and date_part('hour',tf0.last_update_time) 11 then 1 else 0 end) as wal_num_10_11,
        sum(case when date_part('hour',tf0.last_update_time) >=11 and date_part('hour',tf0.last_update_time) 12 then 1 else 0 end) as wal_num_11_12,
        sum(case when date_part('hour',tf0.last_update_time) >=12 and date_part('hour',tf0.last_update_time) 13 then 1 else 0 end) as wal_num_12_13,
        sum(case when date_part('hour',tf0.last_update_time) >=13 and date_part('hour',tf0.last_update_time) 14 then 1 else 0 end) as wal_num_13_14,
        sum(case when date_part('hour',tf0.last_update_time) >=14 and date_part('hour',tf0.last_update_time) 15 then 1 else 0 end) as wal_num_14_15,
        sum(case when date_part('hour',tf0.last_update_time) >=15 and date_part('hour',tf0.last_update_time) 16 then 1 else 0 end) as wal_num_15_16,
        sum(case when date_part('hour',tf0.last_update_time) >=16 and date_part('hour',tf0.last_update_time) 17 then 1 else 0 end) as wal_num_16_17,
        sum(case when date_part('hour',tf0.last_update_time) >=17 and date_part('hour',tf0.last_update_time) 18 then 1 else 0 end) as wal_num_17_18,
        sum(case when date_part('hour',tf0.last_update_time) >=18 and date_part('hour',tf0.last_update_time) 19 then 1 else 0 end) as wal_num_18_19,
        sum(case when date_part('hour',tf0.last_update_time) >=19 and date_part('hour',tf0.last_update_time) 20 then 1 else 0 end) as wal_num_19_20,
        sum(case when date_part('hour',tf0.last_update_time) >=20 and date_part('hour',tf0.last_update_time) 21 then 1 else 0 end) as wal_num_20_21,
        sum(case when date_part('hour',tf0.last_update_time) >=21 and date_part('hour',tf0.last_update_time) 22 then 1 else 0 end) as wal_num_21_22,
        sum(case when date_part('hour',tf0.last_update_time) >=22 and date_part('hour',tf0.last_update_time) 23 then 1 else 0 end) as wal_num_22_23, 
        sum(case when date_part('hour',tf0.last_update_time) >=23 and date_part('hour',tf0.last_update_time) 24 then 1 else 0 end) as wal_num_23_24
    from tmp_file tf0
    where 1=1
     and tf0.file_ls not in ('archive_status')
    group by to_char(date_trunc('day',tf0.last_update_time),'yyyymmdd')
    order by to_char(date_trunc('day',tf0.last_update_time),'yyyymmdd') desc
    ; 

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • postgresql 利用xlog进行热备操作
    • Postgresql中xlog生成和清理逻辑操作
    • Postgresql去重函数distinct的用法说明
    • postgresql 12版本搭建及主备部署操作
    • 开源数据库postgreSQL13在麒麟v10sp1源码安装过程详解
    • postgresql初始化之initdb的使用详解
    • postgresql之使用lsn 获取 wal文件名的实例
    • PostgreSQL 实现定时job执行(pgAgent)
    上一篇:postgresql之使用lsn 获取 wal文件名的实例
    下一篇:postgresql初始化之initdb的使用详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    postgresql 如何查看pg_wal目录下xlog文件总大小 postgresql,如何,查看,wal,目,