Nic*_*mas 7 database-size vertica
我有一个 Vertica 数据库。我怎么知道数据库有多大?
我需要一个粗略的答案,以便向高层管理人员报告有关我们环境的基本统计数据。
Ker*_*mit 17
有多种方法可以获取数据库的大小,每种方法都适用于略有不同的用例。需要注意的是,Vertica以不同的方式使用原始数据和压缩数据,您应该注意您需要的大小。例如,许可基于原始数据大小。
该原始尺寸进行容量规划或监控许可使用(它如果没有被压缩的数据会占用空间)是有用的。要获取整个数据库的原始数据大小,可以使用该GET_COMPLIANCE_STATUS()
函数,也可以查询系统表v_internal.license_audits
。
该GET_COMPLIANCE_STATUS()
函数检索有关最近审计的信息。审计估计数据库的原始数据大小并将信息存储在v_internal.license_audits
. 默认情况下,审计在每天 23:59 进行,可以配置或手动运行。
这是一些示例输出:
dbadmin=> SELECT GET_COMPLIANCE_STATUS();
GET_COMPLIANCE_STATUS
---------------------------------------------------------------------------------
Raw Data Size: 4.83TB +/- 0.24TB
License Size : 30.00TB
Utilization : 16%
Audit Time : 2014-05-11 23:59:49.763799+00
Compliance Status : The database is in compliance with respect to raw data size.
License End Date: 10/30/2014
Days Remaining: 171.18
Run Code Online (Sandbox Code Playgroud)
如果有权限,可以直接查询license_audits
表:
SELECT /*+ label(license_utilization)*/
audit_start_timestamp,
database_size_bytes / ( 1024^3 ) AS database_size_gb,
license_size_bytes / ( 1024^3 ) AS license_size_gb,
usage_percent
FROM v_catalog.license_audits
ORDER BY audit_start_timestamp DESC
LIMIT 30;
Run Code Online (Sandbox Code Playgroud)
此外,如果您希望在架构级别获得原始数据大小,您可以使用它(来自vertica.tips):
SELECT /*+ label(estimated_raw_size)*/
pj.anchor_table_schema,
pj.used_compressed_gb,
pj.used_compressed_gb * la.ratio AS raw_estimate_gb
FROM (SELECT ps.anchor_table_schema,
SUM(used_bytes) / ( 1024^3 ) AS used_compressed_gb
FROM v_catalog.projections p
JOIN v_monitor.projection_storage ps
ON ps.projection_id = p.projection_id
WHERE p.is_super_projection = 't'
GROUP BY ps.anchor_table_schema) pj
CROSS JOIN (SELECT (SELECT database_size_bytes
FROM v_catalog.license_audits
ORDER BY audit_start_timestamp DESC
LIMIT 1) / (SELECT SUM(used_bytes)
FROM V_MONITOR.projection_storage) AS ratio) la
ORDER BY pj.used_compressed_gb DESC;
Run Code Online (Sandbox Code Playgroud)
该压缩的大小是磁盘上的数据的实际大小。这对于估计磁盘空间使用情况很有用,因为 Vertica 建议始终至少有 40% 的空间可用。您可以从column_storage
或projection_storage
系统表中获取压缩大小。
使用projection_storage
还将返回任何空表(来自vertica.tips):
SELECT /*+ label(compressed_table_size)*/
anchor_table_schema,
anchor_table_name,
SUM(used_bytes) / ( 1024^3 ) AS used_compressed_gb
FROM v_monitor.projection_storage
GROUP BY anchor_table_schema,
anchor_table_name
ORDER BY SUM(used_bytes) DESC;
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
17315 次 |
最近记录: |