mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
disable snmp timeout/retries as defaults
git-svn-id: http://www.observium.org/svn/observer/trunk@1720 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
@@ -57,9 +57,9 @@ $config['show_locations_dropdown'] = 1; # Enable Locations dropdown on menu
|
||||
$config['show_services'] = 1; # Enable Services on menu
|
||||
$config['ports_page_default'] = "details/"; ## eg "details/" "graphs/bits/"
|
||||
|
||||
### SNMP Settings
|
||||
$config['snmp']['timeout'] = 1; # timeout in seconds
|
||||
$config['snmp']['retries'] = 5; # how many times to retry the query
|
||||
### SNMP Settings - Timeouts/Retries disabled as default
|
||||
#$config['snmp']['timeout'] = 1; # timeout in seconds
|
||||
#$config['snmp']['retries'] = 5; # how many times to retry the query
|
||||
$config['snmp']['community'][] = "public"; # Communities to try during discovery (dangerous)
|
||||
$config['snmp']['internal'] = false; # Enable php_snmp functions to make gets faster
|
||||
|
||||
|
||||
@@ -8,8 +8,8 @@
|
||||
|
||||
function snmp_get_multi($device, $oids, $options = "-OQUs", $mib = NULL, $mibdir = NULL) {
|
||||
global $debug,$config,$runtime_stats,$mibs_loaded;
|
||||
if ($device['timeout'] == NULL) { $timeout = $config['snmp']['timeout']; } else { $timeout = $device['timeout']; }
|
||||
if ($device['retries'] == NULL) { $retries = $config['snmp']['retries']; } else { $retries = $device['retries']; }
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($config['snmp']['internal'] == true) {
|
||||
|
||||
if ($mib && $mibdir && !$mibs_loaded[$mib])
|
||||
@@ -20,7 +20,7 @@ function snmp_get_multi($device, $oids, $options = "-OQUs", $mib = NULL, $mibdir
|
||||
snmp_set_quick_print(1);
|
||||
$oids = explode(" ",trim($oids));
|
||||
// s->ms - php snmp extension requires the timeout in microseconds.
|
||||
$timeout = $timeout*1000*1000;
|
||||
if(isset($timeout)) { $timeout = $timeout*1000*1000; }
|
||||
foreach($oids as $oid) {
|
||||
if ($device['snmpver'] == "v2c") {
|
||||
$data = @snmp2_get($device['hostname'].":".$device['port'], $device['community'], $oid, $timeout, $retries);
|
||||
@@ -32,13 +32,15 @@ function snmp_get_multi($device, $oids, $options = "-OQUs", $mib = NULL, $mibdir
|
||||
if ($data) { $array[$index][$oid] = $data; }
|
||||
else { $array[$index][$oid] = null; }
|
||||
}
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
$cmd = $config['snmpget'] . " -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
if ($options) { $cmd .= " " . $options; }
|
||||
if ($mib) { $cmd .= " -m " . $mib; }
|
||||
if ($mibdir) { $cmd .= " -M " . $mibdir; } else { $cmd .= " -M ".$config['mibdir']; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oids;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
if ($debug) { echo("$cmd\n"); }
|
||||
@@ -59,8 +61,8 @@ function snmp_get_multi($device, $oids, $options = "-OQUs", $mib = NULL, $mibdir
|
||||
|
||||
function snmp_get($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL) {
|
||||
global $debug,$config,$runtime_stats,$mibs_loaded;
|
||||
if ($device['timeout'] == NULL) { $timeout = $config['snmp']['timeout']; } else { $timeout = $device['timeout']; }
|
||||
if ($device['retries'] == NULL) { $retries = $config['snmp']['retries']; } else { $retries = $device['retries']; }
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($config['snmp']['internal'] == true)
|
||||
{
|
||||
if ($mib && $mibdir && !$mibs_loaded[$mib])
|
||||
@@ -70,7 +72,7 @@ function snmp_get($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL) {
|
||||
}
|
||||
snmp_set_quick_print(1);
|
||||
// s->ms - php snmp extension requires the timeout in microseconds.
|
||||
$timeout = $timeout*1000*1000;
|
||||
if(isset($timeout)) { $timeout = $timeout*1000*1000; }
|
||||
if ($device['snmpver'] == "v2c")
|
||||
{
|
||||
$data = @snmp2_get($device['hostname'].":".$device['port'], $device['community'], $oid, $timeout, $retries);
|
||||
@@ -83,7 +85,10 @@ function snmp_get($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL) {
|
||||
if ($options) { $cmd .= " " . $options; }
|
||||
if ($mib) { $cmd .= " -m " . $mib; }
|
||||
if ($mibdir) { $cmd .= " -M " . $mibdir; } else { $cmd .= " -M ".$config['mibdir']; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
if ($debug) { echo("$cmd\n"); }
|
||||
@@ -98,8 +103,8 @@ function snmp_get($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL) {
|
||||
|
||||
function snmp_walk($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL) {
|
||||
global $debug,$config,$runtime_stats;
|
||||
if ($device['timeout'] == NULL) { $timeout = $config['snmp']['timeout']; } else { $timeout = $device['timeout']; }
|
||||
if ($device['retries'] == NULL) { $retries = $config['snmp']['retries']; } else { $retries = $device['retries']; }
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
// php has no bulkwalk functionality, so use binary for this.
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk']) {
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
@@ -111,7 +116,8 @@ function snmp_walk($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL)
|
||||
if ($options) { $cmd .= " $options "; }
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
if ($mibdir) { $cmd .= " -M " . $mibdir; } else { $cmd .= " -M ".$config['mibdir']; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
if ($debug) { echo("$cmd\n"); }
|
||||
@@ -135,8 +141,8 @@ function snmp_walk($device, $oid, $options = NULL, $mib = NULL, $mibdir = NULL)
|
||||
|
||||
function snmpwalk_cache_cip($device, $oid, $array, $mib = 0) {
|
||||
global $config;
|
||||
if ($device['timeout'] == NULL) { $timeout = $config['snmp']['timeout']; } else { $timeout = $device['timeout']; }
|
||||
if ($device['retries'] == NULL) { $retries = $config['snmp']['retries']; } else { $retries = $device['retries']; }
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk']) {
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
}
|
||||
@@ -146,7 +152,8 @@ function snmpwalk_cache_cip($device, $oid, $array, $mib = 0) {
|
||||
$cmd = $snmpcommand . " -O snQ -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
$data = trim(shell_exec($cmd));
|
||||
@@ -176,6 +183,8 @@ function snmpwalk_cache_cip($device, $oid, $array, $mib = 0) {
|
||||
function snmp_cache_ifIndex($device)
|
||||
{
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk'])
|
||||
{
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
@@ -187,7 +196,8 @@ function snmp_cache_ifIndex($device)
|
||||
$cmd = $snmpcommand . " -O Qs -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
$cmd .= " -m IF-MIB ifIndex";
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries . " " . $device['hostname'].":".$device['port'];
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
$data = trim(shell_exec($cmd));
|
||||
$device_id = $device['device_id'];
|
||||
@@ -275,6 +285,8 @@ function snmpwalk_cache_triple_oid($device, $oid, $array, $mib = NULL, $mibdir =
|
||||
function snmpwalk_cache_twopart_oid($device, $oid, $array, $mib = 0)
|
||||
{
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk'])
|
||||
{
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
@@ -286,7 +298,8 @@ function snmpwalk_cache_twopart_oid($device, $oid, $array, $mib = 0)
|
||||
$cmd = $snmpcommand . " -O QUs -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
$data = trim(shell_exec($cmd));
|
||||
@@ -304,6 +317,8 @@ function snmpwalk_cache_twopart_oid($device, $oid, $array, $mib = 0)
|
||||
|
||||
function snmpwalk_cache_threepart_oid($device, $oid, $array, $mib = 0) {
|
||||
global $config, $debug;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk'])
|
||||
{
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
@@ -315,7 +330,8 @@ function snmpwalk_cache_threepart_oid($device, $oid, $array, $mib = 0) {
|
||||
$cmd = $snmpcommand . " -O QUs -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
$data = trim(shell_exec($cmd));
|
||||
@@ -334,6 +350,8 @@ function snmpwalk_cache_threepart_oid($device, $oid, $array, $mib = 0) {
|
||||
|
||||
function snmp_cache_slotport_oid($oid, $device, $array, $mib = 0) {
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
if ($device['snmpver'] == 'v1' || $config['os'][$device['os']]['nobulk'])
|
||||
{
|
||||
$snmpcommand = $config['snmpwalk'];
|
||||
@@ -345,7 +363,8 @@ function snmp_cache_slotport_oid($oid, $device, $array, $mib = 0) {
|
||||
$cmd = $snmpcommand . " -O QUs -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." ".$oid;
|
||||
if (!$debug) { $cmd .= " 2>/dev/null"; }
|
||||
$data = trim(shell_exec($cmd));
|
||||
@@ -371,10 +390,14 @@ function snmp_cache_oid($oid, $device, $array, $mib = 0)
|
||||
|
||||
function snmp_cache_port_oids($oids, $port, $device, $array, $mib=0) {
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
foreach($oids as $oid){
|
||||
$string .= " $oid.$port";
|
||||
}
|
||||
$cmd = $config['snmpget'] . " -O vq -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
if ($mib) { $cmd .= " -m $mib"; }
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
@@ -395,9 +418,12 @@ function snmp_cache_port_oids($oids, $port, $device, $array, $mib=0) {
|
||||
|
||||
function snmp_cache_portIfIndex ($device, $array) {
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
$cmd = $config['snmpwalk'] . " -CI -m CISCO-STACK-MIB -O q -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." portIfIndex";
|
||||
$output = trim(shell_exec($cmd));
|
||||
$device_id = $device['device_id'];
|
||||
@@ -414,9 +440,12 @@ function snmp_cache_portIfIndex ($device, $array) {
|
||||
|
||||
function snmp_cache_portName ($device, $array) {
|
||||
global $config;
|
||||
if (is_numeric($device['timeout'])) { $timeout = $device['timeout']; } elseif (isset($config['snmp']['timeout'])) { $timeout = $config['snmp']['timeout']; }
|
||||
if (is_numeric($device['retries'])) { $timeout = $device['retries']; } elseif (isset($config['snmp']['retries'])) { $timeout = $config['snmp']['retries']; }
|
||||
$cmd = $config['snmpwalk'] . " -CI -m CISCO-STACK-MIB -O Qs -" . $device['snmpver'] . " -c " . $device['community'] . " ";
|
||||
$cmd .= " -M ".$config['install_dir']."/mibs/";
|
||||
$cmd .= " -t " . $timeout . " -r " . $retries;
|
||||
if (isset($timeout)) { $cmd .= " -t " . $timeout; }
|
||||
if (isset($retries)) { $cmd .= " -r " . $retries; }
|
||||
$cmd .= " ".$device['hostname'].":".$device['port']." portName";
|
||||
$output = trim(shell_exec($cmd));
|
||||
$device_id = $device['device_id'];
|
||||
|
||||
Reference in New Issue
Block a user