MySQLTuner è uno script Perl che permette di analizzare velocemente una installazione di MySQL, nonché di apportare modifiche per migliorare le prestazioni e la stabilità. In modo coinciso sono riportati lo stato attuale delle variabili di configurazione e i dati sullo stato del sistema, corredati da suggerimenti di base per il miglioramento delle prestazioni.
MySQLTuner supporta, in quest'ultima versione, circa 250 indicatori per i server MySQL/MariaDB/Percona.
MySQLTuner è attivamente manutenuto e nuovi indicatori sono aggiunti di settimana in settimana, supportando un gran numero di configurazioni tra le quali ,
,
, metriche relative al SO Linux,
,
,
, …
Maggiori dettagli sugli indicatori
.
MySQLTuner ha bisogno di collaboratori per documentazione, codice e suggerimenti ..
È estremamente importante che tu capisca appieno ogni singola modifica apportata alla configurazione del server MySQL. Qualora non capissi appieno qualche parte dell'output dello script o se non capissi quanto raccomandato dovresti consultare un DBA esperto o un amministratore di sistema di cui hai fiducia. Testa sempre le modifiche su ambienti ad hoc e tieni sempre presente che miglioramenti in un settore potrebbero influenzare negativamente MySQL in altri settori.
Seriamente - consulta la sezione FAQ che segue.
Tutti i controlli effettuati da MySQLTuner sono documentati in MySQLTuner Internals.
Si può semplicemente scaricare l'intero codice utilizzando git clone
seguito dalla URL riportata sopra.
Il modo più semplice è il seguente:
wget http://mysqltuner.pl/ -O mysqltuner.pl
wget https://raw.githubusercontent.com/major/MySQLTuner-perl/master/basic_passwords.txt -O basic_passwords.txt
wget https://raw.githubusercontent.com/major/MySQLTuner-perl/master/vulnerabilities.csv -O vulnerabilities.csv
perl mysqltuner.pl
Ovviamente è possibile assegnare il permesso di esecuzione in modo da poter lanciare il comando senza chiamare l'interprete perl
(chmod +x mysqltuner.pl
).
Uso: Minimale locale
perl mysqltuner.pl
Uso: Minimale da remoto
perl mysqltuner.pl --host targetDNS_IP --user admin_user --pass admin_password
Uso: Abilitando il massimo livello di informazione in output su MySQL/MariaDb senza usare l'optione di debug
perl mysqltuner.pl --verbose
perl mysqltuner.pl --buffers --dbstat --idxstat --sysstat --pfstat
Uso: Abilitando la verifica delle vulnerabilità CVE per la versione di MariaDB o MySQL installata
perl mysqltuner.pl --cvefile=vulnerabilities.csv
Uso: Salvando i risultati su un file con le stesse informazione mostrate a video
perl mysqltuner.pl --outputfile /tmp/result_mysqltuner.txt
Uso: Salvando i risultati su un file senza mostrare nulla a video
perl mysqltuner.pl --silent --outputfile /tmp/result_mysqltuner.txt
Uso: Utilizzando un modello per personalizzare il file di output, con la sintassi di Text::Template.
perl mysqltuner.pl --silent --reportfile /tmp/result_mysqltuner.txt --template=/tmp/mymodel.tmpl
Uso: Abilitando la modalità di debug
perl mysqltuner.pl --debug
Domanda: MySQLTuner sistemerà il mio server MySQL lento?
No. MySQLTuner è uno script che legge solamente. Non scriverà alcun file di configurazione, non modificherà lo stato di alcun demone né chiamerà tua madre per augurarle buon compleanno. Ti darà una panoramica delle prestazioni del tuo server, facendo alcune raccomandazioni basilari circa i miglioramenti che tu puoi apportare. assicurati di leggere l'avviso precedente prima di seguire qualsiasi raccomandazione.
Domanda: Posso eliminare il mio DBA ora?
MySQLTuner non sostituirà il tuo DBA in alcun modo. Se il tuo DBA continuamente occupa il tuo parcheggio e ruba il tuo cibo dal frigo puoi considerare l'opzione - ma resta una tua scelta.
Domanda: Perché MySQLTuner continua a chiedermi ogni volta le credenziali di login di MySQL?
Lo script cerca di arguirle in ogni modo possibile. Cercando file ~/.my.cnf
, file di password di Plesk e provando il login di root con password vuota.
Se nessuno di questi modi ha successo, allora la password viene richiesta. Se preferisci che lo script giri in modo automatico, senza interazione con l'utente, allora crea un file .my.cnf
nella tua cartella home che contenga:
[client]
user=someusername
pass=thatuserspassword
Una volta creato, assicurati che tu sia il proprietario (owner) e che i permessi siano 0600. Questo dovrebbe preservare le tue credenziali di login per i database da occhi indiscreti, in condizioni normali. Se un Terminator modello T-1000 apparisse vestito da Carabiniere e chiedesse le tue credenziali non avresti poi tante scelte.
Domanda: C'è qualche altro modo per rendere sicure le credenziali sulle ultime versioni di MySQL e MariaDB ?
Potresti utilizzare il comando mysql_config_editor
.
$ mysql_config_editor set --login-path=client --user=someusername --password --host=localhost
Enter passord: ********
$
Che crea il file ~/.mylogin.cnf
con i prmessi di accesso appropriati.
Per avere informazioni sulle credenziali salvate, si usi ilseguente comando:
$mysql_config_editor print
[client]
user = someusername
password = *****
host = localhost
Domanda: Quali sono i privilegi minimi, nel database, necessari per un utente mysqltuner ad hoc ?
mysql>GRANT SELECT, PROCESS,EXECUTE, REPLICATION CLIENT,SHOW DATABASES,SHOW VIEW ON *.* FOR 'mysqltuner'@'localhost' identified by pwd1234;
Domanda: Non funziona sul mio SO! Che succede?!
Questo genere di cose sono destinate ad accadere. Ecco i dettagli di cui ho bisogno per indagare sul problema:
SHOW VARIABLES;
e SHOW GLOBAL STATUS;
(se possibile)Domanda: Come eseguo il check per le vulnerabilità CVE ?
vulnerabilities.csv
da questo repository.--cvefile
per eseguire i test delle CVEDomanda: Come uso mysqltuner da un altro computer ? Grazie a @rolandomysqldba
Connessione e Autenticazione
--host <hostname> Si connette a un host remoto per eseguire i test (default: localhost)
--socket <socket> Usa un socket per effettuare una connessione locale
--port <port> Porta per la connessione (default: 3306)
--user <username> Username per l'autenticazione
--pass <password> Password per l'autenticazione
--defaults-file <path> defaults file per le credenziali
Poiché si sta utilizzando un host remoto, si utilizzino i seguenti parametri per fornire allo script i valori del SO
--forcemem <size> Valore della RAM installata, in megabyte
--forceswap <size> Valore della memoria di swap configurata, in megabyte
Se il database ha troppe tabelle, o tabelle veramente grandi, si usi:
--skipsize Non elenca le tabelle ed i rispettivi tipi e dimensioni (default: on)
(Raccomandato per server con molte tabelle)
MySQLTuner contiene le seguenti configurazioni per Vagrant: * Fedora Core 23 / MariaDB 10.0 * Fedora Core 23 / MariaDB 10.1 * Fedora Core 23 / MySQL 5.6 * Fedora Core 23 / MySQL 5.7
Vagrant File sono collocati nella sotto-directory di Vagrant.
* Segui questi due passaggi dopo l'installazione di Vagrant:
* Rinominare VagrantFile_for_Mxxx
in Vagrantfile
* vagrant up
MySQLTuner contiene una configurazione Vagrant a scopo di test e sviluppo
* Installare VirtualBox e Vagrant
* https://www.virtualbox.org/wiki/Downloads
* https://www.vagrantup.com/downloads.html
* Clone del repository
* git clone https://github.com/major/MySQLTuner-perl.git
* Installare i plugin di Vagrant vagrant-hostmanager
e vagrant-vbguest
* vagrant plugin install vagrant-hostmanager
* vagrant plugin install vagrant-vbguest
* Aggiungere un box Fedora Core 23 dal sito ufficiale di Fedora
* vagrant box add --name fc23 https://download.fedoraproject.org/pub/fedora/linux/releases/23/Cloud/x86_64/Images/Fedora-Cloud-Base-Vagrant-23-20151030.x86_64.vagrant-virtualbox.box
* Creare una directory data
* mkdir data
* Rinominare Vagrantfile_MariaDB10.0
in Vagrantfile
* cp MySQLTuner-perl/Vagrant/Vagrantfile_for_MariaDB10.0 Vagrantfile
* Start vagrant
* vagrant up
MySQLTuner ha bisogno di collaboratori per documentazione, codice e suggerimenti ..