CLUSTER_HARDWARE

集群硬件表 CLUSTER_HARDWARE 提供了集群各实例所在服务器的硬件信息。

  1. USE information_schema;
  2. DESC cluster_hardware;
  1. +-------------+--------------+------+------+---------+-------+
  2. | Field | Type | Null | Key | Default | Extra |
  3. +-------------+--------------+------+------+---------+-------+
  4. | TYPE | varchar(64) | YES | | NULL | |
  5. | INSTANCE | varchar(64) | YES | | NULL | |
  6. | DEVICE_TYPE | varchar(64) | YES | | NULL | |
  7. | DEVICE_NAME | varchar(64) | YES | | NULL | |
  8. | NAME | varchar(256) | YES | | NULL | |
  9. | VALUE | varchar(128) | YES | | NULL | |
  10. +-------------+--------------+------+------+---------+-------+
  11. 6 rows in set (0.00 sec)

字段解释:

  • TYPE:对应集群信息表 information_schema.cluster_info 中的 TYPE 字段,可取值为 tidbpdtikv
  • INSTANCE:对应于集群信息表 information_schema.cluster_info 中的 INSTANCE 字段。
  • DEVICE_TYPE:硬件类型。目前可以查询的硬件类型有 cpumemorydisknet
  • DEVICE_NAME:硬件名。对于不同的 DEVICE_TYPEDEVICE_NAME 的取值不同。
    • cpu:硬件名为 cpu。
    • memory:硬件名为 memory。
    • disk:磁盘名。
    • net:网卡名。
  • NAME:硬件不同的信息名,比如 cpu 有 cpu-logical-corescpu-physical-cores 两个信息名,表示逻辑核心数量和物理核心数量。
  • VALUE:对应硬件信息的值。例如磁盘容量和 CPU 核数。

查询集群 CPU 信息的示例如下:

  1. SELECT * FROM cluster_hardware WHERE device_type='cpu' AND device_name='cpu' AND name LIKE '%cores';
  1. +------+-----------------+-------------+-------------+--------------------+-------+
  2. | TYPE | INSTANCE | DEVICE_TYPE | DEVICE_NAME | NAME | VALUE |
  3. +------+-----------------+-------------+-------------+--------------------+-------+
  4. | tidb | 0.0.0.0:4000 | cpu | cpu | cpu-logical-cores | 16 |
  5. | tidb | 0.0.0.0:4000 | cpu | cpu | cpu-physical-cores | 8 |
  6. | pd | 127.0.0.1:2379 | cpu | cpu | cpu-logical-cores | 16 |
  7. | pd | 127.0.0.1:2379 | cpu | cpu | cpu-physical-cores | 8 |
  8. | tikv | 127.0.0.1:20165 | cpu | cpu | cpu-logical-cores | 16 |
  9. | tikv | 127.0.0.1:20165 | cpu | cpu | cpu-physical-cores | 8 |
  10. +------+-----------------+-------------+-------------+--------------------+-------+
  11. 6 rows in set (0.03 sec)