mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Modernize mempools (#12282)
* mempools to modern module quick hacky hrstorage port * port ucd-snmp-mib to Mempools * Populate DB for ucd Prep for yaml * initial yaml attempt * more complex conversions fixes to YamlDiscovery, make leading $ optional and allow mib::oid format * walk full tables and skip values normalize percentages above 100 * handle precent only ones (specify total as 100) * Move default polling out of YamlMempoolsDiscovery * fixes * Update test data hrstorage should be correct. * perc_warn for hrstorage * Host Resources, record buffer, cached, and shared * Host Resources is always better, don't do both HR and UCD * fix unix, include warning levels * variable size * consolidate skip_values * define mempools schema * number instead of integer * more schema refactor * one more skip_values reference * throw error for invalid oid translation aos6 * a* and Cisco * updated test data * update almost all hrstorage data files * b* * c* with test data use standard cache for hrStorage * use cache for storage module too * hand bsnmp properly * bdcom * exclude total oid from yaml so it is not polled May add a way to ignore this behavior and poll it, but I don't know if that is needed. * automatically handle percent only values * ciscowlc * only poll used or free if we have used, free, and total. * fix skipping * the dlinkoning fix find value when value "name" is numeric * support numeric oids * dnos/ftos attempt * I guess we can't filter on total > 0 * edgecos * e* * f WIP * f* * gwd (aka g*) * h* + procurve * i* * j* * m* * support 0% used memory (however unlikely) * n* * CISCO-PROCESS-MIB memory, share cache with processors module * ignore mempools with invalid total * p* * quanta * r* fix raisecom mibs terribly broken * s-z * style fixes * Move VRP back to PHP and make it actually work * fix zynos * update schema * Update Cisco processor data for description bug fixes * fix comware processors * comware mempools with memory size default precision to 1 * sophos-xg updated data * hrstorage use ram size for buffers, cache, and shared * Show memory available instead of free in device overview * UCD, use same rrd format, store available instead of free in the db. * Calculate availability for HOST-RESOURCES-MIB * Convert UCD to standard polling * rename old rrd files * initial graph work * graph WIP * Graph looking decent * Graph looking decent for hr * remove old ucd_graph code * handle availability mempool more graph cleanup * color adjustments * remove accidental free calculation * Update test data and fix corner cases * fis pfsense * update schema * add default value for mempool_class * fix whitespace * update schema * update schema correctly * one more time * fortigate_1500d-sensors missing oids * Update docs. * fix indent * add implements MempoolsDiscovery explicitly to OS * remove ucd_memory graph references remove unused device_memory graph * remove unused functions * set devices with mempools to rediscover to prevent/minimize gaps * use a subquery * add overview graph * port health mempools table * Update device mempool * only show overview if multiple * Don't override user set warn percentages in discovery * fix missed usage * fix style * Safety check to not rename rrd files incorrectly if migration has not been run. * Fix overview percent bar and represent available and used on the bar * missed an item to convert to mempool_class * percent on the wrong side
This commit is contained in:
@@ -25,38 +25,49 @@
|
||||
namespace LibreNMS\OS;
|
||||
|
||||
use App\Models\Device;
|
||||
use App\Models\Mempool;
|
||||
use Illuminate\Support\Str;
|
||||
use LibreNMS\Device\Processor;
|
||||
use LibreNMS\Device\YamlDiscovery;
|
||||
use LibreNMS\Interfaces\Discovery\MempoolsDiscovery;
|
||||
use LibreNMS\Interfaces\Discovery\ProcessorDiscovery;
|
||||
use LibreNMS\OS;
|
||||
|
||||
class Edgecos extends OS implements ProcessorDiscovery
|
||||
class Edgecos extends OS implements MempoolsDiscovery, ProcessorDiscovery
|
||||
{
|
||||
public function discoverOS(Device $device): void
|
||||
public function discoverMempools()
|
||||
{
|
||||
if (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.6.')) { //ES3528M0
|
||||
$tmp_mib = 'ES3528MO-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.22.')) { //ES3528MV2
|
||||
$tmp_mib = 'ES3528MV2-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.24.')) { //ECS4510
|
||||
$tmp_mib = 'ECS4510-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.39.')) { //ECS4110
|
||||
$tmp_mib = 'ECS4110-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.42.')) { //ECS4210
|
||||
$tmp_mib = 'ECS4210-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.27.')) { //ECS3510
|
||||
$tmp_mib = 'ECS3510-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.45.')) { //ECS4120
|
||||
$tmp_mib = 'ECS4120-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.8.1.11')) { //ES3510MA
|
||||
$tmp_mib = 'ES3510MA-MIB';
|
||||
} elseif (Str::startsWith($device->sysObjectID, '.1.3.6.1.4.1.259.10.1.43.')) { //ECS2100
|
||||
$tmp_mib = 'ECS2100-MIB';
|
||||
} else {
|
||||
return;
|
||||
$mib = $this->findMib();
|
||||
$data = snmp_get_multi_oid($this->getDeviceArray(), ['memoryTotal.0', 'memoryFreed.0', 'memoryAllocated.0'], '-OUQs', $mib);
|
||||
|
||||
if (empty($data)) {
|
||||
return collect();
|
||||
}
|
||||
|
||||
$data = snmp_get_multi($this->getDeviceArray(), ['swOpCodeVer.1', 'swProdName.0', 'swSerialNumber.1', 'swHardwareVer.1'], '-OQUs', $tmp_mib);
|
||||
$mempool = new Mempool([
|
||||
'mempool_index' => 0,
|
||||
'mempool_type' => 'edgecos',
|
||||
'mempool_class' => 'system',
|
||||
'mempool_precision' => 1,
|
||||
'mempool_descr' => 'Memory',
|
||||
'mempool_perc_warn' => 90,
|
||||
]);
|
||||
|
||||
if ($data['memoryAllocated.0']) {
|
||||
$mempool->mempool_used_oid = YamlDiscovery::oidToNumeric('memoryAllocated.0', $this->getDeviceArray(), $mib);
|
||||
} else {
|
||||
$mempool->mempool_free_oid = YamlDiscovery::oidToNumeric('memoryFreed.0', $this->getDeviceArray(), $mib);
|
||||
}
|
||||
|
||||
$mempool->fillUsage($data['memoryAllocated.0'], $data['memoryTotal.0'], $data['memoryFreed.0']);
|
||||
|
||||
return collect([$mempool]);
|
||||
}
|
||||
|
||||
public function discoverOS(Device $device): void
|
||||
{
|
||||
$mib = $this->findMib();
|
||||
$data = snmp_get_multi($this->getDeviceArray(), ['swOpCodeVer.1', 'swProdName.0', 'swSerialNumber.1', 'swHardwareVer.1'], '-OQUs', $mib);
|
||||
|
||||
$device->version = trim($data[1]['swHardwareVer'] . ' ' . $data[1]['swOpCodeVer']) ?: null;
|
||||
$device->hardware = $data[0]['swProdName'] ?? null;
|
||||
@@ -102,4 +113,31 @@ class Edgecos extends OS implements ProcessorDiscovery
|
||||
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Find the MIB based on sysObjectID
|
||||
* @return string
|
||||
*/
|
||||
protected function findMib(): ?string
|
||||
{
|
||||
$table = [
|
||||
'.1.3.6.1.4.1.259.6.' => 'ES3528MO-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.22.' => 'ES3528MV2-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.24.' => 'ECS4510-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.39.' => 'ECS4110-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.42.' => 'ECS4210-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.27.' => 'ECS3510-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.45.' => 'ECS4120-MIB',
|
||||
'.1.3.6.1.4.1.259.8.1.11' => 'ES3510MA-MIB',
|
||||
'.1.3.6.1.4.1.259.10.1.43.' => 'ECS2100-MIB',
|
||||
];
|
||||
|
||||
foreach ($table as $prefix => $mib) {
|
||||
if (Str::startsWith($this->getDevice()->sysObjectID, $prefix)) {
|
||||
return $mib;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user