Missing argument requirement for cvefile in mysqltuner help #321
Schedule for releases on github #320
This commit is contained in:
		
							parent
							
								
									da858bd936
								
							
						
					
					
						commit
						f180eae082
					
				
					 2 changed files with 84 additions and 57 deletions
				
			
		
							
								
								
									
										6
									
								
								USAGE.md
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								USAGE.md
									
									
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| # NAME | # NAME | ||||||
| 
 | 
 | ||||||
|     MySQLTuner 1.7.0 - MySQL High Performance Tuning Script |     MySQLTuner 1.7.2 - MySQL High Performance Tuning Script | ||||||
| 
 | 
 | ||||||
| # IMPORTANT USAGE GUIDELINES | # IMPORTANT USAGE GUIDELINES | ||||||
| 
 | 
 | ||||||
|  | @ -45,7 +45,7 @@ You must provide the remote server's total memory when connecting to other serve | ||||||
|     --pfstat                    Print Performance schema |     --pfstat                    Print Performance schema | ||||||
|     --bannedports               Ports banned separated by comma(,) |     --bannedports               Ports banned separated by comma(,) | ||||||
|     --maxportallowed            Number of ports opened allowed on this hosts |     --maxportallowed            Number of ports opened allowed on this hosts | ||||||
|     --cvefile                   CVE File for vulnerability checks |     --cvefile <path>            CVE File for vulnerability checks | ||||||
|     --nocolor                   Don't print output in color |     --nocolor                   Don't print output in color | ||||||
|     --json                      Print result as JSON string |     --json                      Print result as JSON string | ||||||
|     --buffers                   Print global and per-thread buffer values |     --buffers                   Print global and per-thread buffer values | ||||||
|  | @ -122,7 +122,7 @@ Maintained by Major Hayden (major\\@mhtx.net) - Licensed under GPL | ||||||
| 
 | 
 | ||||||
| # COPYRIGHT AND LICENSE | # COPYRIGHT AND LICENSE | ||||||
| 
 | 
 | ||||||
| Copyright (C) 2006-2015 Major Hayden - major@mhtx.net | Copyright (C) 2006-2017 Major Hayden - major@mhtx.net | ||||||
| 
 | 
 | ||||||
| For the latest updates, please visit http://mysqltuner.com/ | For the latest updates, please visit http://mysqltuner.com/ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										135
									
								
								mysqltuner.pl
									
									
									
									
									
								
							
							
						
						
									
										135
									
								
								mysqltuner.pl
									
									
									
									
									
								
							|  | @ -1,5 +1,5 @@ | ||||||
| #!/usr/bin/env perl | #!/usr/bin/env perl | ||||||
| # mysqltuner.pl - Version 1.7.1 | # mysqltuner.pl - Version 1.7.2 | ||||||
| # High Performance MySQL Tuning Script | # High Performance MySQL Tuning Script | ||||||
| # Copyright (C) 2006-2017 Major Hayden - major@mhtx.net | # Copyright (C) 2006-2017 Major Hayden - major@mhtx.net | ||||||
| # | # | ||||||
|  | @ -55,7 +55,7 @@ $Data::Dumper::Pair = " : "; | ||||||
| #use Env; | #use Env; | ||||||
| 
 | 
 | ||||||
| # Set up a few variables for use in the script | # Set up a few variables for use in the script | ||||||
| my $tunerversion = "1.7.1"; | my $tunerversion = "1.7.2"; | ||||||
| my ( @adjvars, @generalrec ); | my ( @adjvars, @generalrec ); | ||||||
| 
 | 
 | ||||||
| # Set defaults | # Set defaults | ||||||
|  | @ -174,7 +174,7 @@ sub usage { | ||||||
|       . "      --pfstat             Print Performance schema information\n" |       . "      --pfstat             Print Performance schema information\n" | ||||||
|       . "      --bannedports        Ports banned separated by comma(,)\n" |       . "      --bannedports        Ports banned separated by comma(,)\n" | ||||||
|       . "      --maxportallowed     Number of ports opened allowed on this hosts\n" |       . "      --maxportallowed     Number of ports opened allowed on this hosts\n" | ||||||
|       . "      --cvefile            CVE File for vulnerability checks\n" |       . "      --cvefile <path>     CVE File for vulnerability checks\n" | ||||||
|       . "      --nocolor            Don't print output in color\n" |       . "      --nocolor            Don't print output in color\n" | ||||||
|       . "      --json               Print result as JSON string\n" |       . "      --json               Print result as JSON string\n" | ||||||
|       . "      --prettyjson         Print result as human readable JSON\n" |       . "      --prettyjson         Print result as human readable JSON\n" | ||||||
|  | @ -300,9 +300,10 @@ sub infoprinthcmd { | ||||||
|     infoprintcmd "$_[1]"; |     infoprintcmd "$_[1]"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| # Calculates the number of phyiscal cores considering HyperThreading  | # Calculates the number of phyiscal cores considering HyperThreading | ||||||
| sub cpu_cores { | sub cpu_cores { | ||||||
|     my $cntCPU = `awk -F: '/^core id/ && !P[\$2] { CORES++; P[\$2]=1 }; /^physical id/ && !N[\$2] { CPUs++; N[\$2]=1 };  END { print CPUs*CORES }' /proc/cpuinfo`; |     my $cntCPU = | ||||||
|  | `awk -F: '/^core id/ && !P[\$2] { CORES++; P[\$2]=1 }; /^physical id/ && !N[\$2] { CPUs++; N[\$2]=1 };  END { print CPUs*CORES }' /proc/cpuinfo`; | ||||||
|     return ( $cntCPU == 0 ? `nproc` : $cntCPU ); |     return ( $cntCPU == 0 ? `nproc` : $cntCPU ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -537,7 +538,8 @@ sub validate_tuner_version { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     my $update; |     my $update; | ||||||
|     my $url = "https://raw.githubusercontent.com/major/MySQLTuner-perl/master/mysqltuner.pl"; |     my $url = | ||||||
|  | "https://raw.githubusercontent.com/major/MySQLTuner-perl/master/mysqltuner.pl"; | ||||||
|     my $httpcli = get_http_cli(); |     my $httpcli = get_http_cli(); | ||||||
|     if ( $httpcli =~ /curl$/ ) { |     if ( $httpcli =~ /curl$/ ) { | ||||||
|         debugprint "$httpcli is available."; |         debugprint "$httpcli is available."; | ||||||
|  | @ -612,9 +614,9 @@ sub update_tuner_version { | ||||||
|             debugprint "$httpcli is available."; |             debugprint "$httpcli is available."; | ||||||
| 
 | 
 | ||||||
|             debugprint |             debugprint | ||||||
|               "$httpcli -qe timestamping=off -t 1 -T 3 -O $script '$url$script'"; | "$httpcli -qe timestamping=off -t 1 -T 3 -O $script '$url$script'"; | ||||||
|             $update = |             $update = | ||||||
|               `$httpcli -qe timestamping=off -t 1 -T 3 -O $script '$url$script'`; | `$httpcli -qe timestamping=off -t 1 -T 3 -O $script '$url$script'`; | ||||||
|             chomp($update); |             chomp($update); | ||||||
| 
 | 
 | ||||||
|             if ( -s $script eq 0 ) { |             if ( -s $script eq 0 ) { | ||||||
|  | @ -721,7 +723,7 @@ sub mysql_setup { | ||||||
|     if ( $opt{socket} ne 0 ) { |     if ( $opt{socket} ne 0 ) { | ||||||
|         $remotestring = " -S $opt{socket} -P $opt{port}"; |         $remotestring = " -S $opt{socket} -P $opt{port}"; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     # Are we being asked to connect to a remote server? |     # Are we being asked to connect to a remote server? | ||||||
|     if ( $opt{host} ne 0 ) { |     if ( $opt{host} ne 0 ) { | ||||||
|         chomp( $opt{host} ); |         chomp( $opt{host} ); | ||||||
|  | @ -739,8 +741,9 @@ sub mysql_setup { | ||||||
|         if ( ( $opt{host} ne "127.0.0.1" ) && ( $opt{host} ne "localhost" ) ) { |         if ( ( $opt{host} ne "127.0.0.1" ) && ( $opt{host} ne "localhost" ) ) { | ||||||
|             $doremote = 1; |             $doremote = 1; | ||||||
|         } |         } | ||||||
|     } else { |     } | ||||||
|       $opt{host}='127.0.0.1'; |     else { | ||||||
|  |         $opt{host} = '127.0.0.1'; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     # Did we already get a username without password on the command line? |     # Did we already get a username without password on the command line? | ||||||
|  | @ -869,6 +872,7 @@ sub mysql_setup { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|  | 
 | ||||||
|         # It's not Plesk or debian, we should try a login |         # It's not Plesk or debian, we should try a login | ||||||
|         debugprint "$mysqladmincmd $remotestring ping 2>&1"; |         debugprint "$mysqladmincmd $remotestring ping 2>&1"; | ||||||
|         my $loginstatus = `$mysqladmincmd $remotestring ping 2>&1`; |         my $loginstatus = `$mysqladmincmd $remotestring ping 2>&1`; | ||||||
|  | @ -1467,7 +1471,8 @@ sub get_kernel_info { | ||||||
|         badprint |         badprint | ||||||
|           "Swappiness is > 10, please consider having a value lower than 10"; |           "Swappiness is > 10, please consider having a value lower than 10"; | ||||||
|         push @generalrec, "setup swappiness lower or equals to 10"; |         push @generalrec, "setup swappiness lower or equals to 10"; | ||||||
|         push @adjvars, 'vm.swappiness <= 10 (echo 10 > /proc/sys/vm/swappiness)'; |         push @adjvars, | ||||||
|  |           'vm.swappiness <= 10 (echo 10 > /proc/sys/vm/swappiness)'; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         infoprint "Swappiness is < 10."; |         infoprint "Swappiness is < 10."; | ||||||
|  | @ -1822,7 +1827,7 @@ sub get_replication_status { | ||||||
|           "This replication slave is not running but seems to be configured."; |           "This replication slave is not running but seems to be configured."; | ||||||
|     } |     } | ||||||
|     if (   defined($io_running) |     if (   defined($io_running) | ||||||
|         && $io_running =~ /yes/i |         && $io_running  =~ /yes/i | ||||||
|         && $sql_running =~ /yes/i ) |         && $sql_running =~ /yes/i ) | ||||||
|     { |     { | ||||||
|         if ( $myvar{'read_only'} eq 'OFF' ) { |         if ( $myvar{'read_only'} eq 'OFF' ) { | ||||||
|  | @ -2088,7 +2093,7 @@ sub check_storage_engines { | ||||||
|             debugprint "Data dump " . Dumper(@$tbl); |             debugprint "Data dump " . Dumper(@$tbl); | ||||||
|             my ( $engine, $size, $datafree ) = @$tbl; |             my ( $engine, $size, $datafree ) = @$tbl; | ||||||
|             next if $engine eq 'NULL'; |             next if $engine eq 'NULL'; | ||||||
|             $size     = 0 if $size eq 'NULL'; |             $size     = 0 if $size     eq 'NULL'; | ||||||
|             $datafree = 0 if $datafree eq 'NULL'; |             $datafree = 0 if $datafree eq 'NULL'; | ||||||
|             if ( defined $enginestats{$engine} ) { |             if ( defined $enginestats{$engine} ) { | ||||||
|                 $enginestats{$engine} += $size; |                 $enginestats{$engine} += $size; | ||||||
|  | @ -2325,7 +2330,7 @@ sub calculations { | ||||||
|                           $myvar{'key_cache_block_size'} |                           $myvar{'key_cache_block_size'} | ||||||
|                     ) / $myvar{'key_buffer_size'} |                     ) / $myvar{'key_buffer_size'} | ||||||
|                 ) |                 ) | ||||||
|             ) * 100 |               ) * 100 | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|  | @ -2366,8 +2371,9 @@ sub calculations { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if ( $mystat{'Key_write_requests'} > 0 ) { |     if ( $mystat{'Key_write_requests'} > 0 ) { | ||||||
|         $mycalc{'pct_wkeys_from_mem'} = sprintf( |         $mycalc{'pct_wkeys_from_mem'} = sprintf( "%.1f", | ||||||
|             "%.1f",( ($mystat{'Key_writes'} / $mystat{'Key_write_requests'} ) * 100 ) ); |             ( ( $mystat{'Key_writes'} / $mystat{'Key_write_requests'} ) * 100 ) | ||||||
|  |         ); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         $mycalc{'pct_wkeys_from_mem'} = 0; |         $mycalc{'pct_wkeys_from_mem'} = 0; | ||||||
|  | @ -2411,14 +2417,14 @@ sub calculations { | ||||||
|             ( |             ( | ||||||
|                 $mystat{'Qcache_hits'} / |                 $mystat{'Qcache_hits'} / | ||||||
|                   ( $mystat{'Com_select'} + $mystat{'Qcache_hits'} ) |                   ( $mystat{'Com_select'} + $mystat{'Qcache_hits'} ) | ||||||
|             ) * 100 |               ) * 100 | ||||||
|         ); |         ); | ||||||
|         if ( $myvar{'query_cache_size'} ) { |         if ( $myvar{'query_cache_size'} ) { | ||||||
|             $mycalc{'pct_query_cache_used'} = sprintf( |             $mycalc{'pct_query_cache_used'} = sprintf( | ||||||
|                 "%.1f", |                 "%.1f", | ||||||
|                 100 - ( |                 100 - ( | ||||||
|                     $mystat{'Qcache_free_memory'} / $myvar{'query_cache_size'} |                     $mystat{'Qcache_free_memory'} / $myvar{'query_cache_size'} | ||||||
|                 ) * 100 |                   ) * 100 | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         if ( $mystat{'Qcache_lowmem_prunes'} == 0 ) { |         if ( $mystat{'Qcache_lowmem_prunes'} == 0 ) { | ||||||
|  | @ -2643,7 +2649,7 @@ sub mysql_stats { | ||||||
| 
 | 
 | ||||||
|         if ( defined $myvar{'query_cache_type'} ) { |         if ( defined $myvar{'query_cache_type'} ) { | ||||||
|             infoprint "Query Cache Buffers"; |             infoprint "Query Cache Buffers"; | ||||||
|             infoprint " +-- Query Cache: " |             infoprint " +-- Query Cache: "  | ||||||
|               . $myvar{'query_cache_type'} . " - " |               . $myvar{'query_cache_type'} . " - " | ||||||
|               . ( |               . ( | ||||||
|                 $myvar{'query_cache_type'} eq 0 | |                 $myvar{'query_cache_type'} eq 0 | | ||||||
|  | @ -3146,6 +3152,7 @@ sub mysql_myisam { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|  | 
 | ||||||
|         # No queries have run that would use keys |         # No queries have run that would use keys | ||||||
|         debugprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" |         debugprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" | ||||||
|           . hr_num( |           . hr_num( | ||||||
|  | @ -3205,6 +3212,7 @@ sub mysql_myisam { | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|  | 
 | ||||||
|             # No queries have run that would use keys |             # No queries have run that would use keys | ||||||
|             debugprint "Key buffer size / total MyISAM indexes: " |             debugprint "Key buffer size / total MyISAM indexes: " | ||||||
|               . hr_bytes( $myvar{'key_buffer_size'} ) . "/" |               . hr_bytes( $myvar{'key_buffer_size'} ) . "/" | ||||||
|  | @ -3229,6 +3237,7 @@ sub mysql_myisam { | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|  | 
 | ||||||
|             # No queries have run that would use keys |             # No queries have run that would use keys | ||||||
|             debugprint |             debugprint | ||||||
|               "Write Key buffer hit rate: $mycalc{'pct_wkeys_from_mem'}% (" |               "Write Key buffer hit rate: $mycalc{'pct_wkeys_from_mem'}% (" | ||||||
|  | @ -5039,11 +5048,11 @@ group by c.table_schema,c.table_name | ||||||
| having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|     if (   get_wsrep_option('wsrep_slave_threads') > cpu_cores * 4 |     if (   get_wsrep_option('wsrep_slave_threads') > cpu_cores *4 | ||||||
|         or get_wsrep_option('wsrep_slave_threads') < cpu_cores * 3 ) |         or get_wsrep_option('wsrep_slave_threads') < cpu_cores *3 ) | ||||||
|     { |     { | ||||||
|         badprint |         badprint | ||||||
|           "wsrep_slave_threads is not equal to 2, 3 or 4 times number of CPU(s)"; | "wsrep_slave_threads is not equal to 2, 3 or 4 times number of CPU(s)"; | ||||||
|         push @adjvars, "wsrep_slave_threads= Nb of Core CPU * 4"; |         push @adjvars, "wsrep_slave_threads= Nb of Core CPU * 4"; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|  | @ -5056,43 +5065,55 @@ having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | ||||||
|     { |     { | ||||||
|         badprint "gcs.limit should be equal to 5 * wsrep_slave_threads"; |         badprint "gcs.limit should be equal to 5 * wsrep_slave_threads"; | ||||||
|         push @adjvars, "gcs.limit= wsrep_slave_threads * 5"; |         push @adjvars, "gcs.limit= wsrep_slave_threads * 5"; | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "gcs.limit should be equal to 5 * wsrep_slave_threads"; |         goodprint "gcs.limit should be equal to 5 * wsrep_slave_threads"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (get_wsrep_option('wsrep_slave_threads') > 1) { |     if ( get_wsrep_option('wsrep_slave_threads') > 1 ) { | ||||||
|         infoprint "wsrep parallel slave can cause frequent inconsistency crash."; |         infoprint | ||||||
|         push @adjvars, "Set wsrep_slave_threads to 1 in case of HA_ERR_FOUND_DUPP_KEY crash on slave"; |           "wsrep parallel slave can cause frequent inconsistency crash."; | ||||||
|  |         push @adjvars, | ||||||
|  | "Set wsrep_slave_threads to 1 in case of HA_ERR_FOUND_DUPP_KEY crash on slave"; | ||||||
|  | 
 | ||||||
|         # check options for parallel slave |         # check options for parallel slave | ||||||
|         if (get_wsrep_option('wsrep_slave_FK_checks') eq "OFF") { |         if ( get_wsrep_option('wsrep_slave_FK_checks') eq "OFF" ) { | ||||||
|             badprint "wsrep_slave_FK_checks is off with parallel slave"; |             badprint "wsrep_slave_FK_checks is off with parallel slave"; | ||||||
|             push @adjvars, "wsrep_slave_FK_checks should be ON when using parallel slave"; |             push @adjvars, | ||||||
|  |               "wsrep_slave_FK_checks should be ON when using parallel slave"; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         # wsrep_slave_UK_checks seems useless in MySQL source code |         # wsrep_slave_UK_checks seems useless in MySQL source code | ||||||
|         if ($myvar{'innodb_autoinc_lock_mode'} != 2) { |         if ( $myvar{'innodb_autoinc_lock_mode'} != 2 ) { | ||||||
|             badprint "innodb_autoinc_lock_mode is incorrect with parallel slave"; |             badprint | ||||||
|             push @adjvars, "innodb_autoinc_lock_mode should be 2 when using parallel slave"; |               "innodb_autoinc_lock_mode is incorrect with parallel slave"; | ||||||
|  |             push @adjvars, | ||||||
|  |               "innodb_autoinc_lock_mode should be 2 when using parallel slave"; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     if (get_wsrep_option('gcs.fc_limit') != $myvar{'wsrep_slave_threads'} * 5 ) { |     if ( get_wsrep_option('gcs.fc_limit') != $myvar{'wsrep_slave_threads'} * 5 ) | ||||||
|  |     { | ||||||
|         badprint "gcs.fc_limit should be equal to 5 * wsrep_slave_threads"; |         badprint "gcs.fc_limit should be equal to 5 * wsrep_slave_threads"; | ||||||
|         push @adjvars, "gcs.fc_limit= wsrep_slave_threads * 5"; |         push @adjvars, "gcs.fc_limit= wsrep_slave_threads * 5"; | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "gcs.fc_limit is equal to 5 * wsrep_slave_threads"; |         goodprint "gcs.fc_limit is equal to 5 * wsrep_slave_threads"; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     if (get_wsrep_option('gcs.fc_factor') != 0.8 ) { |     if ( get_wsrep_option('gcs.fc_factor') != 0.8 ) { | ||||||
|         badprint "gcs.fc_factor should be equal to 0.8"; |         badprint "gcs.fc_factor should be equal to 0.8"; | ||||||
|         push @adjvars, "gcs.fc_factor=0.8"; |         push @adjvars, "gcs.fc_factor=0.8"; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         goodprint "gcs.fc_factor is equal to 0.8"; |         goodprint "gcs.fc_factor is equal to 0.8"; | ||||||
|     } |     } | ||||||
|    if ( get_wsrep_option('wsrep_flow_control_paused') > 0.02 ) { |     if ( get_wsrep_option('wsrep_flow_control_paused') > 0.02 ) { | ||||||
|         badprint "Fraction of time node pause flow control > 0.02"; |         badprint "Fraction of time node pause flow control > 0.02"; | ||||||
|     } else { |     } | ||||||
|         goodprint "Flow control fraction seems to be OK (wsrep_flow_control_paused<=0.02)"; |     else { | ||||||
|  |         goodprint | ||||||
|  | "Flow control fraction seems to be OK (wsrep_flow_control_paused<=0.02)"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if ( scalar(@primaryKeysNbTables) > 0 ) { |     if ( scalar(@primaryKeysNbTables) > 0 ) { | ||||||
|  | @ -5101,7 +5122,8 @@ having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | ||||||
|             badprint "\t$badtable"; |             badprint "\t$badtable"; | ||||||
|             push @{ $result{'Tables without PK'} }, $badtable; |             push @{ $result{'Tables without PK'} }, $badtable; | ||||||
|         } |         } | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "All tables get a primary key"; |         goodprint "All tables get a primary key"; | ||||||
|     } |     } | ||||||
|     my @nonInnoDBTables = select_array( |     my @nonInnoDBTables = select_array( | ||||||
|  | @ -5114,19 +5136,22 @@ having sum(if(c.column_key in ('PRI','UNI'), 1,0)) = 0" | ||||||
|         foreach my $badtable (@nonInnoDBTables) { |         foreach my $badtable (@nonInnoDBTables) { | ||||||
|             badprint "\t$badtable"; |             badprint "\t$badtable"; | ||||||
|         } |         } | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "All tables are InnoDB tables"; |         goodprint "All tables are InnoDB tables"; | ||||||
|     } |     } | ||||||
|     if ( $myvar{'binlog_format'} ne 'ROW' ) { |     if ( $myvar{'binlog_format'} ne 'ROW' ) { | ||||||
|         badprint "Binlog format should be in ROW mode."; |         badprint "Binlog format should be in ROW mode."; | ||||||
|         push @adjvars, "binlog_format = ROW"; |         push @adjvars, "binlog_format = ROW"; | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "Binlog format is in ROW mode."; |         goodprint "Binlog format is in ROW mode."; | ||||||
|     } |     } | ||||||
|     if ( $myvar{'innodb_flush_log_at_trx_commit'} != 0 ) { |     if ( $myvar{'innodb_flush_log_at_trx_commit'} != 0 ) { | ||||||
|         badprint "InnoDB flush log at each commit should be disabled."; |         badprint "InnoDB flush log at each commit should be disabled."; | ||||||
|         push @adjvars, "innodb_flush_log_at_trx_commit = 0"; |         push @adjvars, "innodb_flush_log_at_trx_commit = 0"; | ||||||
|     } else { |     } | ||||||
|  |     else { | ||||||
|         goodprint "InnoDB flush log at each commit is disabled for Galera."; |         goodprint "InnoDB flush log at each commit is disabled for Galera."; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -5815,13 +5840,13 @@ ENDSQL | ||||||
|         infoprint " +-- TYPE        : " . $info[6]; |         infoprint " +-- TYPE        : " . $info[6]; | ||||||
|         infoprint " +-- SELECTIVITY : " . $info[7] . "%"; |         infoprint " +-- SELECTIVITY : " . $info[7] . "%"; | ||||||
| 
 | 
 | ||||||
|         $result{'Indexes'}{ $info[1] }{'Column'}            = $info[0]; |         $result{'Indexes'}{ $info[1] }{'Column'}           = $info[0]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Sequence number'}   = $info[2]; |         $result{'Indexes'}{ $info[1] }{'Sequence number'}  = $info[2]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Number of column'}  = $info[3]; |         $result{'Indexes'}{ $info[1] }{'Number of column'} = $info[3]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Cardinality'}       = $info[4]; |         $result{'Indexes'}{ $info[1] }{'Cardinality'}      = $info[4]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Row number'}        = $info[5]; |         $result{'Indexes'}{ $info[1] }{'Row number'}       = $info[5]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Index Type'}        = $info[6]; |         $result{'Indexes'}{ $info[1] }{'Index Type'}       = $info[6]; | ||||||
|         $result{'Indexes'}{ $info[1] }{'Selectivity'}       = $info[7]; |         $result{'Indexes'}{ $info[1] }{'Selectivity'}      = $info[7]; | ||||||
|         if ( $info[7] < 25 ) { |         if ( $info[7] < 25 ) { | ||||||
|             badprint "$info[1] has a low selectivity"; |             badprint "$info[1] has a low selectivity"; | ||||||
|         } |         } | ||||||
|  | @ -5917,6 +5942,7 @@ if ( $opt{'template'} ne 0 ) { | ||||||
|     $templateModel = file2string( $opt{'template'} ); |     $templateModel = file2string( $opt{'template'} ); | ||||||
| } | } | ||||||
| else { | else { | ||||||
|  | 
 | ||||||
|     # DEFAULT REPORT TEMPLATE |     # DEFAULT REPORT TEMPLATE | ||||||
|     $templateModel = <<'END_TEMPLATE'; |     $templateModel = <<'END_TEMPLATE'; | ||||||
| <!DOCTYPE html> | <!DOCTYPE html> | ||||||
|  | @ -6037,13 +6063,14 @@ close_outputfile;          # Close reportfile if needed | ||||||
| 1; | 1; | ||||||
| 
 | 
 | ||||||
| __END__ | __END__ | ||||||
|  | 
 | ||||||
| =pod | =pod | ||||||
| 
 | 
 | ||||||
| =encoding UTF-8 | =encoding UTF-8 | ||||||
| 
 | 
 | ||||||
| =head1 NAME | =head1 NAME | ||||||
| 
 | 
 | ||||||
|  MySQLTuner 1.7.1 - MySQL High Performance Tuning Script |  MySQLTuner 1.7.2 - MySQL High Performance Tuning Script | ||||||
| 
 | 
 | ||||||
| =head1 IMPORTANT USAGE GUIDELINES | =head1 IMPORTANT USAGE GUIDELINES | ||||||
| 
 | 
 | ||||||
|  | @ -6088,7 +6115,7 @@ You must provide the remote server's total memory when connecting to other serve | ||||||
|  --pfstat                    Print Performance schema |  --pfstat                    Print Performance schema | ||||||
|  --bannedports               Ports banned separated by comma(,) |  --bannedports               Ports banned separated by comma(,) | ||||||
|  --maxportallowed            Number of ports opened allowed on this hosts |  --maxportallowed            Number of ports opened allowed on this hosts | ||||||
|  --cvefile                   CVE File for vulnerability checks |  --cvefile <path>            CVE File for vulnerability checks | ||||||
|  --nocolor                   Don't print output in color |  --nocolor                   Don't print output in color | ||||||
|  --json                      Print result as JSON string |  --json                      Print result as JSON string | ||||||
|  --buffers                   Print global and per-thread buffer values |  --buffers                   Print global and per-thread buffer values | ||||||
|  | @ -6271,7 +6298,7 @@ L<https://github.com/major/MySQLTuner-perl> | ||||||
| 
 | 
 | ||||||
| =head1 COPYRIGHT AND LICENSE | =head1 COPYRIGHT AND LICENSE | ||||||
| 
 | 
 | ||||||
| Copyright (C) 2006-2015 Major Hayden - major@mhtx.net | Copyright (C) 2006-2017 Major Hayden - major@mhtx.net | ||||||
| 
 | 
 | ||||||
| For the latest updates, please visit http://mysqltuner.com/ | For the latest updates, please visit http://mysqltuner.com/ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Jean-Marie RENOUARD
						Jean-Marie RENOUARD