ProxmoxVE(PVE) 7.1-x 在主界面添加CPU频率/CPU温度/硬盘温度

【折腾须知】

#本教程目前仅在PVE7.1-X的版本下运行正常,在PVE7.2-X版本下和其他的版本不一定能用;

#修改文件之前,最好先备份文件,万一有问题还有机会还原。

1.登录PVE的SSH,执行命令安装sensors:

apt-get install lm-sensors

2.探测下温度,执行:(一路yes,回车)

sensors-detect

3.获取温度信息,执行:sensors

jpg

  • ACPI interface那里是主板温度:temp1和temp2 (有些主板不一样,建议不管主板温度)

  • ISA adapter那里是CPU温度:Core0和Core1 (几个核心就是显示几个,演示机只有双核,所以只有2个)

a) 如果是全新安装,需要安装工具并重启 pveproxy 服务:

apt-get install lm-sensors && apt-get install nvme-cli && apt-get install hddtemp && chmod +s /usr/sbin/nvme && chmod +s /usr/sbin/hddtemp && chmod +s /usr/sbin/smartctl && systemctl restart pveproxy

b) 如果是更新脚本,只需要重启 pveproxy 服务:

systemctl restart pveproxy

4.WinSCP登录到PVE,修改这个文件:/usr/share/perl5/PVE/API2/Nodes.pm

(我习惯于下载到本地用Notepad++修改)

搜索:

$res->{pveversion} = PVE::pvecfg::package()

在这个定义的下方添加:

$res->{thermalstate} = `sensors`;

结果如图:

jpg

修改完保存,然后塞回路径。

5.修改这个文件:/usr/share/pve-manager/js/pvemanagerlib.js (建议备份,万一自己改炸就不好了。)

搜索PVE Manager Version

jpg

  • 在这个定义的下方添加一个定义:
	{
          itemId: 'thermal',
          colspan: 2,
          printBar: false,
          title: gettext('CPU温度'),
          textField: 'thermalstate',
          renderer:function(value){
              const p0 = value.match(/Package id 0.*?\+([\d\.]+)Â/)[1];
              const c0 = value.match(/Core 0.*?\+([\d\.]+)Â/)[1];
              const c1 = value.match(/Core 1.*?\+([\d\.]+)Â/)[1];
              const b0 = value.match(/temp1.*?\+([\d\.]+)?/)[1];
              const b1 = value.match(/temp2.*?\+([\d\.]+)?/)[1];
              return `Package: ${p0} ℃ || 核心1: ${c0} ℃ | 核心2: ${c1} ℃ || 主板: ${b0} ℃ | ${b1} ℃ `
            }
    },

结果如图: jpg

因为我是双核心,所以只写了2个核心的温度参数。

  • 如果不要加入主板温度,就是这样:
	{
          itemId: 'thermal',
          colspan: 2,
          printBar: false,
          title: gettext('CPU温度'),
          textField: 'thermalstate',
          renderer:function(value){
              const p0 = value.match(/Package id 0.*?\+([\d\.]+)Â/)[1];
              const c0 = value.match(/Core 0.*?\+([\d\.]+)Â/)[1];
              const c1 = value.match(/Core 1.*?\+([\d\.]+)Â/)[1];
              return `Package: ${p0} ℃ || 核心1: ${c0} ℃ | 核心2: ${c1} ℃ `
            }
    },
  • 如果是四核心的就是这样:
	{
          itemId: 'thermal',
          colspan: 2,
          printBar: false,
          title: gettext('CPU温度'),
          textField: 'thermalstate',
          renderer:function(value){
              const p0 = value.match(/Package id 0.*?\+([\d\.]+)Â/)[1];
              const c0 = value.match(/Core 0.*?\+([\d\.]+)Â/)[1];
              const c1 = value.match(/Core 1.*?\+([\d\.]+)Â/)[1];
              const c2 = value.match(/Core 2.*?\+([\d\.]+)Â/)[1];
              const c3 = value.match(/Core 3.*?\+([\d\.]+)Â/)[1];
              const b0 = value.match(/temp1.*?\+([\d\.]+)?/)[1];
              const b1 = value.match(/temp2.*?\+([\d\.]+)?/)[1];
              return `Package: ${p0} ℃ || 核心1: ${c0} ℃ | 核心2: ${c1} ℃ | 核心3: ${c2} ℃ | 核心4: ${c3} ℃ || 主板: ${b0} ℃ | ${b1} ℃ `
            }
    },	  
  • 如果是四核心不要加入主板温度就是这样:
	{
          itemId: 'thermal',
          colspan: 2,
          printBar: false,
          title: gettext('CPU温度'),
          textField: 'thermalstate',
          renderer:function(value){
              const p0 = value.match(/Package id 0.*?\+([\d\.]+)Â/)[1];
              const c0 = value.match(/Core 0.*?\+([\d\.]+)Â/)[1];
              const c1 = value.match(/Core 1.*?\+([\d\.]+)Â/)[1];
              const c2 = value.match(/Core 2.*?\+([\d\.]+)Â/)[1];
              const c3 = value.match(/Core 3.*?\+([\d\.]+)Â/)[1];
              return `Package: ${p0} ℃ || 核心1: ${c0} ℃ | 核心2: ${c1} ℃ | 核心3: ${c2} ℃ | 核心4: ${c3} ℃ `
            }
    },	  
  • 所以自己设备几个核心,按需修改。修改完保存,然后塞回路径。

6.改完重启进PVE主页,就看到温度显示了。

jpg

  • 扩展下,主界面添加CPU频率,显示在温度下面:

  • 也是修改 /usr/share/perl5/PVE/API2/Nodes.pm 和 /usr/share/pve-manager/js/pvemanagerlib.js 这2个文件

  • /usr/share/perl5/PVE/API2/Nodes.pm 刚刚修改温度的下一行添加:

$res->{cpusensors} = `lscpu | grep MHz`;

jpg

  • /usr/share/pve-manager/js/pvemanagerlib.js 刚刚修改温度的下一行添加:
	{
          itemId: 'MHz',
          colspan: 2,
          printBar: false,
          title: gettext('CPU频率'),
          textField: 'cpusensors',
          renderer:function(value){
			  const f0 = value.match(/CPU MHz.*?([\d]+)/)[1];
			  const f1 = value.match(/CPU min MHz.*?([\d]+)/)[1];
			  const f2 = value.match(/CPU max MHz.*?([\d]+)/)[1];
			  return `CPU实时: ${f0} MHz | 最小: ${f1} MHz | 最大: ${f2} MHz `
            }
	},

jpg

  • 效果就是在主界面显示温度的下一行显示频率:

jpg

添加m2硬盘温度

usr/share/perl5/PVE/API2/Nodes.pm 刚刚修改温度的下一行添加:

$res->{nvme_ssd_temperatures} = `smartctl -a /dev/nvme?|grep -E "Model Number|Total NVM Capacity|Temperature:|Percentage|Data Unit|Power On Hours"`;

  • /usr/share/pve-manager/js/pvemanagerlib.js 刚刚修改温度的下一行添加:
{
itemId: 'nvme_ssd-temperatures',
colspan: 2,
printBar: false,
title: gettext('NVME硬盘'),
textField: 'nvme_ssd_temperatures',
renderer:function(value){
if (value.length > 0) {
let nvmedevices = value.matchAll(/^Model.*:\s*([\s\S]*?)(\n^Total.*\[[\s\S]*?\]$|\s{0}$)\n^Temperature:\s*([\d]+)\s*Celsius\n^Percentage.*([\d]+\%)\n^Data Units.*\[([\s\S]*?)\]\n^Data Units.*\[([\s\S]*?)\]\n^Power.*:\s*([\s\S]*?)\n/gm);
for (const nvmedevice of nvmedevices) {
for (var i=5; i<8; i++) {
nvmedevice[i] = nvmedevice[i].replace(/ |,/gm, '');
}
if (nvmedevice[2].length > 0) {
let nvmecapacity = nvmedevice[2].match(/.*\[([\s\S]*?)\]/);
nvmecapacity = nvmecapacity[1].replace(/ /, '');
value = `${nvmedevice[1]} | 已使用寿命: ${nvmedevice[4]} (累计读取: ${nvmedevice[5]}, 累计写入: ${nvmedevice[6]}) | 容量: ${nvmecapacity} | 已通电: ${nvmedevice[7]}小时 | 温度: ${nvmedevice[3]}°C\n`;
} else {
value = `${nvmedevice[1]} | 已使用寿命: ${nvmedevice[4]} (累计读取: ${nvmedevice[5]}, 累计写入: ${nvmedevice[6]}) | 已通电: ${nvmedevice[7]}小时 | 温度: ${nvmedevice[3]}°C\n`;
}
}
return value.replace(/\n/g, '<br>');
} else { 
return `提示: 未安装硬盘或已直通硬盘控制器`;
}
}
},

添加sata硬盘温度

usr/share/perl5/PVE/API2/Nodes.pm 刚刚修改温度的下一行添加:

$res->{hdd_temperatures} = `smartctl -a /dev/sd?|grep -E "Model|Capacity|Power_On_Hours|Temperature"`;

/usr/share/pve-manager/js/pvemanagerlib.js 刚刚修改温度的下一行添加:

{
itemId: 'hdd-temperatures',
colspan: 2,
printBar: false,
title: gettext('SATA硬盘'),
textField: 'hdd_temperatures',
renderer:function(value){
if (value.length > 0) {
let devices = value.matchAll(/(\s*Model.*:\s*[\s\S]*?\n){1,2}^User.*\[([\s\S]*?)\]\n^\s*9[\s\S]*?\-\s*([\d]+)[\s\S]*?(\n(^19[0,4][\s\S]*?$){1,2}|\s{0}$)/gm);
for (const device of devices) {
if(device[1].indexOf("Family") !== -1){
devicemodel = device[1].replace(/.*Model Family:\s*([\s\S]*?)\n^Device Model:\s*([\s\S]*?)\n/m, '$1 - $2');
} else {
devicemodel = device[1].replace(/.*Model:\s*([\s\S]*?)\n/m, '$1');
}
device[2] = device[2].replace(/ |,/gm, '');
if(value.indexOf("Min/Max") !== -1){
let devicetemps = device[5].matchAll(/19[0,4][\s\S]*?\-\s*(\d+)(\s\(Min\/Max\s(\d+)\/(\d+)\)$|\s{0}$)/gm);
for (const devicetemp of devicetemps) {
value = `${devicemodel} | 容量: ${device[2]} | 已通电: ${device[3]}小时 | 温度: ${devicetemp[1]}°C\n`;
}
} else if (value.indexOf("Temperature") !== -1){
let devicetemps = device[5].matchAll(/19[0,4][\s\S]*?\-\s*(\d+)/gm);
for (const devicetemp of devicetemps) {
value = `${devicemodel} | 容量: ${device[2]} | 已通电: ${device[3]}小时 | 温度: ${devicetemp[1]}°C\n`;
}
} else {
value = `${devicemodel} | 容量: ${device[2]} | 已通电: ${device[3]}小时 | 提示: 未检测到温度传感器\n`;
}
}
return value.replace(/\n/g, '<br>');
} else { 
return `提示: 未安装硬盘或已直通硬盘控制器`;
}
}
}

7.如果更新到PVE 7.1-5或者更新,发现改了温度+频率都不显示,前面的步骤又没错,那么就需要改布局:

还是这个文件:pvemanagerlib.js,搜索:

gettext('Status') + ': ' + zpool

7.1-10 往上可能可能没有这个参数 直接修改下面的参数就行了

jpg

将 height: 600 改大为700,然后保存。


搜索widget.pveNodeStatus

Ext.define('PVE.node.StatusView', {
extend: 'PVE.panel.StatusView',
alias: 'widget.pveNodeStatus',

height: 500, // 原始值为 300
bodyPadding: '20 15 20 15',

layout: {

两处 height 的值需按情况修改,每多一行数据增加 20,我这边增加一行显示CPU温度,4行显示硬盘温度,所以增加了100。

 


原文地址:http://songw.top/archives/748.html

点赞
  1. 白雪紫薯说道:
    Google Chrome Windows 10
    大佬,旁边显示的“未启用Proxmox VE存储库“有办法去除吗? :lei: 在这个文件里没找到,切成英文搜关键词也没有
    1. 博主说道:
      Google Chrome Windows 10
      不太清楚哦,自从转ESXI以后,PVE我研究不多了。建议你去PVE官方论坛发贴咨询。
  2. jedi1112说道:
    Google Chrome Windows 10
    大佬你好, 按照教程操作,其他都能正常显示,就是 NVME硬盘 一直提示: 未安装硬盘或已直通硬盘控制器,版本是7.2 这台机器有插上两块nvme,有办法解决吗?
    1. 博主说道:
      Google Chrome Windows 10
      PVE7.2用的脚本和PVE7.1用的不一样哦,所以不能完全照搬。
      1. jedi1112说道:
        Google Chrome Windows 10
        $res->{nvme_ssd_temperatures} = `smartctl -a /dev/nvme?|grep -E "Model Number|Total NVM Capacity|Temperature:|Percentage|Data Unit|Power On Hours"`; 折腾了一晚上,发现/dev/nvme? 其中打问号改成0或1就显示了,因为我的机器是两条nvme,所以就添加两次nvme监控,分别给予nvme0和nvme1,就显示出来了。我不太清楚这个命名格式,大佬有办法统一到一段里吗?
  3. mr陈说道:
    Google Chrome Android 10
    博主按你的要求改了,显示温度就一直转圈没其他的了,想问问改好后需要重启pve么
    1. 博主说道:
      Google Chrome Windows 10
      首先PVE各版本不通用,这个教程是PVE7.1下面用的,修改完成后把PVE重启一次。
      1. mr陈说道:
        Google Chrome Android 10
        7.1.7版本按教程没任何错误
  4. HelloMe说道:
    Firefox Mac OS X 10.15
    smartctl -a /dev/sd? ERROR: smartctl takes ONE device name as the final command-line argument. 报错,多个SATA硬盘,hddtemp /dev/sd?反而正常。 不知道为啥
    1. 博主说道:
      Google Chrome Windows 10
      我也不知道
  5. xiaopp说道:
    Google Chrome Windows 10
    如果你是PVE6-7 工具箱 安装请执行 rm /etc/apt/sources.list.d/pve-enterprise.list export LC_ALL=en_US.UTF-8 apt update && apt -y install git && git clone https://github.com/ivanhao/pvetools.git cd pvetools./pvetools ------------------------------------------------------------------------- 运行 ./pvetools/pvetools.sh 里面有很多工具。欢迎交流学习。
    1. 博主说道:
      Google Chrome Windows 10
      不错
  6. 天天忽悠说道:
    Google Chrome Windows 10
    唉。。早点看到博主的文章就好了,自己之前网上看的教程,都不全,我弄了好久才成功。后来发现是少了chmod +s /usr/sbin/hddtemp 因为运行web服务的进程没权限导致hddtemp的命令跑不起来。 :kuanghan:
  7. 上帝的左翼说道:
    Google Chrome Windows 10
    大佬,按照教程添加了CPU 主板 频率 NVME。中文汉字,温度单位符号,全部显示“?”,请教如何破?谢谢! CPU�¶� Package: 56.0 �� || ����1: 56.0 �� | ����2: 46.0 �� | ����3: 44.0 �� | ����4: 44.0 �� | ����5: 47.0 �� | ����6: 44.0 �� || ����: 27.8 �� CPUƵ�� CPUʵʱ: 2900 MHz | ��С: 800 MHz | ���: 4300 MHz NVMEӲ�� Samsung SSD 970 EVO Plus 250GB | ��ʹ������: 1% (�ۼƶ�ȡ: 5.83TB, �ۼ�д��: 4.98TB) | ����: 250GB | ��ͨ��: 582Сʱ | �¶�: 53��C
    1. 博主说道:
      Google Chrome Windows 10
      你文件的编码乱了
      1. 上帝的左翼说道:
        Google Chrome Windows 10
        对啊,大佬。完全按照教程弄得。温度显示都正常。关键咋解决编码乱的问题呢?
      2. 上帝的左翼说道:
        Google Chrome Windows 10
        搞定了,应该是复制出来用Notepad++修改(在winscp中直接修改)都出问题了。在后台用nano命令修改成功了!
  8. 不哭死神说道:
    WebView Android 10
    请教大佬,按照教程设置后,m.2硬盘和sata硬盘,都提示 未安装硬盘或者已经直通硬盘控制器。 我的两个m.2硬盘和3个sata盘都没有直通,都能在pve磁盘界面查看smart信息,也能通过smartctl命令输出相应的结果。
    1. 博主说道:
      Google Chrome Windows 10
      估计是你哪个步骤没做对吧
      1. 不哭死神说道:
        QQbrowser Android 10
        反复尝试过多次了。cpu温度,频率,风扇转速等都实现了。sata硬盘也用hddtmp实现了。
        1. 上帝的左翼说道:
          Google Chrome Windows 10
          请教一下,风扇转速如何实现?谢谢!
          1. 不哭死神说道:
            Google Chrome Windows 10
            $res->{thermalstate} = `sensors`; const f1 = value.match(/fan2:.*?\ ([\d.]+) R/)[1];
        2. 上帝的左翼说道:
          Google Chrome Windows 10
          感谢,貌似我的sensors命令未列出风扇转速,无法实现。还是非常感谢指导!
      2. 不哭死神说道:
        Google Chrome Windows 10
        真的尝试过好多次了 每次都是提示 未安装硬盘或者已经直通硬盘控制器 我把板载的sata控制器直通给黑裙辉了,两个NVME盘和阵列卡没有直通。
  9. hehe9011说道:
    Google Chrome Windows 10
    之前有pvetools可以用,不过现在好久不更新了
    1. 一根小香蕉说道:
      Google Chrome Windows 10
      虽然没更新,也还能用
  10. 迷情说道:
    Google Chrome Mac OS X 10.15.7
    每次pve一更新就不在了必须重新改麻烦死了 现在不想折腾了 :heixian:
    1. 博主说道:
      Google Chrome Windows 10
      这个是给不折腾不升级的人用的,装好以后不升级系统,也不再折腾了。
      1. 大西瓜和芒果和苹果和雪梨说道:
        Safari Mac OS X 10.15.7
        我也是不想折腾,懒。 还是感谢博主的教程。

发表回复