From c2140d79f7742e2bd11537de840b104dfb50877a Mon Sep 17 00:00:00 2001 From: Fabio Pedretti Date: Wed, 7 Feb 2024 10:57:48 +0100 Subject: [PATCH 1/3] fix perl shebang Previously at least on Debian it broke with: $ ./mysqltuner.pl -bash: ./mysqltuner.pl: /bin/env: bad interpreter: No such file or directory --- mysqltuner.pl | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mysqltuner.pl b/mysqltuner.pl index 801909295..21e185825 100755 --- a/mysqltuner.pl +++ b/mysqltuner.pl @@ -1,4 +1,4 @@ -#!/bin/env perl +#!/usr/bin/perl # mysqltuner.pl - Version 2.5.2 # High Performance MySQL Tuning Script # Copyright (C) 2015-2023 Jean-Marie Renouard - jmrenouard@gmail.com From 30e61d917b7903185911fde5bd46960f9ea17a60 Mon Sep 17 00:00:00 2001 From: Jean-Marie Renouard Date: Thu, 8 Feb 2024 22:15:50 +0100 Subject: [PATCH 2/3] Generate 2.5.3 sub version at 2024-02-08T22:15:50+01:00 --- USAGE.md | 2 +- mysqltuner.pl | 36 +++++++++++++++++++++--------------- 2 files changed, 22 insertions(+), 16 deletions(-) diff --git a/USAGE.md b/USAGE.md index c63d361b3..9fa4e1677 100644 --- a/USAGE.md +++ b/USAGE.md @@ -1,6 +1,6 @@ # NAME - MySQLTuner 2.5.2 - MySQL High Performance Tuning Script + MySQLTuner 2.5.3 - MySQL High Performance Tuning Script # IMPORTANT USAGE GUIDELINES diff --git a/mysqltuner.pl b/mysqltuner.pl index 801909295..52c871bf3 100755 --- a/mysqltuner.pl +++ b/mysqltuner.pl @@ -1,5 +1,5 @@ #!/bin/env perl -# mysqltuner.pl - Version 2.5.2 +# mysqltuner.pl - Version 2.5.3 # High Performance MySQL Tuning Script # Copyright (C) 2015-2023 Jean-Marie Renouard - jmrenouard@gmail.com # Copyright (C) 2006-2023 Major Hayden - major@mhtx.net @@ -57,7 +57,7 @@ package main; #use Env; # Set up a few variables for use in the script -my $tunerversion = "2.5.2"; +my $tunerversion = "2.5.3"; my ( @adjvars, @generalrec ); # Set defaults @@ -109,6 +109,7 @@ package main; "prettyjson" => 0, "reportfile" => 0, "verbose" => 0, + "experimental" => 0, "defaults-file" => '', "defaults-extra-file" => '', "protocol" => '', @@ -151,7 +152,7 @@ package main; 'server-log=s', 'protocol=s', 'defaults-extra-file=s', 'dumpdir=s', 'feature=s', 'dbgpattern=s', - 'defaultarch=i' + 'defaultarch=i', 'experimental' ) or pod2usage( -exitval => 1, @@ -209,6 +210,9 @@ package main; $opt{dbgpattern} = '.*' if ( $opt{dbgpattern} eq '' ); +# Activate experimental calculations and analysis +if ( $opt{experimental} ne '' ) { $opt{experimental} = 1; } + # check if we need to enable verbose mode if ( $opt{feature} ne '' ) { $opt{verbose} = 1; } if ( $opt{verbose} ) { @@ -2530,7 +2534,7 @@ sub check_architecture { } elsif ( `uname` =~ /Darwin/ && `uname -m` =~ /x86_64/ ) { -# Darwin gibas.local 12.5.2 Darwin Kernel Version 12.3.0: Sun Jan 6 22:37:10 PST 2013; root:xnu-2050.22.13~1/RELEASE_X86_64 x86_64 +# Darwin gibas.local 12.5.3 Darwin Kernel Version 12.3.0: Sun Jan 6 22:37:10 PST 2013; root:xnu-2050.22.13~1/RELEASE_X86_64 x86_64 $arch = 64; goodprint "Operating on 64-bit architecture"; } @@ -3219,8 +3223,8 @@ sub calculations { "select round( 100* sum(allocated)/( select VARIABLE_VALUE " . "FROM performance_schema.global_variables " . "WHERE VARIABLE_NAME='innodb_buffer_pool_size' ) ,2)" - . 'FROM sys.x\$innodb_buffer_stats_by_table;' ); - + . 'FROM sys.x\$innodb_buffer_stats_by_table;' ) + if ($opt{experimental}); # Binlog Cache if ( $myvar{'log_bin'} ne 'OFF' ) { $mycalc{'pct_binlog_cache'} = percentage( @@ -6372,14 +6376,16 @@ sub mysql_innodb { # ,2) as "PCT ALLOC/BUFFER POOL" #from sys.x$innodb_buffer_stats_by_table; - if (defined $mycalc{innodb_buffer_alloc_pct}) { - if ( $mycalc{innodb_buffer_alloc_pct} < 80 ) { - badprint "Ratio Buffer Pool allocated / Buffer Pool Size: " - . $mycalc{'innodb_buffer_alloc_pct'} . '%'; - } - else { - goodprint "Ratio Buffer Pool allocated / Buffer Pool Size: " - . $mycalc{'innodb_buffer_alloc_pct'} . '%'; + if ( $opt{experimental}) { + if (defined $mycalc{innodb_buffer_alloc_pct}) { + if ( $mycalc{innodb_buffer_alloc_pct} < 80 ) { + badprint "Ratio Buffer Pool allocated / Buffer Pool Size: " + . $mycalc{'innodb_buffer_alloc_pct'} . '%'; + } + else { + goodprint "Ratio Buffer Pool allocated / Buffer Pool Size: " + . $mycalc{'innodb_buffer_alloc_pct'} . '%'; + } } } if ( $mycalc{'innodb_log_size_pct'} < 20 @@ -7402,7 +7408,7 @@ sub which { =head1 NAME - MySQLTuner 2.5.2 - MySQL High Performance Tuning Script + MySQLTuner 2.5.3 - MySQL High Performance Tuning Script =head1 IMPORTANT USAGE GUIDELINES From ffd7aca201e49533eb5f443ee8b4a44fef7dd57d Mon Sep 17 00:00:00 2001 From: Jean-Marie Renouard Date: Thu, 8 Feb 2024 23:11:20 +0100 Subject: [PATCH 3/3] Adding eperimental feature with --experiemental --- mysqltuner.pl | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/mysqltuner.pl b/mysqltuner.pl index 52c871bf3..f891b11b0 100755 --- a/mysqltuner.pl +++ b/mysqltuner.pl @@ -1,4 +1,4 @@ -#!/bin/env perl +#!env perl # mysqltuner.pl - Version 2.5.3 # High Performance MySQL Tuning Script # Copyright (C) 2015-2023 Jean-Marie Renouard - jmrenouard@gmail.com @@ -210,8 +210,10 @@ package main; $opt{dbgpattern} = '.*' if ( $opt{dbgpattern} eq '' ); +# Activate debug variables +#if ( $opt{debug} ne '' ) { $opt{debug} = 2; } # Activate experimental calculations and analysis -if ( $opt{experimental} ne '' ) { $opt{experimental} = 1; } + #if ( $opt{experimental} ne '' ) { $opt{experimental} = 1; } # check if we need to enable verbose mode if ( $opt{feature} ne '' ) { $opt{verbose} = 1; } @@ -6376,7 +6378,7 @@ sub mysql_innodb { # ,2) as "PCT ALLOC/BUFFER POOL" #from sys.x$innodb_buffer_stats_by_table; - if ( $opt{experimental}) { + if ( $opt{experimental} ) { if (defined $mycalc{innodb_buffer_alloc_pct}) { if ( $mycalc{innodb_buffer_alloc_pct} < 80 ) { badprint "Ratio Buffer Pool allocated / Buffer Pool Size: " @@ -6414,7 +6416,7 @@ sub mysql_innodb { . $myvar{'innodb_log_files_in_group'} . " / " . hr_bytes( $myvar{'innodb_buffer_pool_size'} ) . " should be equal to 25%"; - push( + push( @adjvars, "innodb_log_file_size should be (=" . hr_bytes_rnd( @@ -7207,6 +7209,8 @@ sub headerprint { . "\t * Major Hayden \n" . " >> Bug reports, feature requests, and downloads at http://mysqltuner.pl/\n" . " >> Run with '--help' for additional options and output filtering"; + debugprint("Debug: ".$opt{debug}); + debugprint("Experimental: ".$opt{experimental}); } sub string2file { @@ -7217,12 +7221,12 @@ sub string2file { "Unable to open $filename in write mode. Please check permissions for this file or directory"; print $fh $content if defined($content); close $fh; - debugprint $content if ( $opt{'debug'} ); + debugprint $content; } sub file2array { my $filename = shift; - debugprint "* reading $filename" if ( $opt{'debug'} ); + debugprint "* reading $filename"; my $fh; open( $fh, q(<), "$filename" ) or die "Couldn't open $filename for reading: $!\n";