Update Vulnerabilities list
Indenting mysqltuner Update Usage information
This commit is contained in:
		
							parent
							
								
									10e5cb16f6
								
							
						
					
					
						commit
						60df6043b1
					
				
					 2 changed files with 175 additions and 18 deletions
				
			
		
							
								
								
									
										153
									
								
								USAGE.md
									
									
									
									
									
								
							
							
						
						
									
										153
									
								
								USAGE.md
									
									
									
									
									
								
							|  | @ -0,0 +1,153 @@ | ||||||
|  | # NAME | ||||||
|  | 
 | ||||||
|  |     MySQLTuner 1.7.15 - MySQL High Performance Tuning Script | ||||||
|  | 
 | ||||||
|  | # IMPORTANT USAGE GUIDELINES | ||||||
|  | 
 | ||||||
|  | To run the script with the default options, run the script without arguments | ||||||
|  | Allow MySQL server to run for at least 24-48 hours before trusting suggestions | ||||||
|  | Some routines may require root level privileges (script will provide warnings) | ||||||
|  | You must provide the remote server's total memory when connecting to other servers | ||||||
|  | 
 | ||||||
|  | # CONNECTION AND AUTHENTICATION | ||||||
|  | 
 | ||||||
|  |     --host <hostname>           Connect to a remote host to perform tests (default: localhost) | ||||||
|  |     --socket <socket>           Use a different socket for a local connection | ||||||
|  |     --port <port>               Port to use for connection (default: 3306) | ||||||
|  |     --user <username>           Username to use for authentication | ||||||
|  |     --userenv <envvar>          Name of env variable which contains username to use for authentication | ||||||
|  |     --pass <password>           Password to use for authentication | ||||||
|  |     --passenv <envvar>          Name of env variable which contains password to use for authentication | ||||||
|  |     --ssl-ca <path>             Path to public key | ||||||
|  |     --mysqladmin <path>         Path to a custom mysqladmin executable | ||||||
|  |     --mysqlcmd <path>           Path to a custom mysql executable | ||||||
|  |     --defaults-file <path>      Path to a custom .my.cnf | ||||||
|  | 
 | ||||||
|  | # PERFORMANCE AND REPORTING OPTIONS | ||||||
|  | 
 | ||||||
|  |     --skipsize                  Don't enumerate tables and their types/sizes (default: on) | ||||||
|  |                                 (Recommended for servers with many tables) | ||||||
|  |     --skippassword              Don't perform checks on user passwords(default: off) | ||||||
|  |     --checkversion              Check for updates to MySQLTuner (default: don't check) | ||||||
|  |     --updateversion             Check for updates to MySQLTuner and update when newer version is available (default: don't check) | ||||||
|  |     --forcemem <size>           Amount of RAM installed in megabytes | ||||||
|  |     --forceswap <size>          Amount of swap memory configured in megabytes | ||||||
|  |     --passwordfile <path>       Path to a password file list(one password by line) | ||||||
|  | 
 | ||||||
|  | # OUTPUT OPTIONS | ||||||
|  | 
 | ||||||
|  |     --silent                    Don't output anything on screen | ||||||
|  |     --nogood                    Remove OK responses | ||||||
|  |     --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 | ||||||
|  |     --nocolor                   Don't print output in color | ||||||
|  |     --json                      Print result as JSON string | ||||||
|  |     --buffers                   Print global and per-thread buffer values | ||||||
|  |     --outputfile <path>         Path to a output txt file | ||||||
|  |     --reportfile <path>         Path to a report txt file | ||||||
|  |     --template   <path>         Path to a template file | ||||||
|  | 
 | ||||||
|  | # PERLDOC | ||||||
|  | 
 | ||||||
|  | You can find documentation for this module with the perldoc command. | ||||||
|  | 
 | ||||||
|  |     perldoc mysqltuner | ||||||
|  | 
 | ||||||
|  | ## INTERNALS | ||||||
|  | 
 | ||||||
|  | [https://github.com/major/MySQLTuner-perl/blob/master/INTERNALS.md](https://github.com/major/MySQLTuner-perl/blob/master/INTERNALS.md) | ||||||
|  | 
 | ||||||
|  |     Internal documentation | ||||||
|  | 
 | ||||||
|  | # AUTHORS | ||||||
|  | 
 | ||||||
|  | Major Hayden - major@mhtx.net | ||||||
|  | 
 | ||||||
|  | # CONTRIBUTORS | ||||||
|  | 
 | ||||||
|  | - Matthew Montgomery | ||||||
|  | - Paul Kehrer | ||||||
|  | - Dave Burgess | ||||||
|  | - Jonathan Hinds | ||||||
|  | - Mike Jackson | ||||||
|  | - Nils Breunese | ||||||
|  | - Shawn Ashlee | ||||||
|  | - Luuk Vosslamber | ||||||
|  | - Ville Skytta | ||||||
|  | - Trent Hornibrook | ||||||
|  | - Jason Gill | ||||||
|  | - Mark Imbriaco | ||||||
|  | - Greg Eden | ||||||
|  | - Aubin Galinotti | ||||||
|  | - Giovanni Bechis | ||||||
|  | - Bill Bradford | ||||||
|  | - Ryan Novosielski | ||||||
|  | - Michael Scheidell | ||||||
|  | - Blair Christensen | ||||||
|  | - Hans du Plooy | ||||||
|  | - Victor Trac | ||||||
|  | - Everett Barnes | ||||||
|  | - Tom Krouper | ||||||
|  | - Gary Barrueto | ||||||
|  | - Simon Greenaway | ||||||
|  | - Adam Stein | ||||||
|  | - Isart Montane | ||||||
|  | - Baptiste M. | ||||||
|  | - Cole Turner | ||||||
|  | - Major Hayden | ||||||
|  | - Joe Ashcraft | ||||||
|  | - Jean-Marie Renouard | ||||||
|  | - Stephan GroBberndt | ||||||
|  | - Christian Loos | ||||||
|  | 
 | ||||||
|  | # SUPPORT | ||||||
|  | 
 | ||||||
|  | Bug reports, feature requests, and downloads at http://mysqltuner.com/ | ||||||
|  | 
 | ||||||
|  | Bug tracker can be found at https://github.com/major/MySQLTuner-perl/issues | ||||||
|  | 
 | ||||||
|  | Maintained by Major Hayden (major\\@mhtx.net) - Licensed under GPL | ||||||
|  | 
 | ||||||
|  | # SOURCE CODE | ||||||
|  | 
 | ||||||
|  | [https://github.com/major/MySQLTuner-perl](https://github.com/major/MySQLTuner-perl) | ||||||
|  | 
 | ||||||
|  |     git clone https://github.com/major/MySQLTuner-perl.git | ||||||
|  | 
 | ||||||
|  | # COPYRIGHT AND LICENSE | ||||||
|  | 
 | ||||||
|  | Copyright (C) 2006-2018 Major Hayden - major@mhtx.net | ||||||
|  | 
 | ||||||
|  | For the latest updates, please visit http://mysqltuner.com/ | ||||||
|  | 
 | ||||||
|  | Git repository available at https://github.com/major/MySQLTuner-perl | ||||||
|  | 
 | ||||||
|  | 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 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | 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 <https://www.gnu.org/licenses/>. | ||||||
|  | @ -1097,7 +1097,9 @@ sub get_all_vars { | ||||||
|     unless ( defined( $myvar{'innodb_support_xa'} ) ) { |     unless ( defined( $myvar{'innodb_support_xa'} ) ) { | ||||||
|         $myvar{'innodb_support_xa'} = 'ON'; |         $myvar{'innodb_support_xa'} = 'ON'; | ||||||
|     } |     } | ||||||
|     $mystat{'Uptime'} = 1 unless defined($mystat{'Uptime'}) and $mystat{'Uptime'}>0; |     $mystat{'Uptime'} = 1 | ||||||
|  |       unless defined( $mystat{'Uptime'} ) | ||||||
|  |       and $mystat{'Uptime'} > 0; | ||||||
|     $myvar{'have_galera'} = "NO"; |     $myvar{'have_galera'} = "NO"; | ||||||
|     if (   defined( $myvar{'wsrep_provider_options'} ) |     if (   defined( $myvar{'wsrep_provider_options'} ) | ||||||
|         && $myvar{'wsrep_provider_options'} ne "" |         && $myvar{'wsrep_provider_options'} ne "" | ||||||
|  | @ -1738,7 +1740,8 @@ sub security_recommendations { | ||||||
| 
 | 
 | ||||||
|     my $PASS_COLUMN_NAME = 'password'; |     my $PASS_COLUMN_NAME = 'password'; | ||||||
|     if ( $myvar{'version'} =~ /5\.7|10\..*MariaDB*/ ) { |     if ( $myvar{'version'} =~ /5\.7|10\..*MariaDB*/ ) { | ||||||
|         my $password_column_exists = `$mysqlcmd $mysqllogin -Bse "SELECT 1 FROM information_schema.columns WHERE TABLE_SCHEMA = 'mysql' AND TABLE_NAME = 'user' AND COLUMN_NAME = 'password'" 2>>/dev/null`; |         my $password_column_exists = | ||||||
|  | `$mysqlcmd $mysqllogin -Bse "SELECT 1 FROM information_schema.columns WHERE TABLE_SCHEMA = 'mysql' AND TABLE_NAME = 'user' AND COLUMN_NAME = 'password'" 2>>/dev/null`; | ||||||
|         if ($password_column_exists) { |         if ($password_column_exists) { | ||||||
|             $PASS_COLUMN_NAME = |             $PASS_COLUMN_NAME = | ||||||
| "IF(plugin='mysql_native_password', authentication_string, password)"; | "IF(plugin='mysql_native_password', authentication_string, password)"; | ||||||
|  | @ -5772,8 +5775,9 @@ sub mysql_innodb { | ||||||
| 
 | 
 | ||||||
| sub check_metadata_perf { | sub check_metadata_perf { | ||||||
|     subheaderprint "Analysis Performance Metrics"; |     subheaderprint "Analysis Performance Metrics"; | ||||||
|     if (defined $myvar{'innodb_stats_on_metadata'}) { |     if ( defined $myvar{'innodb_stats_on_metadata'} ) { | ||||||
|         infoprint "innodb_stats_on_metadata: " . $myvar{'innodb_stats_on_metadata'}; |         infoprint "innodb_stats_on_metadata: " | ||||||
|  |           . $myvar{'innodb_stats_on_metadata'}; | ||||||
|         if ( $myvar{'innodb_stats_on_metadata'} eq 'ON' ) { |         if ( $myvar{'innodb_stats_on_metadata'} eq 'ON' ) { | ||||||
|             badprint "Stat are updated during querying INFORMATION_SCHEMA."; |             badprint "Stat are updated during querying INFORMATION_SCHEMA."; | ||||||
|             push @adjvars, "SET innodb_stats_on_metadata = OFF"; |             push @adjvars, "SET innodb_stats_on_metadata = OFF"; | ||||||
|  | @ -6000,7 +6004,7 @@ sub mysql_tables { | ||||||
|                 my $current_type = |                 my $current_type = | ||||||
|                   uc($ctype) . ( $isnull eq 'NO' ? " NOT NULL" : "" ); |                   uc($ctype) . ( $isnull eq 'NO' ? " NOT NULL" : "" ); | ||||||
|                 my $optimal_type = select_str_g( "Optimal_fieldtype", |                 my $optimal_type = select_str_g( "Optimal_fieldtype", | ||||||
|                     "SELECT \\`$_\\` FROM \\`$dbname\\`.\\`$tbname\\` PROCEDURE ANALYSE(100000)" | "SELECT \\`$_\\` FROM \\`$dbname\\`.\\`$tbname\\` PROCEDURE ANALYSE(100000)" | ||||||
|                 ); |                 ); | ||||||
|                 if ( not defined($optimal_type) or $optimal_type eq '' ) { |                 if ( not defined($optimal_type) or $optimal_type eq '' ) { | ||||||
|                     infoprint "      Current Fieldtype: $current_type"; |                     infoprint "      Current Fieldtype: $current_type"; | ||||||
|  | @ -6012,7 +6016,7 @@ sub mysql_tables { | ||||||
|                     badprint |                     badprint | ||||||
| "Consider changing type for column $_ in table $dbname.$tbname"; | "Consider changing type for column $_ in table $dbname.$tbname"; | ||||||
|                     push( @generalrec, |                     push( @generalrec, | ||||||
|                         "ALTER TABLE \`$dbname\`.\`$tbname\` MODIFY \`$_\` $optimal_type;" | "ALTER TABLE \`$dbname\`.\`$tbname\` MODIFY \`$_\` $optimal_type;" | ||||||
|                     ); |                     ); | ||||||
| 
 | 
 | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Jean-Marie Renouard
						Jean-Marie Renouard