查看数据库占用磁盘空间的方法
一、通过系统函数查找
通过系统函数查询数据库大小得到的结果仅为数据库、模式、表等各类逻辑数据对象占用大小,不包含WAL日志、审计日志、数据库运行日志等其他部分。
1、查看全部数据库大小之和
highgo=# select sum(pg_database_size(datname)) from pg_database; sum -------------------------- 33227060 (1 row) highgo=# highgo=# highgo=# select pg_size_pretty(sum(pg_database_size(datname))) from pg_database; pg_size_pretty --------------------------- 32 MB (1 row) highgo=# select sum(pg_database_size(datname)) /1024/1024 as "SIZE M" from pg_database; SIZE --------------------------- 31.6877937316894531 (1 row)
|
注:函数pg_database_size()得到的结果单位为字节,函数pg_size_pretty()得到的结果单位是数据库认为便于观看单位,结果不是非常准确,存在四舍五入。
2、查看某几个数据库大小之和,使用过程中将函数内的参数填写对应数据库名称即可。
highgo=# select sum(pg_database_size(pg_database.datname))/1024/1024 as "SIZE M" from pg_database where datname in('highgo','template0'); total_size ------------ 16744602 (1 row)
highgo=# select pg_size_pretty(sum(pg_database_size(pg_database.datname))) as total_size from pg_database where datname in('highgo','template0'); total_size ------------ 16 MB (1 row) highgo=# select sum(pg_database_size(pg_database.datname))/1024/1024 as "SIZE M" from pg_database where datname in('highgo','template0'); SIZE --------------------- 15.9688968658447266 (1 row)
|
3、查看单个数据库大小明细,使用过程中将函数内的参数填写为对应数据库名称即可。
highgo=# SELECT pg_database_size('highgo'); pg_database_size ------------------ 8576663
(1 row) highgo=# SELECT pg_size_pretty(pg_database_size('highgo'));
pg_size_pretty ---------------- 8376 kB (1 row) highgo=# SELECT pg_database_size('highgo')/1024/1024 as "SIZE M";
SIZE -------- 8 (1 row)
|
4、查看数据库集群内各数据库大小明细
highgo=# select datname,pg_size_pretty(pg_database_size(datname)) from pg_database; datname | pg_size_pretty -----------+---------------- highgo | 8376 kB template1 | 7977 kB template0 | 7977 kB test | 8120 kB (4 rows)
|
二、通过查看数据库对应目录大小确定磁盘使用空间
1、数据集簇占用大小,包含WAL日志、数据库运行日志等。
如果用户手动创建过表空间,此种情况下还需要统计该表空间所在目录的大小,表空间的路径可通过元命令\db查看确定。
[highgo@host1 base]$ cd $PGDATA [highgo@host1 data]$ du -sh 49M
|
注:windows环境下找到对应文件夹,鼠标右键查看大小即可。
2、数据库各类逻辑对象大小之和,不包含WAL日志、数据库运行日志等,只需查看base、global两个文件夹大小。
如果用户手动创建过表空间,此种情况下还需要统计该表空间所在目录的大小,表空间的路径可通过元命令\db查看确定。
[highgo@host1 data]$ du -sk base global 32616 base 584 global [highgo@host1 data]$ du -sm base global 32 base 1 global
|
注:windows环境下找到对应文件夹,鼠标右键查看大小即可。
3、单个数据库大小确定。首先查询数据库oid,通过oid确定数据库存放路径,查看该文件夹大小即可,默认存放路径为$PGDATA/base/oid。
如果数据库使用的是用户自建的表空间,则数据库存放路径为$PGDATA/pg_tblspc/oid
highgo=# select datname,oid from pg_database; datname | oid -----------+------- highgo | 13864 template1 | 1 template0 | 13863 test | 16444 tbltest | 16451 (5 rows)
[highgo@host1 16451]$ cd $PGDATA/base/16444 [highgo@host1 16444]$ du -sm 8 [highgo@host1 16444]$ du -sk 8140
|
注:windows环境下找到对应文件夹,鼠标右键查看大小即可。