前置条件:
通过K8S容器运行Nvida GPU
准备Kafka、Prometheus、ClickHouse
1 安装dcgm-exporter并通过Kafka采集(略)
此步骤可以参考:dcgm-exporter + prometheus + kafka-adapter采集GPU容器监控
2 通过ClickHouse消费Kafka数据
在CH集群中创建Kafka引擎表:(多节点的情况下,仅在一个节点创建即可)
CREATE TABLE gpu_metrics.kafka_dcgm_metrics
(
`metrics` String
)
ENGINE = Kafka
SETTINGS kafka_broker_list = '10.xx.xx.xx:xxxx,10.xx.xx.xx:xxxx,10.xx.xx.xx:xxxx', kafka_topic_list = 'gpus-info', kafka_group_name = 'gpus-info-1', kafka_format = 'JSONAsString', kafka_num_consumers = 1
查询结果如下:
3 解析并存储GPU监控数据
创建存储数据表dcgm_metrics:(单节点无需加on cluster xxx)
CREATE TABLE gpu_metrics.dcgm_metrics on cluster test_zz1
(
`dt` Date DEFAULT toDate(timestamp),