我用一个公式来计算大约。MySQL实例的最大内存消耗(简化并用PromQL编写)读取:
(
mysql_global_variables_key_buffer_size +
mysql_global_variables_query_cache_size +
mysql_global_variables_tmp_table_size +
mysql_global_variables_innodb_buffer_pool_size +
mysql_global_variables_innodb_additional_mem_pool_size +
mysql_global_variables_innodb_log_buffer_size +
(
mysql_global_variables_max_connections *
(
mysql_global_variables_sort_buffer_size +
mysql_global_variables_read_buffer_size +
mysql_global_variables_read_rnd_buffer_size +
mysql_global_variables_join_buffer_size +
mysql_global_variables_thread_stack +
mysql_global_variables_binlog_cache_size
)
)
)
不幸的是,该mysql_global_variables_innodb_additional_mem_pool_size
指标并不总是存在于每个实例中,如果将其包含在计算中,则会导致“无数据”。
有可以用来解决这个问题的功能absent(v instant-vector)
,但我不确定如何。
我希望将不存在的指标替换为常数(0
在这种情况下)。是否可以?
您能否向我提供一些关于如何处理 PromQL 计算中缺失指标的提示?