mirror of
				https://github.com/centreon/centreon-plugins.git
				synced 2025-10-25 17:33:44 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| ################################################################################
 | |
| # Copyright 2005-2013 MERETHIS
 | |
| # Centreon is developped by : Julien Mathis and Romain Le Merlus under
 | |
| # GPL Licence 2.0.
 | |
| # 
 | |
| # This program is free software; you can redistribute it and/or modify it under 
 | |
| # the terms of the GNU General Public License as published by the Free Software 
 | |
| # Foundation ; either version 2 of the License.
 | |
| # 
 | |
| # 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.
 | |
| # 
 | |
| # You should have received a copy of the GNU General Public License along with 
 | |
| # this program; if not, see <http://www.gnu.org/licenses>.
 | |
| # 
 | |
| # Linking this program statically or dynamically with other modules is making a 
 | |
| # combined work based on this program. Thus, the terms and conditions of the GNU 
 | |
| # General Public License cover the whole combination.
 | |
| # 
 | |
| # As a special exception, the copyright holders of this program give MERETHIS 
 | |
| # permission to link this program with independent modules to produce an executable, 
 | |
| # regardless of the license terms of these independent modules, and to copy and 
 | |
| # distribute the resulting executable under terms of MERETHIS choice, provided that 
 | |
| # MERETHIS also meet, for each linked independent module, the terms  and conditions 
 | |
| # of the license of that module. An independent module is a module which is not 
 | |
| # derived from this program. If you modify this program, you may extend this 
 | |
| # exception to your version of the program, but you are not obliged to do so. If you
 | |
| # do not wish to do so, delete this exception statement from your version.
 | |
| # 
 | |
| # For more information : contact@centreon.com
 | |
| # Authors : Quentin Garnier <qgarnier@merethis.com>
 | |
| #
 | |
| ####################################################################################
 | |
| 
 | |
| package database::mysql::plugin;
 | |
| 
 | |
| use strict;
 | |
| use warnings;
 | |
| use base qw(centreon::plugins::script_sql);
 | |
| 
 | |
| sub new {
 | |
|     my ($class, %options) = @_;
 | |
|     
 | |
|     my $self = $class->SUPER::new(package => __PACKAGE__, %options);
 | |
|     bless $self, $class;
 | |
|     # $options->{options} = options object
 | |
| 
 | |
|     $self->{version} = '0.1';
 | |
|     %{$self->{modes}} = (
 | |
|                          'connection-time' => 'database::mysql::mode::connectiontime',
 | |
|                          'databases-size' => 'database::mysql::mode::databasessize',
 | |
|                          'queries' => 'database::mysql::mode::queries',
 | |
|                          'slow-queries' => 'database::mysql::mode::slowqueries',
 | |
|                          'threads-connected' => 'database::mysql::mode::threadsconnected',
 | |
|                          'uptime' => 'database::mysql::mode::uptime',
 | |
|                          'open-files' => 'database::mysql::mode::openfiles',
 | |
|                          'innodb-bufferpool-hitrate' => 'database::mysql::mode::innodbbufferpoolhitrate',
 | |
|                          'myisam-keycache-hitrate' => 'database::mysql::mode::myisamkeycachehitrate',
 | |
|                          'replication-master-slave' => 'database::mysql::mode::replicationmasterslave',
 | |
|                          );
 | |
|     $self->{sql_modes}{mysqlcmd} = 'database::mysql::mysqlcmd';
 | |
| 
 | |
|     return $self;
 | |
| }
 | |
| 
 | |
| sub init {
 | |
|     my ($self, %options) = @_;
 | |
| 
 | |
|     $self->{options}->add_options(
 | |
|                                    arguments => {
 | |
|                                                 'host:s@'  => { name => 'db_host' },
 | |
|                                                 'port:s@'  => { name => 'db_port' },
 | |
|                                                 }
 | |
|                                   );
 | |
|     $self->{options}->parse_options();
 | |
|     my $options_result = $self->{options}->get_options();
 | |
|     $self->{options}->clean();
 | |
| 
 | |
|     if (defined($options_result->{db_host})) {
 | |
|         @{$self->{sqldefault}->{dbi}} = ();
 | |
|         @{$self->{sqldefault}->{mysqlcmd}} = ();
 | |
|         for (my $i = 0; $i < scalar(@{$options_result->{db_host}}); $i++) {
 | |
|             $self->{sqldefault}->{dbi}[$i] = { data_source => 'mysql:host=' . $options_result->{db_host}[$i] };
 | |
|             $self->{sqldefault}->{mysqlcmd}[$i] = { host => $options_result->{db_host}[$i] };
 | |
|             if (defined($options_result->{db_port}[$i])) {
 | |
|                 $self->{sqldefault}->{dbi}[$i]->{data_source} .= ';port=' . $options_result->{db_port}[$i];
 | |
|                 $self->{sqldefault}->{mysqlcmd}[$i]->{port} = $options_result->{db_port}[$i];
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     $self->SUPER::init(%options);    
 | |
| }
 | |
| 
 | |
| 1;
 | |
| 
 | |
| __END__
 | |
| 
 | |
| =head1 PLUGIN DESCRIPTION
 | |
| 
 | |
| Check MySQL Server.
 | |
| 
 | |
| =over 8
 | |
| 
 | |
| You can use following options or options from 'sqlmode' directly.
 | |
| 
 | |
| =item B<--host>
 | |
| 
 | |
| Hostname to query.
 | |
| 
 | |
| =item B<--port>
 | |
| 
 | |
| Database Server Port.
 | |
| 
 | |
| =back
 | |
| 
 | |
| =cut
 |