commit
						e0e2168f06
					
				
					 3 changed files with 186 additions and 119 deletions
				
			
		
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							|  | @ -15,3 +15,4 @@ golang/prog-* | ||||||
| test_db/** | test_db/** | ||||||
| result* | result* | ||||||
| result_* | result_* | ||||||
|  | sql/*.sql | ||||||
|  | @ -229,6 +229,12 @@ Of course, you can add the execute bit (`chmod +x mysqltuner.pl`) so you can exe | ||||||
| 
 | 
 | ||||||
| __Usage:__ Minimal usage remotely | __Usage:__ Minimal usage remotely | ||||||
| 
 | 
 | ||||||
|  | In previous version, --forcemem shoud be set manually, in order to be able to run an MT analysis | ||||||
|  | 
 | ||||||
|  | Since 2.1.10, memory and swap are defined to 1Gb by default. | ||||||
|  | 
 | ||||||
|  | If you want a more accurate value according to your remote server, feel free to setup --forcemem and --forceswap to real RAM value | ||||||
|  | 
 | ||||||
| ```bash | ```bash | ||||||
| perl mysqltuner.pl --host targetDNS_IP --user admin_user --pass admin_password | perl mysqltuner.pl --host targetDNS_IP --user admin_user --pass admin_password | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
							
								
								
									
										152
									
								
								mysqltuner.pl
									
									
									
									
									
								
							
							
						
						
									
										152
									
								
								mysqltuner.pl
									
									
									
									
									
								
							|  | @ -1,5 +1,5 @@ | ||||||
| #!/usr/bin/env perl | #!/usr/bin/env perl | ||||||
| # mysqltuner.pl - Version 2.1.9 | # mysqltuner.pl - Version 2.1.11 | ||||||
| # High Performance MySQL Tuning Script | # High Performance MySQL Tuning Script | ||||||
| # Copyright (C) 2006-2023 Major Hayden - major@mhtx.net | # Copyright (C) 2006-2023 Major Hayden - major@mhtx.net | ||||||
| # Copyright (C) 2015-2023 Jean-Marie Renouard - jmrenouard@gmail.com | # Copyright (C) 2015-2023 Jean-Marie Renouard - jmrenouard@gmail.com | ||||||
|  | @ -57,7 +57,7 @@ use Cwd 'abs_path'; | ||||||
| #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 = "2.1.9"; | my $tunerversion = "2.1.11"; | ||||||
| my ( @adjvars, @generalrec ); | my ( @adjvars, @generalrec ); | ||||||
| 
 | 
 | ||||||
| # Set defaults | # Set defaults | ||||||
|  | @ -69,8 +69,8 @@ my %opt = ( | ||||||
|     "debug"               => 0, |     "debug"               => 0, | ||||||
|     "nocolor"             => ( !-t STDOUT ), |     "nocolor"             => ( !-t STDOUT ), | ||||||
|     "color"               => 0, |     "color"               => 0, | ||||||
|     "forcemem"            => 0, |     "forcemem"            => 1024, | ||||||
|     "forceswap"           => 0, |     "forceswap"           => 1024, | ||||||
|     "host"                => 0, |     "host"                => 0, | ||||||
|     "socket"              => 0, |     "socket"              => 0, | ||||||
|     "port"                => 0, |     "port"                => 0, | ||||||
|  | @ -111,7 +111,9 @@ my %opt = ( | ||||||
|     "defaults-extra-file" => '', |     "defaults-extra-file" => '', | ||||||
|     "protocol"            => '', |     "protocol"            => '', | ||||||
|     "dumpdir"             => '', |     "dumpdir"             => '', | ||||||
|     "feature"             => '' |     "feature"             => '', | ||||||
|  |     "dbgpattern"          => '', | ||||||
|  |     "defaultarch"         => 64 | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| # Gather the options from the command line | # Gather the options from the command line | ||||||
|  | @ -144,7 +146,8 @@ GetOptions( | ||||||
|     'idxstat',               'noidxstat', |     'idxstat',               'noidxstat', | ||||||
|     'server-log=s',          'protocol=s', |     'server-log=s',          'protocol=s', | ||||||
|     'defaults-extra-file=s', 'dumpdir=s', |     'defaults-extra-file=s', 'dumpdir=s', | ||||||
|     'feature=s' |     'feature=s',             'dbgpattern=s', | ||||||
|  |     'defaultarch=i' | ||||||
|   ) |   ) | ||||||
|   or pod2usage( |   or pod2usage( | ||||||
|     -exitval  => 1, |     -exitval  => 1, | ||||||
|  | @ -200,6 +203,7 @@ if ( $opt{dumpdir} ne '' ) { | ||||||
| $basic_password_files = "/usr/share/mysqltuner/basic_passwords.txt" | $basic_password_files = "/usr/share/mysqltuner/basic_passwords.txt" | ||||||
|   unless -f "$basic_password_files"; |   unless -f "$basic_password_files"; | ||||||
| 
 | 
 | ||||||
|  | $opt{dbgpattern}='.*' if ($opt{dbgpattern} eq '' ); | ||||||
| # check if we need to enable verbose mode | # check if we need to enable verbose mode | ||||||
| if ( $opt{feature} ne '' ) { $opt{verbose} = 1; } | if ( $opt{feature} ne '' ) { $opt{verbose} = 1; } | ||||||
| if ( $opt{verbose} ) { | if ( $opt{verbose} ) { | ||||||
|  | @ -1261,12 +1265,18 @@ sub arr2hash { | ||||||
|     my $href = shift; |     my $href = shift; | ||||||
|     my $harr = shift; |     my $harr = shift; | ||||||
|     my $sep  = shift; |     my $sep  = shift; | ||||||
|  |     my $key=''; | ||||||
|  |     my $val=''; | ||||||
|  | 
 | ||||||
|     $sep = '\s' unless defined($sep); |     $sep = '\s' unless defined($sep); | ||||||
|     foreach my $line (@$harr) { |     foreach my $line (@$harr) { | ||||||
|         next if ( $line =~ m/^\*\*\*\*\*\*\*/ ); |         next if ( $line =~ m/^\*\*\*\*\*\*\*/ ); | ||||||
|         $line =~ /([a-zA-Z_]*)\s*$sep\s*(.*)/; |         $line =~ /([a-zA-Z_]*)\s*$sep\s*(.*)/; | ||||||
|         $$href{$1} = $2; |         $key = $1; | ||||||
|         debugprint "V: $1 = $2"; |         $val = $2; | ||||||
|  |         $$href{$key} = $val; | ||||||
|  |         | ||||||
|  |         debugprint " * $key = $val" if $key =~ /$opt{dbgpattern}/i; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -2422,6 +2432,8 @@ my ($arch); | ||||||
| sub check_architecture { | sub check_architecture { | ||||||
|     if ( is_remote eq 1 ) { |     if ( is_remote eq 1 ) { | ||||||
|         infoprint "Skipping architecture check on remote host"; |         infoprint "Skipping architecture check on remote host"; | ||||||
|  |         infoprint "Using default $opt{defaultarch} bits as target architecture"; | ||||||
|  |         $arch = $opt{defaultarch}; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     if ( `uname` =~ /SunOS/ && `isainfo -b` =~ /64/ ) { |     if ( `uname` =~ /SunOS/ && `isainfo -b` =~ /64/ ) { | ||||||
|  | @ -2563,6 +2575,7 @@ sub check_storage_engines { | ||||||
|             $result{'Engine'}{$engine}{'Data Size'}    = $dsize; |             $result{'Engine'}{$engine}{'Data Size'}    = $dsize; | ||||||
|             $result{'Engine'}{$engine}{'Index Size'}   = $isize; |             $result{'Engine'}{$engine}{'Index Size'}   = $isize; | ||||||
|         } |         } | ||||||
|  |         #print Dumper( \%enginestats ) if $opt{debug}; | ||||||
|         my $not_innodb = ''; |         my $not_innodb = ''; | ||||||
|         if ( not defined $result{'Variables'}{'innodb_file_per_table'} ) { |         if ( not defined $result{'Variables'}{'innodb_file_per_table'} ) { | ||||||
|             $not_innodb = "AND NOT ENGINE='InnoDB'"; |             $not_innodb = "AND NOT ENGINE='InnoDB'"; | ||||||
|  | @ -2607,7 +2620,7 @@ sub check_storage_engines { | ||||||
|         $fragtables = 0; |         $fragtables = 0; | ||||||
|         foreach my $tbl (@tblist) { |         foreach my $tbl (@tblist) { | ||||||
| 
 | 
 | ||||||
|             #debugprint "Data dump " . Dumper(@$tbl); |             #debugprint "Data dump " . Dumper(@$tbl) if $opt{debug}; | ||||||
|             my ( $engine, $size, $datafree ) = @$tbl; |             my ( $engine, $size, $datafree ) = @$tbl; | ||||||
|             next if $engine eq 'NULL' or not defined($engine); |             next if $engine eq 'NULL' or not defined($engine); | ||||||
|             $size     = 0 if $size eq 'NULL'     or not defined($size); |             $size     = 0 if $size eq 'NULL'     or not defined($size); | ||||||
|  | @ -3766,6 +3779,48 @@ sub mysql_stats { | ||||||
| # Recommendations for MyISAM | # Recommendations for MyISAM | ||||||
| sub mysql_myisam { | sub mysql_myisam { | ||||||
|     subheaderprint "MyISAM Metrics"; |     subheaderprint "MyISAM Metrics"; | ||||||
|  |     my $nb_myisam_tables = select_one( | ||||||
|  |         "SELECT COUNT(*) FROM information_schema.TABLES WHERE ENGINE='MyISAM' and TABLE_SCHEMA NOT IN ('mysql','information_schema','performance_schema')");     | ||||||
|  |     push (@generalrec, "MyISAM engine is deprecated, consider migrating to InnoDB") if $nb_myisam_tables > 0; | ||||||
|  |      | ||||||
|  |     if ($nb_myisam_tables > 0) { | ||||||
|  |       badprint "Consider migrating $nb_myisam_tables followning tables to InnoDB:"; | ||||||
|  |       my $sql_mig=""; | ||||||
|  |       for my $myisam_table ( select_array("SELECT CONCAT(TABLE_SCHEMA, '.', TABLE_NAME) FROM information_schema.TABLES WHERE ENGINE='MyISAM' and TABLE_SCHEMA NOT IN ('mysql','information_schema','performance_schema')" )) { | ||||||
|  |         $sql_mig="${sql_mig}-- InnoDB migration for $myisam_table\nALTER TABLE $myisam_table ENGINE=InnoDB;\n\n"; | ||||||
|  |         infoprint "* InnoDB migration request for $myisam_table Table: ALTER TABLE $myisam_table ENGINE=InnoDB;"; | ||||||
|  |       } | ||||||
|  |       if ( -d "$opt{dumpdir}" ) { | ||||||
|  |         my $file_mig="$opt{dumpdir}/migrate_myisam_to_innodb.sql"; | ||||||
|  |         open (FILE, ">$file_mig") or die "Can't open $file_mig: $!"; | ||||||
|  |         print FILE $sql_mig; | ||||||
|  |         close FILE; | ||||||
|  |         infoprint "Migration script saved to $file_mig"; | ||||||
|  |       } | ||||||
|  |     }   | ||||||
|  |     infoprint("General MyIsam metrics:"); | ||||||
|  |     infoprint " +-- Total MyISAM Tables  : $nb_myisam_tables"; | ||||||
|  |     infoprint " +-- Total MyISAM indexes : " | ||||||
|  |       . hr_bytes( $mycalc{'total_myisam_indexes'} ) if defined($mycalc{'total_myisam_indexes'}); | ||||||
|  |     infoprint " +-- KB Size :" . hr_bytes($myvar{'key_buffer_size'}); | ||||||
|  |     infoprint " +-- KB Used Size :" .hr_bytes( $myvar{'key_buffer_size'} - | ||||||
|  |               $mystat{'Key_blocks_unused'} * $myvar{'key_cache_block_size'} ); | ||||||
|  |     infoprint " +-- KB used :" . $mycalc{'pct_key_buffer_used'} . "%"; | ||||||
|  |     infoprint " +-- Read KB hit rate: $mycalc{'pct_keys_from_mem'}% (" | ||||||
|  |               . hr_num( $mystat{'Key_read_requests'} ) | ||||||
|  |               . " cached / " | ||||||
|  |               . hr_num( $mystat{'Key_reads'} ) | ||||||
|  |               . " reads)"; | ||||||
|  |     infoprint " +-- Write KB hit rate: $mycalc{'pct_wkeys_from_mem'}% (" | ||||||
|  |               . hr_num( $mystat{'Key_write_requests'} ) | ||||||
|  |               . " cached / " | ||||||
|  |               . hr_num( $mystat{'Key_writes'} ) | ||||||
|  |               . " writes)"; | ||||||
|  | 
 | ||||||
|  |     if ( $nb_myisam_tables == 0 ) { | ||||||
|  |         infoprint "No MyISAM table(s) detected ...."; | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|     if ( mysql_version_ge(8) and mysql_version_le(10) ) { |     if ( mysql_version_ge(8) and mysql_version_le(10) ) { | ||||||
|         infoprint "MyISAM Metrics are disabled since MySQL 8.0."; |         infoprint "MyISAM Metrics are disabled since MySQL 8.0."; | ||||||
|         if ( $myvar{'key_buffer_size'} > 0 ) { |         if ( $myvar{'key_buffer_size'} > 0 ) { | ||||||
|  | @ -3775,15 +3830,26 @@ sub mysql_myisam { | ||||||
|         } |         } | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     my $nb_myisam_tables = select_one( |      | ||||||
|         "SELECT COUNT(*) FROM information_schema.TABLES WHERE ENGINE='MyISAM'"); |     if ( !defined( $mycalc{'total_myisam_indexes'} ) ) { | ||||||
|     if ( $nb_myisam_tables == 0 ) { |         badprint "Unable to calculate MyISAM index size on MySQL server < 5.0.0"; | ||||||
|         infoprint "No MyISAM table(s) detected ...."; |         push( @generalrec, | ||||||
|  |             "Unable to calculate MyISAM index size on MySQL server < 5.0.0" ); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |     if ( $mycalc{'pct_key_buffer_used'} == 0 ) { | ||||||
|  |         # No queries have run that would use keys | ||||||
|  |         infoprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" | ||||||
|  |           . hr_bytes( $myvar{'key_buffer_size'} - | ||||||
|  |               $mystat{'Key_blocks_unused'} * $myvar{'key_cache_block_size'} ) | ||||||
|  |           . " used / " | ||||||
|  |           . hr_bytes( $myvar{'key_buffer_size'} ) | ||||||
|  |           . " cache)"; | ||||||
|  |         infoprint "No SQL statement based on MyISAM table(s) detected ...."; | ||||||
|  |         return | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     # Key buffer usage |     # Key buffer usage | ||||||
|     if ( $mycalc{'pct_key_buffer_used'} > 0 ) { |  | ||||||
|     if ( $mycalc{'pct_key_buffer_used'} < 90 ) { |     if ( $mycalc{'pct_key_buffer_used'} < 90 ) { | ||||||
|         badprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" |         badprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" | ||||||
|           . hr_bytes( $myvar{'key_buffer_size'} - |           . hr_bytes( $myvar{'key_buffer_size'} - | ||||||
|  | @ -3802,8 +3868,7 @@ sub mysql_myisam { | ||||||
|               ) |               ) | ||||||
|               . ")" |               . ")" | ||||||
|         ); |         ); | ||||||
|         } |     } else { | ||||||
|         else { |  | ||||||
|       goodprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" |       goodprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" | ||||||
|           . hr_bytes( $myvar{'key_buffer_size'} - |           . hr_bytes( $myvar{'key_buffer_size'} - | ||||||
|           $mystat{'Key_blocks_unused'} * $myvar{'key_cache_block_size'} |           $mystat{'Key_blocks_unused'} * $myvar{'key_cache_block_size'} | ||||||
|  | @ -3812,24 +3877,8 @@ sub mysql_myisam { | ||||||
|         . hr_bytes( $myvar{'key_buffer_size'} ) |         . hr_bytes( $myvar{'key_buffer_size'} ) | ||||||
|         . " cache)"; |         . " cache)"; | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|     else { |  | ||||||
| 
 | 
 | ||||||
|         # No queries have run that would use keys |     # Key buffer size / total MyISAM indexes | ||||||
|         debugprint "Key buffer used: $mycalc{'pct_key_buffer_used'}% (" |  | ||||||
|           . hr_bytes( $myvar{'key_buffer_size'} - |  | ||||||
|               $mystat{'Key_blocks_unused'} * $myvar{'key_cache_block_size'} ) |  | ||||||
|           . " used / " |  | ||||||
|           . hr_bytes( $myvar{'key_buffer_size'} ) |  | ||||||
|           . " cache)"; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     # Key buffer |  | ||||||
|     if ( !defined( $mycalc{'total_myisam_indexes'} ) ) { |  | ||||||
|         push( @generalrec, |  | ||||||
|             "Unable to calculate MyISAM index size on MySQL server < 5.0.0" ); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|     if (   $myvar{'key_buffer_size'} < $mycalc{'total_myisam_indexes'} |     if (   $myvar{'key_buffer_size'} < $mycalc{'total_myisam_indexes'} | ||||||
|         && $mycalc{'pct_keys_from_mem'} < 95 ) |         && $mycalc{'pct_keys_from_mem'} < 95 ) | ||||||
|     { |     { | ||||||
|  | @ -3864,13 +3913,11 @@ sub mysql_myisam { | ||||||
|               . " reads)"; |               . " reads)"; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|         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'} ) . "/" | ||||||
|       . hr_bytes( $mycalc{'total_myisam_indexes'} ) . ""; |       . hr_bytes( $mycalc{'total_myisam_indexes'} ) . ""; | ||||||
|         } |  | ||||||
|     if ( $mystat{'Key_write_requests'} > 0 ) { |     if ( $mystat{'Key_write_requests'} > 0 ) { | ||||||
|         if ( $mycalc{'pct_wkeys_from_mem'} < 95 ) { |         if ( $mycalc{'pct_wkeys_from_mem'} < 95 ) { | ||||||
|             badprint |             badprint | ||||||
|  | @ -3888,9 +3935,7 @@ sub mysql_myisam { | ||||||
|               . hr_num( $mystat{'Key_writes'} ) |               . hr_num( $mystat{'Key_writes'} ) | ||||||
|               . " writes)"; |               . " writes)"; | ||||||
|         } |         } | ||||||
|         } |     } 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'}% (" | ||||||
|  | @ -3900,7 +3945,6 @@ sub mysql_myisam { | ||||||
|         . " writes)"; |         . " writes)"; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| # Recommendations for ThreadPool | # Recommendations for ThreadPool | ||||||
| sub mariadb_threadpool { | sub mariadb_threadpool { | ||||||
|  | @ -5650,7 +5694,7 @@ sub get_wsrep_options { | ||||||
|     @galera_options = remove_cr @galera_options; |     @galera_options = remove_cr @galera_options; | ||||||
|     @galera_options = remove_empty @galera_options; |     @galera_options = remove_empty @galera_options; | ||||||
| 
 | 
 | ||||||
|     #debugprint Dumper( \@galera_options ); |     #debugprint Dumper( \@galera_options ) if $opt{debug}; | ||||||
|     return @galera_options; |     return @galera_options; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -5984,7 +6028,7 @@ having sum(if(c.column_key in ('PRI', 'UNI'), 1, 0)) = 0" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #debugprint Dumper get_wsrep_options(); |     #debugprint Dumper get_wsrep_options() if $opt{debug}; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| # Recommendations for InnoDB | # Recommendations for InnoDB | ||||||
|  | @ -6091,9 +6135,25 @@ sub mysql_innodb { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     # InnoDB Buffer Pool Size |     # InnoDB Buffer Pool Size | ||||||
|  |     if ($arch == 32 && $myvar{'innodb_buffer_pool_size'} > 4294967295) { | ||||||
|  |       badprint "InnoDb Buffer Pool size limit reached for 32 bits architecture: (". hr_bytes(4294967295)." )"; | ||||||
|  |       push( @adjvars, "limit innodb_buffer_pool_size under ".hr_bytes(4294967295)." for 32 bits architecture"); | ||||||
|  |     } | ||||||
|  |     if ($arch == 32 && $myvar{'innodb_buffer_pool_size'} < 4294967295) { | ||||||
|  |       goodprint "InnoDb Buffer Pool size ( " . hr_bytes($myvar{'innodb_buffer_pool_size'}). " ) under limit for 32 bits architecture: (". hr_bytes(4294967295 ).")"; | ||||||
|  |     } | ||||||
|  |     if ($arch == 64 && $myvar{'innodb_buffer_pool_size'} > 18446744073709551615 ) { | ||||||
|  |       badprint "InnoDb Buffer Pool size limit(". hr_bytes(18446744073709551615 ).") reached for 64 bits architecture"; | ||||||
|  |       push( @adjvars, "limit innodb_buffer_pool_size under ".hr_bytes(18446744073709551615)." for 64 bits architecture"); | ||||||
|  |     }  | ||||||
|  | 
 | ||||||
|  |     if ($arch == 64 && $myvar{'innodb_buffer_pool_size'} < 18446744073709551615 ) { | ||||||
|  |       goodprint "InnoDb Buffer Pool size ( " . hr_bytes($myvar{'innodb_buffer_pool_size'}). " ) under limit for 64 bits architecture: (". hr_bytes(18446744073709551615 )." )"; | ||||||
|  |     }  | ||||||
|     if ( $myvar{'innodb_buffer_pool_size'} > $enginestats{'InnoDB'} ) { |     if ( $myvar{'innodb_buffer_pool_size'} > $enginestats{'InnoDB'} ) { | ||||||
|         goodprint "InnoDB buffer pool / data size: " |         goodprint "InnoDB buffer pool / data size: " | ||||||
|           . hr_bytes( $myvar{'innodb_buffer_pool_size'} ) . " / " |           . hr_bytes( $myvar{' | ||||||
|  |           '} ) . " / " | ||||||
|           . hr_bytes( $enginestats{'InnoDB'} ) . ""; |           . hr_bytes( $enginestats{'InnoDB'} ) . ""; | ||||||
|     } else { |     } else { | ||||||
|         badprint "InnoDB buffer pool / data size: " |         badprint "InnoDB buffer pool / data size: " | ||||||
|  | @ -7041,7 +7101,8 @@ os_setup;                  # Set up some OS variables | ||||||
| get_all_vars;              # Toss variables/status into hashes | get_all_vars;              # Toss variables/status into hashes | ||||||
| get_tuning_info;           # Get information about the tuning connection | get_tuning_info;           # Get information about the tuning connection | ||||||
| calculations;              # Calculate everything we need | calculations;              # Calculate everything we need | ||||||
| 
 | check_architecture;        # Suggest 64-bit upgrade | ||||||
|  | check_storage_engines;     # Show enabled storage engines | ||||||
| if ( $opt{'feature'} ne '' ) { | if ( $opt{'feature'} ne '' ) { | ||||||
|     subheaderprint "See FEATURES.md for more information"; |     subheaderprint "See FEATURES.md for more information"; | ||||||
|     no strict 'refs'; |     no strict 'refs'; | ||||||
|  | @ -7049,14 +7110,13 @@ if ( $opt{'feature'} ne '' ) { | ||||||
|         subheaderprint "Running feature: $opt{'feature'}"; |         subheaderprint "Running feature: $opt{'feature'}"; | ||||||
|         $feature->(); |         $feature->(); | ||||||
|     } |     } | ||||||
|  |     make_recommendations; | ||||||
|     exit(0); |     exit(0); | ||||||
| } | } | ||||||
| validate_mysql_version;    # Check current MySQL version | validate_mysql_version;    # Check current MySQL version | ||||||
| 
 | 
 | ||||||
| check_architecture;        # Suggest 64-bit upgrade |  | ||||||
| system_recommendations;    # Avoid too many services on the same host | system_recommendations;    # Avoid too many services on the same host | ||||||
| log_file_recommendations;  # check log file content | log_file_recommendations;  # check log file content | ||||||
| check_storage_engines;     # Show enabled storage engines |  | ||||||
| 
 | 
 | ||||||
| check_metadata_perf;    # Show parameter impacting performance during analysis | check_metadata_perf;    # Show parameter impacting performance during analysis | ||||||
| mysql_databases;        # Show information about databases | mysql_databases;        # Show information about databases | ||||||
|  | @ -7101,7 +7161,7 @@ __END__ | ||||||
| 
 | 
 | ||||||
| =head1 NAME | =head1 NAME | ||||||
| 
 | 
 | ||||||
|  MySQLTuner 2.1.9 - MySQL High Performance Tuning Script |  MySQLTuner 2.1.11 - MySQL High Performance Tuning Script | ||||||
| 
 | 
 | ||||||
| =head1 IMPORTANT USAGE GUIDELINES | =head1 IMPORTANT USAGE GUIDELINES | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Jean-Marie Renouard
						Jean-Marie Renouard