Last modification related to options
This commit is contained in:
		
							parent
							
								
									0f724fa31f
								
							
						
					
					
						commit
						1b9e4e75ba
					
				
					 2 changed files with 123 additions and 83 deletions
				
			
		
							
								
								
									
										10
									
								
								USAGE.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								USAGE.md
									
									
									
									
									
								
							|  | @ -1,6 +1,6 @@ | |||
| # NAME | ||||
| 
 | ||||
|     MySQLTuner 1.7.11 - MySQL High Performance Tuning Script | ||||
|     MySQLTuner 1.7.14 - MySQL High Performance Tuning Script | ||||
| 
 | ||||
| # IMPORTANT USAGE GUIDELINES | ||||
| 
 | ||||
|  | @ -41,12 +41,19 @@ You must provide the remote server's total memory when connecting to other serve | |||
|     --nobad                     Remove negative/suggestion responses | ||||
|     --noinfo                    Remove informational responses | ||||
|     --debug                     Print debug information | ||||
|     --noprocess                Consider no other process is running | ||||
|     --dbstat                    Print database information | ||||
|     --nodbstat                  Don't Print database information | ||||
|     --tbstat                    Print table information | ||||
|     --notbstat                  Don't Print table information | ||||
|     --idxstat                   Print index information | ||||
|     --noidxstat                 Don't Print index information | ||||
|     --sysstat                   Print system information | ||||
|     --nosysstat                 Don't Print system information | ||||
|     --pfstat                    Print Performance schema | ||||
|     --nopfstat                  Don't Print Performance schema | ||||
|     --verbose                   Prints out all options (default: no verbose, dbstat, idxstat, sysstat, tbstat, pfstat) | ||||
|       | ||||
|     --bannedports               Ports banned separated by comma(,) | ||||
|     --maxportallowed            Number of ports opened allowed on this hosts | ||||
|     --cvefile <path>            CVE File for vulnerability checks | ||||
|  | @ -56,7 +63,6 @@ You must provide the remote server's total memory when connecting to other serve | |||
|     --outputfile <path>         Path to a output txt file | ||||
|     --reportfile <path>         Path to a report txt file | ||||
|     --template   <path>         Path to a template file | ||||
|     --verbose                   Prints out all options (default: no verbose) | ||||
| 
 | ||||
| # PERLDOC | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| #!/usr/bin/env perl | ||||
| # mysqltuner.pl - Version 1.7.13 | ||||
| # mysqltuner.pl - Version 1.7.14 | ||||
| # High Performance MySQL Tuning Script | ||||
| # Copyright (C) 2006-2018 Major Hayden - major@mhtx.net | ||||
| # | ||||
|  | @ -56,7 +56,7 @@ $Data::Dumper::Pair = " : "; | |||
| #use Env; | ||||
| 
 | ||||
| # Set up a few variables for use in the script | ||||
| my $tunerversion = "1.7.13"; | ||||
| my $tunerversion = "1.7.14"; | ||||
| my ( @adjvars, @generalrec ); | ||||
| 
 | ||||
| # Set defaults | ||||
|  | @ -85,12 +85,17 @@ my %opt = ( | |||
|     "bannedports"    => '', | ||||
|     "maxportallowed" => 0, | ||||
|     "outputfile"     => 0, | ||||
|     "noprocess"      => 0, | ||||
|     "dbstat"         => 0, | ||||
|     "nodbstat"       => 0, | ||||
|     "tbstat"         => 0, | ||||
|     "notbstat"       => 0, | ||||
|     "idxstat"        => 0, | ||||
|     "noidxstat"      => 0, | ||||
|     "sysstat"        => 0, | ||||
|     "nosysstat"      => 0, | ||||
|     "pfstat"         => 0, | ||||
|     "nopfstat"       => 0, | ||||
|     "skippassword"   => 0, | ||||
|     "noask"          => 0, | ||||
|     "template"       => 0, | ||||
|  | @ -114,18 +119,20 @@ GetOptions( | |||
|     'mysqlcmd=s',      'help', | ||||
|     'buffers',         'skippassword', | ||||
|     'passwordfile=s',  'outputfile=s', | ||||
|     'silent',          'dbstat', | ||||
|     'silent',          'noask', | ||||
|     'json',            'prettyjson', | ||||
|     'idxstat',         'noask', | ||||
|     'template=s',      'reportfile=s', | ||||
|     'cvefile=s',       'bannedports=s', | ||||
|     'updateversion',   'maxportallowed=s', | ||||
|     'verbose',         'sysstat', | ||||
|     'password=s',      'pfstat', | ||||
|     'verbose',         'password=s', | ||||
|     'passenv=s',       'userenv=s', | ||||
|     'defaults-file=s', 'ssl-ca=s', | ||||
|     'color',	       'tbstat', | ||||
|     'notbstat' | ||||
|     'color',           'noprocess', | ||||
|     'dbstat',          'nodbstat', | ||||
|     'tbstat',          'notbstat', | ||||
|     'sysstat',         'nosysstat', | ||||
|     'pfstat',          'nopfstat', | ||||
|     'idxstat',         'noidxstat', | ||||
|   ) | ||||
|   or pod2usage( | ||||
|     -exitval  => 1, | ||||
|  | @ -186,7 +193,14 @@ if ( $opt{verbose} ) { | |||
|     $opt{cvefile} = 'vulnerabilities.csv';    #CVE File for vulnerability checks | ||||
| } | ||||
| $opt{nocolor} = 1 if defined( $opt{outputfile} ); | ||||
| $opt{tbstat}  = 1 if ($opt{notbstat} != 0);    # Don't Print database information | ||||
| $opt{tbstat}  = 0 if ( $opt{notbstat} == 1 );    # Don't Print table information | ||||
| $opt{dbstat} = 0 if ( $opt{nodbstat} == 1 );  # Don't Print database information | ||||
| $opt{noprocess} = 0 | ||||
|   if ( $opt{noprocess} == 1 );                # Don't Print process information | ||||
| $opt{sysstat} = 0 if ( $opt{nosysstat} == 1 ); # Don't Print sysstat information | ||||
| $opt{pfstat} = 0 | ||||
|   if ( $opt{nopfstat} == 1 );    # Don't Print performance schema information | ||||
| $opt{idxstat} = 0 if ( $opt{noidxstat} == 1 );   # Don't Print index information | ||||
| 
 | ||||
| # for RPM distributions | ||||
| $opt{cvefile} = "/usr/share/mysqltuner/vulnerabilities.csv" | ||||
|  | @ -841,7 +855,8 @@ sub mysql_setup { | |||
|             return 1; | ||||
|         } | ||||
|         else { | ||||
|             badprint "Attempted to use login credentials from Debian maintenance account, but they failed."; | ||||
|             badprint | ||||
| "Attempted to use login credentials from Debian maintenance account, but they failed."; | ||||
|             exit 1; | ||||
|         } | ||||
|     } | ||||
|  | @ -965,8 +980,7 @@ sub select_array { | |||
| sub human_size { | ||||
|     my ( $size, $n ) = ( shift, 0 ); | ||||
|     ++$n and $size /= 1024 until $size < 1024; | ||||
|     return sprintf "%.2f %s",  | ||||
|           $size, ( qw[ bytes KB MB GB ] )[ $n ]; | ||||
|     return sprintf "%.2f %s", $size, (qw[ bytes KB MB GB ])[$n]; | ||||
| } | ||||
| 
 | ||||
| # MySQL Request one | ||||
|  | @ -1373,6 +1387,7 @@ sub get_process_memory { | |||
| } | ||||
| 
 | ||||
| sub get_other_process_memory { | ||||
|     return 0 if ( $opt{tbstat} == 0 ); | ||||
|     my @procs = `ps eaxo pid,command`; | ||||
|     @procs = map { | ||||
|         my $v = $_; | ||||
|  | @ -1714,6 +1729,7 @@ sub security_recommendations { | |||
|         infoprint "Skipped due to unsupported feature for MySQL 8"; | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     #exit 0; | ||||
|     if ( $opt{skippassword} eq 1 ) { | ||||
|         infoprint "Skipped due to --skippassword option"; | ||||
|  | @ -1958,8 +1974,10 @@ sub validate_mysql_version { | |||
| # Checks if MySQL version is equal to (major, minor, micro) | ||||
| sub mysql_version_eq { | ||||
|     my ( $maj, $min, $mic ) = @_; | ||||
|     return int($mysqlvermajor) == int($maj) if ( !defined($min) && !defined($mic)); | ||||
|     return int($mysqlvermajor) == int($maj)&& int($mysqlverminor) == int($min)  if ( !defined($mic)); | ||||
|     return int($mysqlvermajor) == int($maj) | ||||
|       if ( !defined($min) && !defined($mic) ); | ||||
|     return int($mysqlvermajor) == int($maj) && int($mysqlverminor) == int($min) | ||||
|       if ( !defined($mic) ); | ||||
|     return ( int($mysqlvermajor) == int($maj) | ||||
|           && int($mysqlverminor) == int($min) | ||||
|           && int($mysqlvermicro) == int($mic) ); | ||||
|  | @ -2374,6 +2392,7 @@ sub calculations { | |||
|       $mycalc{'server_buffers'} + | ||||
|       $mycalc{"max_total_per_thread_buffers"} + | ||||
|       get_pf_memory(); | ||||
| 
 | ||||
|     #   + get_gcache_memory(); | ||||
|     $mycalc{'pct_max_used_memory'} = | ||||
|       percentage( $mycalc{'max_used_memory'}, $physical_memory ); | ||||
|  | @ -2384,6 +2403,7 @@ sub calculations { | |||
|       $mycalc{'server_buffers'} + | ||||
|       $mycalc{'total_per_thread_buffers'} + | ||||
|       get_pf_memory(); | ||||
| 
 | ||||
|     # +  get_gcache_memory(); | ||||
|     $mycalc{'pct_max_physical_memory'} = | ||||
|       percentage( $mycalc{'max_peak_memory'}, $physical_memory ); | ||||
|  | @ -2512,7 +2532,8 @@ sub calculations { | |||
|     # Query cache | ||||
|     if ( mysql_version_ge(8) and mysql_version_le(10) ) { | ||||
|         $mycalc{'query_cache_efficiency'} = 0; | ||||
|     } elsif ( mysql_version_ge(4) ) { | ||||
|     } | ||||
|     elsif ( mysql_version_ge(4) ) { | ||||
|         $mycalc{'query_cache_efficiency'} = sprintf( | ||||
|             "%.1f", | ||||
|             ( | ||||
|  | @ -2724,17 +2745,15 @@ sub mysql_stats { | |||
|     infoprint "Max MySQL memory    : " . hr_bytes( $mycalc{'max_peak_memory'} ); | ||||
|     infoprint "Other process memory: " . hr_bytes( get_other_process_memory() ); | ||||
| 
 | ||||
|     #print hr_bytes( $mycalc{'server_buffers'} ); | ||||
| 
 | ||||
|     infoprint "Total buffers: " | ||||
|       . hr_bytes( $mycalc{'server_buffers'} ) | ||||
|       . " global + " | ||||
|       . hr_bytes( $mycalc{'per_thread_buffers'} ) | ||||
|       . " per thread ($myvar{'max_connections'} max threads)"; | ||||
|     infoprint "P_S Max memory usage: " . hr_bytes_rnd( get_pf_memory() ); | ||||
|     $result{'P_S'}{'memory'} = get_other_process_memory(); | ||||
|     $result{'P_S'}{'memory'} = get_pf_memory(); | ||||
|     $result{'P_S'}{'pretty_memory'} = | ||||
|       hr_bytes_rnd( get_other_process_memory() ); | ||||
|       hr_bytes_rnd( get_pf_memory() ); | ||||
|     infoprint "Galera GCache Max memory usage: " | ||||
|       . hr_bytes_rnd( get_gcache_memory() ); | ||||
|     $result{'Galera'}{'GCache'}{'memory'} = get_gcache_memory(); | ||||
|  | @ -2901,12 +2920,14 @@ sub mysql_stats { | |||
| 
 | ||||
|     # Query cache | ||||
|     if ( !mysql_version_ge(4) ) { | ||||
| 
 | ||||
|         # MySQL versions < 4.01 don't support query caching | ||||
|         push( @generalrec, | ||||
|             "Upgrade MySQL to version 4+ to utilize query caching" ); | ||||
|     } | ||||
|     elsif ( mysql_version_eq(8) ) { | ||||
|         infoprint "Query cache have been removed in MySQL 8"; | ||||
| 
 | ||||
|         #return; | ||||
|     } | ||||
|     elsif ( $myvar{'query_cache_size'} < 1 | ||||
|  | @ -3081,7 +3102,8 @@ sub mysql_stats { | |||
|     else { | ||||
|         if ( $myvar{'thread_cache_size'} eq 0 ) { | ||||
|             badprint "Thread cache is disabled"; | ||||
|             push( @generalrec, "Set thread_cache_size to 4 as a starting value" ); | ||||
|             push( @generalrec, | ||||
|                 "Set thread_cache_size to 4 as a starting value" ); | ||||
|             push( @adjvars, "thread_cache_size (start at 4)" ); | ||||
|         } | ||||
|         else { | ||||
|  | @ -3134,7 +3156,8 @@ sub mysql_stats { | |||
|                   . " over 64: http://bit.ly/1mi7c4C" ); | ||||
|             push( @generalrec, | ||||
|                     "Read this before increasing for MariaDB" | ||||
|                   . " https://mariadb.com/kb/en/library/optimizing-table_open_cache/"); | ||||
|                   . " https://mariadb.com/kb/en/library/optimizing-table_open_cache/" | ||||
|             ); | ||||
|             push( @generalrec, | ||||
| "This is MyISAM only table_cache scalability problem, InnoDB not affected." | ||||
|             ); | ||||
|  | @ -5171,6 +5194,7 @@ sub mariadb_galera { | |||
|     } | ||||
|     infoprint "GCache is using " | ||||
|       . hr_bytes_rnd( get_wsrep_option('gcache.mem_size') ); | ||||
| 
 | ||||
|     #my @primaryKeysNbTables=(); | ||||
|     my @primaryKeysNbTables = select_array( | ||||
|         "Select CONCAT(c.table_schema,CONCAT('.', c.table_name)) | ||||
|  | @ -5182,7 +5206,6 @@ group by c.table_schema,c.table_name | |||
| having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | ||||
|     ); | ||||
| 
 | ||||
| 
 | ||||
|     infoprint "CPU core detected  : " . (cpu_cores); | ||||
|     infoprint "wsrep_slave_threads: " . get_wsrep_option('wsrep_slave_threads'); | ||||
|     if (   get_wsrep_option('wsrep_slave_threads') > ( (cpu_cores) * 4 ) | ||||
|  | @ -5740,13 +5763,15 @@ sub check_metadata_perf { | |||
|     if ( $myvar{'innodb_stats_on_metadata'} eq 'ON' ) { | ||||
|         badprint "Stat are updated during querying INFORMATION_SCHEMA."; | ||||
|         push @adjvars, "SET innodb_stats_on_metadata = OFF"; | ||||
| 
 | ||||
|         #Disabling innodb_stats_on_metadata | ||||
|         select_one("SET GLOBAL innodb_stats_on_metadata = OFF;"); | ||||
|         return 1; | ||||
|     } | ||||
|     goodprint "No stat updates during querying INFORMATION_SCHEMA."; | ||||
|     return 0  | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| # Recommendations for Database metrics | ||||
| sub mysql_databases { | ||||
|     return if ( $opt{dbstat} == 0 ); | ||||
|  | @ -6210,15 +6235,16 @@ sub dump_result { | |||
|         } | ||||
| 
 | ||||
|         my $json = JSON->new->allow_nonref; | ||||
|         print $json->utf8(1)->pretty( ( $opt{'prettyjson'} ? 1 : 0 ) )->encode( \%result ); | ||||
| 
 | ||||
|         print $json->utf8(1)->pretty( ( $opt{'prettyjson'} ? 1 : 0 ) ) | ||||
|           ->encode( \%result ); | ||||
| 
 | ||||
|         if ( $opt{'outputfile'} ne 0 ) { | ||||
|             unlink $opt{'outputfile'} if ( -e $opt{'outputfile'} ); | ||||
|             open my $fh, q(>), $opt{'outputfile'} | ||||
|               or die | ||||
| "Unable to open $opt{'outputfile'} in write mode. please check permissions for this file or directory"; | ||||
|               print $fh  $json->utf8(1)->pretty( ( $opt{'prettyjson'} ? 1 : 0 ) )->encode( \%result ); | ||||
|             print $fh $json->utf8(1)->pretty( ( $opt{'prettyjson'} ? 1 : 0 ) ) | ||||
|               ->encode( \%result ); | ||||
|             close $fh; | ||||
|         } | ||||
|     } | ||||
|  | @ -6273,6 +6299,7 @@ mysql_innodb;              # Print InnoDB stats | |||
| mariadb_ariadb;              # Print MariaDB AriaDB stats | ||||
| mariadb_tokudb;              # Print MariaDB Tokudb stats | ||||
| mariadb_xtradb;              # Print MariaDB XtraDB stats | ||||
| 
 | ||||
| #mariadb_rockdb;            # Print MariaDB RockDB stats | ||||
| #mariadb_spider;            # Print MariaDB Spider stats | ||||
| #mariadb_connect;           # Print MariaDB Connect stats | ||||
|  | @ -6295,7 +6322,7 @@ __END__ | |||
| 
 | ||||
| =head1 NAME | ||||
| 
 | ||||
|  MySQLTuner 1.7.13 - MySQL High Performance Tuning Script | ||||
|  MySQLTuner 1.7.14 - MySQL High Performance Tuning Script | ||||
| 
 | ||||
| =head1 IMPORTANT USAGE GUIDELINES | ||||
| 
 | ||||
|  | @ -6336,12 +6363,19 @@ You must provide the remote server's total memory when connecting to other serve | |||
|  --nobad                     Remove negative/suggestion responses | ||||
|  --noinfo                    Remove informational responses | ||||
|  --debug                     Print debug information | ||||
|  --noprocess                Consider no other process is running | ||||
|  --dbstat                    Print database information | ||||
|  --nodbstat                  Don't Print database information | ||||
|  --tbstat                    Print table information | ||||
|  --notbstat                  Don't Print table information | ||||
|  --idxstat                   Print index information | ||||
|  --noidxstat                 Don't Print index information | ||||
|  --sysstat                   Print system information | ||||
|  --nosysstat                 Don't Print system information | ||||
|  --pfstat                    Print Performance schema | ||||
|  --nopfstat                  Don't Print Performance schema | ||||
|  --verbose                   Prints out all options (default: no verbose, dbstat, idxstat, sysstat, tbstat, pfstat) | ||||
|    | ||||
|  --bannedports               Ports banned separated by comma(,) | ||||
|  --maxportallowed            Number of ports opened allowed on this hosts | ||||
|  --cvefile <path>            CVE File for vulnerability checks | ||||
|  | @ -6351,7 +6385,7 @@ You must provide the remote server's total memory when connecting to other serve | |||
|  --outputfile <path>         Path to a output txt file | ||||
|  --reportfile <path>         Path to a report txt file | ||||
|  --template   <path>         Path to a template file | ||||
|  --verbose                   Prints out all options (default: no verbose) | ||||
| 
 | ||||
| 
 | ||||
| =head1 PERLDOC | ||||
| 
 | ||||
|  | @ -6528,7 +6562,7 @@ L<https://github.com/major/MySQLTuner-perl> | |||
| 
 | ||||
| =head1 COPYRIGHT AND LICENSE | ||||
| 
 | ||||
| Copyright (C) 2006-2017 Major Hayden - major@mhtx.net | ||||
| Copyright (C) 2006-2018 Major Hayden - major@mhtx.net | ||||
| 
 | ||||
| For the latest updates, please visit http://mysqltuner.com/ | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Jean-Marie Renouard
						Jean-Marie Renouard