2008-08-22 20:07:32 +02:00
< ? php
2006-03-27 05:37:27 +02:00
2021-11-04 16:28:15 +01:00
// Pandora FMS - http://pandorafms.com
2009-06-08 20:21:21 +02:00
// ==================================================
2020-11-27 13:52:35 +01:00
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
2009-06-08 20:21:21 +02:00
// Please see http://pandorafms.org for full contribution list
2008-04-24 01:29:50 +02:00
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
2008-08-22 20:07:32 +02:00
// as published by the Free Software Foundation for version 2.
2008-04-24 01:29:50 +02:00
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
2006-03-27 05:37:27 +02:00
// Load global vars
2010-03-03 18:10:37 +01:00
global $config ;
2019-01-30 16:18:44 +01:00
check_login ();
2008-04-24 01:29:50 +02:00
2019-01-30 16:18:44 +01:00
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'DM' )) {
db_pandora_audit (
2022-01-20 10:55:23 +01:00
AUDIT_LOG_ACL_VIOLATION ,
2019-01-30 16:18:44 +01:00
'Trying to access Database Management'
);
include 'general/noaccess.php' ;
return ;
2008-07-16 23:04:31 +02:00
}
2010-02-10 21:02:51 +01:00
// Get some general DB stats (not very heavy)
// NOTE: this is not realtime monitoring stats, are more focused on DB sanity
2019-01-30 16:18:44 +01:00
$stat_access = db_get_sql ( 'SELECT COUNT(*) FROM tagent_access WHERE id_agent != 0' );
$stat_data = db_get_sql ( 'SELECT COUNT(*) FROM tagente_datos WHERE id_agente_modulo != 0' );
$stat_data_log4x = db_get_sql ( 'SELECT COUNT(*) FROM tagente_datos_log4x WHERE id_agente_modulo != 0' );
$stat_data_string = db_get_sql ( 'SELECT COUNT(*) FROM tagente_datos_string WHERE id_agente_modulo != 0' );
$stat_modules = db_get_sql ( 'SELECT COUNT(*) FROM tagente_estado WHERE id_agente_modulo != 0' );
$stat_event = db_get_sql ( ' SELECT COUNT(*) FROM tevento' );
$stat_agente = db_get_sql ( ' SELECT COUNT(*) FROM tagente' );
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
$stat_uknown = db_get_sql ( 'SELECT COUNT(*) FROM tagente WHERE ultimo_contacto < NOW() - (intervalo * 2)' );
break ;
case 'postgresql' :
$stat_uknown = db_get_sql (
" SELECT COUNT(*)
2011-03-08 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_html.php, include/functions_messages.php,
include/functions_exportserver.php, include/functions_reporting.php,
include/functions_gis.php, include/functions_networkmap.php,
include/functions_servers.php, include/functions_api.php,
include/fgraph.php, include/functions_agents.php, include/functions_db.php,
include/functions_alerts.php, extensions/module_groups.php,
operation/incidents/incident.php, operation/incidents/incident_detail.php,
operation/search_modules.php, operation/agentes/status_monitor.php,
operation/agentes/export_csv.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/alerts_status.php, operation/agentes/estado_agente.php,
operation/agentes/sla_view.php, operation/agentes/ver_agente.php,
operation/servers/view_server_detail.php, operation/menu.php,
operation/search_graphs.php, operation/snmpconsole/snmp_view.php,
operation/gis_maps/ajax.php, operation/events/events_rss.php,
operation/events/events_list.php, operation/search_alerts.php,
operation/search_reports.php, operation/reporting/reporting_xml.php,
operation/reporting/graph_viewer.php, operation/search_maps.php,
operation/search_users.php, mobile/operation/agents/view_agents.php,
mobile/operation/events/events.php, godmode/groups/modu_group_list.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/db/db_main.php, godmode/db/db_purge.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/alert_list.list.php, godmode/users/configure_user.php,
godmode/massive/massive_edit_modules.php,
godmode/modules/manage_network_templates_form.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/reporting_builder.item_editor.php: changed or added in
some cases the SQL queries for to be PostgreSQL standard, and cleaned source
style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4074 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-09 15:26:36 +01:00
FROM tagente
2019-01-30 16:18:44 +01:00
WHERE ceil ( date_part ( 'epoch' , ultimo_contacto )) < ceil ( date_part ( 'epoch' , NOW ())) - ( intervalo * 2 ) "
);
break ;
case 'oracle' :
$stat_uknown = db_get_sql (
' SELECT COUNT ( * )
2011-04-11 19:05:20 +02:00
FROM tagente
2019-01-30 16:18:44 +01:00
WHERE CAST ( ultimo_contacto AS DATE ) < SYSDATE - ( intervalo * 2 ) '
);
break ;
2011-04-11 19:05:20 +02:00
}
2019-01-30 16:18:44 +01:00
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
case 'postgresql' :
$stat_noninit = db_get_sql ( 'SELECT COUNT(*) FROM tagente_estado WHERE utimestamp = 0;' );
break ;
case 'oracle' :
$stat_noninit = db_get_sql ( 'SELECT COUNT(*) FROM tagente_estado WHERE utimestamp = 0' );
break ;
2011-03-08 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_html.php, include/functions_messages.php,
include/functions_exportserver.php, include/functions_reporting.php,
include/functions_gis.php, include/functions_networkmap.php,
include/functions_servers.php, include/functions_api.php,
include/fgraph.php, include/functions_agents.php, include/functions_db.php,
include/functions_alerts.php, extensions/module_groups.php,
operation/incidents/incident.php, operation/incidents/incident_detail.php,
operation/search_modules.php, operation/agentes/status_monitor.php,
operation/agentes/export_csv.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/alerts_status.php, operation/agentes/estado_agente.php,
operation/agentes/sla_view.php, operation/agentes/ver_agente.php,
operation/servers/view_server_detail.php, operation/menu.php,
operation/search_graphs.php, operation/snmpconsole/snmp_view.php,
operation/gis_maps/ajax.php, operation/events/events_rss.php,
operation/events/events_list.php, operation/search_alerts.php,
operation/search_reports.php, operation/reporting/reporting_xml.php,
operation/reporting/graph_viewer.php, operation/search_maps.php,
operation/search_users.php, mobile/operation/agents/view_agents.php,
mobile/operation/events/events.php, godmode/groups/modu_group_list.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/db/db_main.php, godmode/db/db_purge.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/alert_list.list.php, godmode/users/configure_user.php,
godmode/massive/massive_edit_modules.php,
godmode/modules/manage_network_templates_form.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/reporting_builder.item_editor.php: changed or added in
some cases the SQL queries for to be PostgreSQL standard, and cleaned source
style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4074 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-09 15:26:36 +01:00
}
2010-02-10 21:02:51 +01:00
// Todo: Recalculate this data dinamically using the capacity and total agents
$max_access = 1000000 ;
$max_data = 12000000 ;
2019-01-30 16:18:44 +01:00
ui_print_page_header ( __ ( 'Current database maintenance setup' ), 'images/gm_db.png' , false , '' , true );
2010-02-10 21:02:51 +01:00
2011-06-28 15:31:52 +02:00
echo '<table class=databox width="98%" cellspacing="4" cellpadding="4" border="0">' ;
2010-02-10 21:02:51 +01:00
// Current setup
echo '<tr><th colspan=2><i>' ;
echo __ ( 'Database setup' );
echo '</i></td></tr>' ;
echo '<tr class="rowOdd"><td>' ;
echo __ ( 'Max. time before compact data' );
echo '<td><b>' ;
2019-01-30 16:18:44 +01:00
echo $config [ 'days_compact' ] . ' ' . __ ( 'days' );
2010-02-10 21:02:51 +01:00
echo '</b></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Max. time before purge' );
echo '<td><b>' ;
echo $config [ 'days_purge' ] . ' ' . __ ( 'days' );
echo '</b></td></tr>' ;
// DB size stats
echo '<tr><th colspan=2><i>' ;
echo __ ( 'Database size stats' );
echo '</i></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Total agents' );
echo '<td><b>' ;
echo $stat_agente ;
echo '</b></td></tr>' ;
echo '<tr class="rowOdd"><td>' ;
echo __ ( 'Total events' );
echo '<td><b>' ;
echo $stat_event ;
echo '</b></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Total data items (tagente_datos)' );
echo '<td><b>' ;
2019-01-30 16:18:44 +01:00
if ( $stat_data > $max_data ) {
echo " <font color='#ff0000'> $stat_data </font> " ;
} else {
echo $stat_data ;
}
2010-02-10 21:02:51 +01:00
echo '</b></td></tr>' ;
2010-03-19 15:03:40 +01:00
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Total log4x items (tagente_datos_log4x)' );
echo '<td><b>' ;
2019-01-30 16:18:44 +01:00
if ( $stat_data_log4x > $max_data ) {
echo " <font color='#ff0000'> $stat_data_log4x </font> " ;
} else {
echo $stat_data_log4x ;
}
2010-03-19 15:03:40 +01:00
echo '</b></td></tr>' ;
2010-02-10 21:02:51 +01:00
echo '<tr class="rowOdd"><td>' ;
echo __ ( 'Total data string items (tagente_datos_string)' );
echo '<td><b>' ;
echo $stat_data_string ;
echo '</b></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Total modules configured' );
echo '<td><b>' ;
echo $stat_modules ;
echo '</b></td></tr>' ;
echo '<tr class="rowOdd"><td>' ;
echo __ ( 'Total agent access records' );
echo '<td><b>' ;
2019-01-30 16:18:44 +01:00
if ( $stat_access > $max_access ) {
echo " <font color='#ff0000'> $stat_access </font> " ;
} else {
echo $stat_access ;
}
2010-02-10 21:02:51 +01:00
echo '</b></td></tr>' ;
// Sanity
echo '<tr><th colspan=2><i>' ;
echo __ ( 'Database sanity' );
echo '</i></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Total uknown agents' );
echo '<td><b>' ;
echo $stat_uknown ;
echo '</b></td></tr>' ;
echo '<tr class="rowOdd"><td>' ;
echo __ ( 'Total non-init modules' );
echo '<td><b>' ;
echo $stat_noninit ;
echo '</b></td></tr>' ;
echo '<tr class="rowPair"><td>' ;
echo __ ( 'Last time on DB maintance' );
echo '<td>' ;
2012-07-27 11:01:12 +02:00
if ( ! isset ( $config [ 'db_maintance' ])) {
2019-01-30 16:18:44 +01:00
echo '<b><font size=12px>' . __ ( 'Never' ) . '</font></b>' ;
} else {
$seconds = ( time () - $config [ 'db_maintance' ]);
if ( $seconds > 90000 ) {
// (1,1 days)
echo " <b><font color='#ff0000' size=12px> " ;
} else {
echo '<font><b>' ;
}
echo human_time_description_raw ( $seconds );
echo ' *' ;
2012-07-27 11:01:12 +02:00
}
2019-01-30 16:18:44 +01:00
echo '</td></tr>' ;
2010-02-10 21:02:51 +01:00
echo '<tr><td colspan=2>' ;
echo '<div align="justify"><br><hr width=100%>' ;
2018-05-22 19:22:37 +02:00
echo '(*) ' . __ ( " Please make sure your %s Server settings are correct and that the database maintenance daemon is running. It's very important to keep your database up to date in order to get the best performance and results from %s. " , get_product_name (), get_product_name ());
2010-02-10 21:02:51 +01:00
echo '</div>' ;
echo '</td></tr></table>' ;