Manuel MySQL
Table des matières
- 5.1. Scripts serveur MySQL et utilitaires
- 5.2. Configuration de MySQL
- 5.3. Le processus d'extinction de MySQL
- 5.4. Sécurité générale du serveur
- 5.5. Règles de sécurité et droits d'accès au serveur MySQL
-
- 5.5.1. Rôle du système de privilèges
- 5.5.2. Comment fonctionne le système de droits
- 5.5.3. Droits fournis par MySQL
- 5.5.4. Se connecter au serveur MySQL
- 5.5.5. Contrôle d'accès, étape 1 : Vérification de la connexion
- 5.5.6. Contrôle d'accès, étape 2 : Vérification de la requête
- 5.5.7. Quand les modifications de privilèges prennent-ils effets ?
- 5.5.8. Causes des erreurs
Access denied - 5.5.9. Hashage de mots de passe en MySQL 4.1
- 5.6. Gestion des comptes utilisateurs de MySQL
-
- 5.6.1. Nom d'utilisateurs MySQL et mots de passe
- 5.6.2. Ajouter de nouveaux utilisateurs à MySQL
- 5.6.3. Supprimer un compte utilisateur de MySQL
- 5.6.4. Limiter les ressources utilisateurs
- 5.6.5. Configurer les mots de passe
- 5.6.6. Garder vos mots de passe en lieu sûr
- 5.6.7. Utilisation des connexions sécurisées
- 5.7. Prévention des désastres et restauration
- 5.8. Localisation MySQL et utilisation internationale
-
- 5.8.1. Le jeu de caractères utilisé pour les données et le stockage
- 5.8.2. Langue des messages d'erreurs
- 5.8.3. Ajouter un nouveau jeu de caractères
- 5.8.4. Le tableau de définition des caractères
- 5.8.5. Support d'assemblage des chaînes
- 5.8.6. Support des caractères multi-octets
- 5.8.7. Problèmes avec les jeux de caractères
- 5.8.8. Support des fuseaux horaires avec MySQL
- 5.9. Les fichiers de log de MySQL
- 5.10. Faire fonctionner plusieurs serveurs MySQL sur la même machine
- 5.11. Cache de requêtes MySQL
Ce chapitre couvre les problèmes d'administration de MySQL, comme la configuration des comptes et les sauvegardes.
Le serveur MySQL, mysqld, est le programme principal qui effectue l'essentiel du travail. Le serveur est accompagné par différents scripts connexes qui effectuent des opérations de configuration lors de l'installation, ou fournissent de l'aide pour administrer le serveur.
Cette section fournit une introduction au serveur et ses utilitaires, et des informations sur les scripts de démarrage. Les informations sur la configuration du serveur lui-même sont données dans la section Section 5.2, « Configuration de MySQL ».
Tous les programmes MySQL prennent des options différentes. Toutefois, tous les programmes MySQL disposent de l'option --help qui vous aidera à connaître la liste complète des différentes options. Par exemple, essayez mysql --help.
Vous pouvez modifier toutes les valeurs par défaut des programmes en les pla¸ant dans le fichier de configuration. Section 4.3.2, « Fichier d'options my.cnf ».
Voici la liste des programmes coté serveur de MySQL :
-
Le démon SQL (c'est à dire, le serveur MySQL). Pour utiliser les programmes clients, ce programme doit fonctionner, car les clients viendront se connecter dessus. See Section 5.2, « Configuration de MySQL ».
-
Une version du serveur qui inclut des fonctionnalités supplémentaires. See Section 5.1.2, «
mysqld-max, la version étendue du serveurmysqld». -
Un script de démarrage du serveur.
mysqld_safetente de démarrermysqld-maxs'il existe, et sinonmysqld. See Section 5.1.3, «safe_mysqld, le script père demysqld». -
Un script de démarrage du serveur. Ce script est utilisé sur les systèmes qui ont un dossier contenant des services système. Il invoque
mysqld_safepour démarrer le serveur MySQL. See Section 5.1.4, « Le script de démarragemysql.server». -
Un script de démarrage qui peut lancer ou arrêter différentes instances du serveur, installées sur le système. See Section 5.1.5, «
mysqld_multi, un programme pour gérer plusieurs serveurs MySQL ». -
Crée les tables de droits MySQL, avec les droits par défaut. Il est généralement exécuté une fois, lors de la première installation de
-
Ce script est utilisé après une mise à jour de MySQL, pour mettre à jour les tables de droits, et les adapter aux nouvelles versions de MySQL.
Il y a plusieurs autres utilitaires qui fonctionnent du coté du serveur :
-
Un utilitaire pour décrire, vérifier, optimiser et réparer les tables
MyISAM.myisamchkest décrit dans Section 5.7.3, « Utilisation demyisamchkpour la maintenance des tables et leur recouvrement ». -
Ce programme crée une version compilée de MySQL. Le résultat peut être envoyé par FTP à
/pub/mysql/Incomingsursupport.mysql.compour aider les autres utilisateurs MySQL. -
Le script de rapport de bogues de MySQL. Il peut être utilisé pour envoyer un rapport de bogues à MySQL. Vous pouvez aussi aller sur http://bugs.mysql.com/ pour remplir un formulaire en ligne.
Le serveur MySQL-Max est une vesrion du serveur mysqld qui a été compilée avec des fonctionnalités supplémentaires.
La distribution à utiliser dépend de votre plate-forme :
-
Sous Windows, les distributions binaires MySQL incluent le serveur standard (
mysqld.exe) et le serveurMySQL-Max(mysqld-max.exe), alors il n'y a pas de téléchargement spécial à faire. Utilisez simplement la distribution Windows habituelle, disponible sur http://dev.mysql.com/downloads/mysql-4.0.html. See Section 2.2.1, « Installer MySQL sous Windows ». -
Sous Linux, si vous installez une distribution
RPM, utilisez leRPMMySQL-serverstandard pour installer le serveurmysqld. Puis, utilisez leRPMMySQL-Maxpour installer le serveurmysqld-max. LeRPMMySQL-Maxsuppose que vous avez déjà installé le serveur régulierRPM. Voyez Section 2.2.12, « Installer MySQL sous Linux » pour plus d'informations sur les paquets LinuxRPM. -
Toutes les autres distributiosn de MySQL-Max contiennent un serveur unique, appelé
mysqldmais qui inclut les fonctionnalités supplémentaires.
Vous pouvez trouver les distributions binaires sur le site web de MySQL AB, sur http://dev.mysql.com/downloads/mysql-4.0.html.
MySQL AB compile le serveur MySQL-Max avec les options de configure suivantes :
-
--with-server-suffix=-maxCette option ajoute le suffixe
-maxà la chaîne de version demysqld. -
--with-innodbCette option active le support du moteur
InnoDB. MySQL-Max inclut toujours le support deInnoDB, mais cette option est nécessaire pour MySQL 3.23. Depuis MySQL 4,InnoDBest inclut par défaut dans les distributions binaires, alors il n'est pas nécessaire d'utiliser MySQL-Max pour ¸a. -
--with-bdbCette option active le support du moteur de table Berkeley DB (
BDB). -
CFLAGS=-DUSE_SYMDIRCette option active le support des liens symboliques sous Windows.
Les distributions binaires de MySQL-Max sont disponibles pour ceux qui souhaitent installer une version pré-compilée. Si vous voulez compiler MySQL-Max depuis les sources, vous pouvez le faire et choisir les fonctionnalités que vous souhaitez au moment de la compilation.
Le serveur MySQL-Max inclut le moteur de stockage BerkeleyDB (BDB) lorsque c'est possible, mais toutes les plate-formes ne supportent pas BDB. La table suivante montre quelles plate-formes permettent à MySQL-Max d'inclure BDB :
| Système | BDB Support |
| AIX 4.3 | N |
| HP-UX 11.0 | N |
| Linux-Alpha | N |
| Linux-IA-64 | N |
| Linux-Intel | Y |
| Mac OS X | N |
| NetWare | N |
| SCO OSR5 | Y |
| Solaris-Intel | N |
| Solaris-SPARC | Y |
| UnixWare | Y |
| Windows/NT | Y |
Pour connaître les moteurs de stockages que votre serveur supporte, utilisez la commande suivante :
mysql> SHOW ENGINES;
Avant MySQL 4.1.2, SHOW ENGINES est indisponible. Utilisez la commande suivante et vérifiez la valeur de la variable pour le moteur de table qui vous intéresse :
mysql> SHOW VARIABLES LIKE 'have_%';
+------------------+----------+
| Variable_name | Value |
+------------------+----------+
| have_bdb | NO |
| have_crypt | YES |
| have_innodb | YES |
| have_isam | NO |
| have_raid | NO |
| have_symlink | DISABLED |
| have_openssl | NO |
| have_query_cache | YES |
+------------------+----------+
La signification des valeurs est :
| Valeur | Signification |
YES |
L'option est activatée et utilisable. |
NO |
L'option n'est pas supportée. |
DISABLED |
L'option est supportée mais désactivée. |
La valeur NO signifie que le serveur a été compilé sans le support, et que la fonctionnalité ne peut pas être activée durant l'exécution.
La valeur de DISABLED apparait soit parce que le serveur a été lancé sans l'option qui active cette foncitonnalité, soit si toutes les options nécessaires ne sont pas dispoinbles. Dans ce dernier cas, le fichier d'erreurs host_name.err devrait contenir la raison indiquant pourquoi l'option a été désactivée.
Une situation dans laquelle vous pouvez voir DISABLED survient en version MySQL 3.23, lorsque le moteurInnoDB est compilé. En MySQL 3.23, vous devez fournir au moins l'option innodb_data_file_path à l'exécution pour configurer l'espace de tables InnoDB. Sans cette option, InnoDB se désactive. See Section 15.3, « InnoDB avec MySQL version 3.23 ». Vous pouvez spécifier les options de configuration opur les tables BDB, mais BDB ne se désactivera pas de lui-même si vous les oubliez. See Section 14.4.3, « Options de démarrage BDB ».
Vous pouvez aussi rencontrer la valeur de DISABLED pour InnoDB, BDB, ou ISAM si le serveur a été compilé pour les supporter, mais si les options de démarrage --skip-innodb, --skip-bdb ou --skip-isam à l'exécution.
Depuis la version 3.23, tous les serveurs MySQL supportent les tables MyISAM, car le moteur MyISAM est le moteur par défaut.
safe_mysqld est la méthode recommandée pour démarrer un démon mysqld sous Unix. safe_mysqld ajoute des fonctionnalités de sécurité telles que le redémarrage automatique lorsqu'une erreur survient et l'enregistrement d'informations d'exécution dans un fichier de log.
Note: Avant MySQL 4.0, mysqld_safe s'appelait safe_mysqld. Pour préserver la compatibilité ascendante, la distribution binaire MySQL propose un lien symbolique de safe_mysqld vers mysqld_safe.
Par défaut, mysqld_safe essaie de lancer l'exécutable appelé mysqld-max s'il existe, ou mysqld sinon. Cela a des implications :
-
Sous Linux, le
RPMMySQL-Maxdépend demysqld_safe. LeRPMinstalle un exécutable appelémysqld-max, qui fait quemysqld_safeva automatiquement utiliser l'exécutable installé -
Si vous installez la distribution
MySQL-Maxqui incluent un serveur appelémysqld-max, puis que vous le mettez à jour avec une version non-max,mysqld_safeva essayer d'utiliser l'ancien serveurmysqld-max. Si vous faites une telle mise à jour, supprimez manuellement l'ancien serveurmysqld-maxpour vous assurer quemysqld_safeutilise le nouveaumysqld.
Pour remplacer le comportement par défaut et spécifier explicitement le serveur que vous voulez utiliser, spécifiez l'option --mysqld ou --mysqld-version avec mysqld_safe.
De nombreux options de mysqld_safe sont identiques aux options de mysqld. See Section 5.2.1, « Options de ligne de commande de mysqld ».
Toutes les options spécifiées avec mysqld_safe en ligne de commande sont passées à mysqld. Si vous voulez utiliser des options qui sont spécifiques à mysqld_safe et que mysqld ne les supporte pas, ne les spécifiez pas en ligne de commande. Au lieu de cela, listez les dans le groupe [mysqld_safe] du fichier d'options. See Section 4.3.2, « Fichier d'options my.cnf ».
mysqld_safe lit toutes les options des groupes [mysqld], [server] et [mysqld_safe] dans le fichier d'options. Pour assurer la compatibilité ascendante, il lit aussi le groupe [safe_mysqld]. Vous devriez renommer ces sections [mysqld_safe] lorsque vous passez à MySQL 4.0 ou plus récent.
safe_mysqld supporte les options suivantes :
-
--basedir=pathLe chemin jusqu'à l'installation de MySQL.
-
--core-file-size=#Taille du fichier
corequemysqlddoit être capable de créer. Il est passé àulimit -c. -
--datadir=pathLe chemin jusqu'au dossier de données.
-
--defaults-extra-file=pathLe nom du fichier d'options à lire en plus des fichiers habituels.
-
--defaults-file=pathLe nom d'un fichier d'options qui doit être lu à la place du fichier d'options habituel.
-
--err-log=pathL'ancienne option
--log-error, à utiliser avant MySQL 4.0. -
--ledir=pathLe chemin jusqu'au dossier contenant le dossier
mysqld. Utilisez cette option pour indiquer explicitement le lieu du serveur. -
--log-error=pathEcrit le fichier d'erreurs dans le fichier ci-dessus. See Section 5.9.1, « Le log d'erreurs ».
-
--mysqld=prog_nameLe nom du programme serveur (dans le dossier
ledir) que vous voulez lancer. Cette option est nécessaire si vous utilisez une distribution binaire MySQL, mais que les données sont hors du dossier d'installation. -
--mysqld-version=suffixCette option est similaire à l'option
--mysqld, mais vous spécifiez uniquement le suffixe du nom du programme. Le nom de base sera alorsmysqld. Par exemple, si vous utilisez--mysqld-version=max,mysqld_safeva lancer le programmemysqld-maxdans le dossierledir. Si l'argument de--mysqld-versionest vide,mysqld_safeutilisemysqlddans le dossierledir. -
--nice=priorityUtilise le programme
nicepour donner la priorité du serveur. Cette option a été ajoutée en MySQL 4.0.14. -
--no-defaultsNe lit aucun fichier d'options.
-
--open-files-limit=countLe nombre de fichiers que
mysqldouvre au maximum. La valeur de l'option est passée àulimit -n. Notez que vous devez lancermysqld_safeen tant querootpour que cela fonctionne correctement. -
--pid-file=pathLe chemin jusqu'au fichier d'identifiant de processus.
-
--port=port_numLe numéro de port à utiliser pour attendre les connexion TCP/IP.
-
--socket=pathLe fichier de socket Unix pour les connexions locales.
-
--timezone=zoneConfigure la variable d'environnement
TZ. Consultez votre documentation système pour connaître le format légal des fuseaux horaires. -
--user={user_name | user_id}Lance le serveur
mysqldsous le nom d'utilisateuruser_nameou avec l'utilisateur d'identifiant numérique IDuser_id. (``Utilisateur'' dans ce contexte représente le compte système, et non pas les utilisateurs des tables de droits MySQL).
Le script safe_mysqld a été écrit pour qu'il soit capable de démarrer le serveur qui a été installé à partir des sources ou de la version binaire, même si l'installation de MySQL est légèrement exotique. See Section 2.1.5, « Dispositions d'installation ». safe_mysqld suppose que les conditions suivantes sont remplies :
-
Le serveur et les bases de données sont placées dans un dossier relativement au dossier d'où
safe_mysqldest appelé.safe_mysqldcherche dans les sous dossiersbinetdata(pour les distributions binaires) et,libexecetvar(pour les distributions sources). Cette condition doit être remplie si vous exécutezsafe_mysqlddepuis votre dossier d'installation MySQL (par exemple,/usr/local/mysqlpour une distribution binaire). -
Si le serveur et les bases de données ne peuvent être trouvées dans le dossier de travail,
safe_mysqldessaie de les trouver en utilisant leurs chemins absolus. Les chemin typiquement étudiés sont/usr/local/libexecet/usr/local/var. Les chemins réels sont déterminés lorsque la distribution est compilée, etsafe_mysqlda alors aussi été généré. Ils doivent être corrects si MySQL a été installé dans un dossier standard.
Comme safe_mysqld essaie de trouver le serveur et les bases dans un dossier situé dans le dossier de travail, vous pouvez installer la version binaire de MySQL n'importe où, du moment que vous démarrez le script safe_mysqld dans le dossier d'installation de MySQL :
shell>cd mysql_installation_directoryshell>bin/safe_mysqld &
Si safe_mysqld échoue, même si il est appelé depuis le dossier d'installation, vous pouvez le modifier pour qu'il reconnaisse le chemin que vous utilisez jusqu'à mysqld. Notez que si vous faites évoluer votre installation de MySQL, votre version de safe_mysqld sera écrasée, et vous devrez la rééditer.
Normalement, vous ne devez pas éditer le script mysqld_safe. Au lieu de cela, configurez mysqld_safe en utilisant les options de ligne de commande, ou les options de la section [mysqld_safe] du fichier d'options my.cnf. Dans de rares cas, il sera peut être nécessaire d'éditer mysqld_safe pour faire fonctionner correctement le serveur. Cependant, si vous faites cela, mysqld_safe risque d'être écrasé lors de la prochaine mise à jour de MySQL : faîtes en une sauvegarde avant d'installer.
Sous NetWare, mysqld_safe est un NetWare Loadable Module (NLM) qui est un port du script Unix original. Il fait ceci :
-
Effectue des vérifications système et des options.
-
Lance la vérification des tables
MyISAMetISAM. -
Affiche un écran de présence de MySQL.
-
Lance
mysqld, le surveille et le relance s'il s'arrête sur une erreur. -
Envoie les messages de
mysqlddans le fichierhost_name.errdans le dossier de données. -
Envoie les affichages de
mysqld_safedans le fichierhost_name.safedans le dossier de données.
Les distributions MySQL sous Unix incluent un script appelé mysql.server. Il peut être utilisé pour lancer et arrêter les services. Il est aussi utilisé par le script de démarrage de Max OS X.
mysql.server est placé dans le dossier support-files sous le dossier d'installation de MYSQL, ou dans le dossier de source.
Si vous utilisez le paquet RPM pour Linux (MySQL-server-VERSION.rpm), le script mysql.server sera déjà installé dans le dossier /etc/init.d sous le nom de mysql. Vous n'avez pas besoin de l'installer manuellement. Voyez Section 2.2.12, « Installer MySQL sous Linux » pour plus d'informations sur les paquets MySQL RPM Linux.
Certains éditeurs fournissent des paquets RPM qui installent un script de démarrage sous le nom de mysqld.
Si vous installez MySQL depuis une distribution source, ou en utilisant une distribution binaire qui n'installe pas automatiquement le fichier mysql.server, vous pouvez l'installer manuellement. Les instructions sont fournies dans la section Section 2.5.2.2, « Lancer et arrêter MySQL automatiquement ».
mysql.server lit les options dans les sections [mysql.server] et [mysqld] du fichier de configuration. Pour la compatibilité ascendante, il lit aussi la section [mysql_server], même si vous devrez la renommer en [mysql.server] lorsque vous commencerez à utiliser MySQL 4.0.
mysqld_multi sert à gérer plusieurs serveurs mysqld qui utilisent différentes sockets Unix et ports TCP/IP.
Le programme va rechercher les groupes nommés [mysqld#] dans le fichier my.cnf (ou le fichier appelé --config-file=...), où # peut être n'importe quel nombre positif, supérieur ou égal à 1. Ce nombre est appelé le numéro de groupe d'options. Les numéros de groupe permettent de distinguer un groupe d'options d'un autre, et sont utilisés comme argument du script mysqld_multi pour spécifier quel serveur vous voulez démarrer, arrêter ou examiner. Les options listées dans ces groupes doivent être les mêmes que celle que vous utiliseriez dans une section dédiée au démon [mysqld]. Voyez, par exemple, Section 2.5.2.2, « Lancer et arrêter MySQL automatiquement ». Cependant, pour mysqld_multi, vous devez vous assurer que chaque groupe contient des valeurs pour les options telles que port, socket, etc., qui seront utilisées par chaque processus mysqld. Pour plus d'informations sur sur les options de chaque serveur dans un environnement à serveurs multiples, voyez la section Section 5.10, « Faire fonctionner plusieurs serveurs MySQL sur la même machine ».
mysqld_multi est utilisé ave la syntaxe suivante :
shell> mysqld_multi [options] {start|stop|report} [GNR[,GNR]...]
start, stop et report indique le type d'opération que vous voulez faire. Vous pouvez faire une opération sur un serveur unique ou plusieurs serveurs, en fonction de la liste GNR qui suit le nom de l'opération. S'il n'y a pas de liste, mysqld_multi effectue l'opération sur tous les serveurs du fichier d'options.
Chaque GNR représente un numéro de groupe d'options. Vous pouvez démarrer, arrêter ou examiner n'importe quel numéro de groupe d'options, ou même plusieurs d'entre eux en même temps. Par exemple, le groupe GNR pour le groupe appelé [mysqld17] est 17. Pour spécifier un intervalle de nombres, séparez le premier et le dernier numéro par un tiret. La valeur GNR 10-13 représente les groupes de [mysqld10] à [mysqld13]. Les groupes multiples ou les intervalles de groupes peuvent être spécifiées en ligne de commande, séparés par virgules. Il ne doit pas y avoir d'espace blanc entre deux éléments de la liste : tout ce qui sera après un espace sera ignoré.
Cette commande lance un serveur unique, avec le groupe d'options [mysqld17] :
shell> mysqld_multi start 17
Cette commande arrête plusieurs serveurs, en utilisant les groupes d'options [mysql8] et [mysqld10] à [mysqld13] :
shell> mysqld_multi start 8,10-13
Pour afficher un exemple de configurations, utilisez cette commande :
shell> mysqld_multi --example
Les valeurs de numéro de groupe d'options peuvent être une liste de valeurs séparées par une virgule ou un tiret. Dans ce dernier cas, toutes les numéro de groupe d'options situés entre les deux numéros seront alors affectés. Sans numéro de groupe d'options spécifié, tous les numéros de groupes du fichier d'options sont affectés. Notez que vous ne devez pas avoir d'espace dans la liste des numéros de groupe d'options. Tout ce qui est placé au-delà de l'espace sera ignoré.
mysqld_multi supporte les options suivantes :
-
Un fichier de configuration alternatif. Note : cela ne va pas modifier les options de ce programme (
[mysqld_multi]), mais uniquement les groupes[mysqld#]. Sans cette option, tout sera lu dans le fichier d'options traditionnelmy.cnf. Cette option n'affecte pas la fa¸on avec laquellemysqld_multilit ses options, qui sont toujours prises dans le groupe[mysqld_multi]du fichiermy.cnfhabituel. -
Affiche un exemple de fichier de configuration.
-
Affiche l'aide et quitte.
-
Fichier de log. Le chemin complet et le nom du fichier sont nécessaires.
-
L'exécutable
mysqladminà utiliser lors de l'arrêt du serveur. -
L'exécutable
mysqldà utiliser. Notez que vous pouvez donner cette option àsafe_mysqld. Ces options sont passées àmysqld. Assurez-vous que vous avez bienmysqlddans votre variable d'environnementPATHou corrigezsafe_mysqld. -
Affiche les données d'historique à l'écran plutôt que dans le fichier de log. Par défaut, le fichier de log est activé.
-
Le mot de passe de l'utilisateur
mysqladmin. -
Connexion au serveur MySQL via le port TCP/IP au lieu de la socket Unix. Cela affecte l'arrêt et le rapport. Si le fichier de socket manque, le serveur peut continuer de tourner, mais il n'est plus accessible que par port TCP/IP. Par défaut, les connexions sont faites avec les sockets Unix.
-
L'utilisateur MySQL pour
mysqladmin. -
Affiche le numéro de version et quitte.
Quelques notes pour mysqld_multi :
-
Assurez-vous que l'utilisateur MySQL, qui stoppe les services
mysqld(e.g en utilisant la commandemysqladmin), a les mêmes nom d'utilisateur et mot de passe pour tous les dossiers de données utilisés. Et assurez-vous que cet utilisateur a bien les droits deSHUTDOWN! Si vous avez de nombreux dossiers de données et de nombreuses basesmysqlavec différents mots de passe pour le serveurrootMySQL, vous souhaiterez peut être créer un utilisateur communmulti_adminà chaque base, avec le même mot de passe (voir ci-dessous). Voici comment faire :shell>
mysql -u root -S /tmp/mysql.sock -proot_password -e"GRANT SHUTDOWN ON *.* TO multi_admin@localhost IDENTIFIED BY 'multipass'"See Section 5.5.2, « Comment fonctionne le système de droits ». Vous devrez utiliser la même commande pour chaque serveur
mysqldqui fonctionne : changez simplement la socket,-S=...). -
pid-fileest très important, si vous utilisezsafe_mysqldpour démarrermysqld(e.g.,--mysqld=safe_mysqld). Chaquemysqlddoit avoir son propre fichierpid-file. L'avantage d'utilisersafe_mysqldau lieu demysqldest quesafe_mysqld``surveille'' tous les processusmysqldet les redémarrera si un processusmysqlds'arrête suite à la reception d'un signalkill -9, ou pour toute autre raison comme une erreur de segmentation (que MySQL ne devrait jamais faire, bien sûr !). Notez bien que le scriptsafe_mysqldvous imposera peut être d'être démarré depuis un dossier spécial. Cela signifie que vous devrez probablement utiliser la commande shellcdjusqu'à un certain dossier avant de pouvoir exécutermysqld_multi. Si vous avez des problèmes pour démarrer, voyez le scriptsafe_mysqld. Vérifiez notamment ces lignes :---------------------------------------------------------------- MY_PWD=`pwd` # Check if we are starting this relative (for the binary release) if test -d $MY_PWD/data/mysql -a -f ./share/mysql/english/errmsg.sys -a \ -x ./bin/mysqld ----------------------------------------------------------------
See Section 5.1.3, «
safe_mysqld, le script père demysqld». Le test ci-dessus devrait fonctionner, ou bien vous rencontrerez probablement des problèmes. -
Le fichier de socket et le port TCP/IP doivent être différents pour chaque
mysqld. -
Vous pouvez utiliser l'option
--userdemysqld, mais afin de faire cela, vous devez exécuter le scriptmysqld_multien tant querootUnix. Placer cette option dans le fichier de configuration ne changera rien : vous obtiendrez une alerte, si vous n'êtes pas le super utilisateur, et les démonsmysqldseront démarrés avec vos droits Unix. -
Important : assurez-vous bien que le fichier de données et le fichier de
pid-filesont accessibles en lecture et écriture (et exécution pour le dernier) à l'utilisateur Unix qui lance les processusmysqld. N'utilisez pas le compte root Unix pour cela, à moins que vous ne sachiez ce que vous faîtes. -
Très important : assurez-vous de bien comprendre la signification des options que vous passez à
mysqlds et pourquoi vous avez besoin de plusieurs processusmysqld. Méfiez vous des pièges des serveurs multiplesmysqlddans le même dossier de données. Utilisez des dossiers de données à moins que vous ne sachiers ce que vous faîtes. Démarrer plusieurs serveursmysqlds dans le même dossier ne vous donnera aucun gain de performance dans un système threadé. See Section 5.10, « Faire fonctionner plusieurs serveurs MySQL sur la même machine ».
Voici un exemple de fichier de configuration fourni par mysqld_multi.
# This file should probably be in your home dir (~/.my.cnf) or /etc/my.cnf # Version 2.1 by Jani Tolonen [mysqld_multi] mysqld = /usr/local/bin/safe_mysqld mysqladmin = /usr/local/bin/mysqladmin user = multi_admin password = multipass [mysqld2] socket = /tmp/mysql.sock2 port = 3307 pid-file = /usr/local/mysql/var2/hostname.pid2 datadir = /usr/local/mysql/var2 language = /usr/local/share/mysql/english user = john [mysqld3] socket = /tmp/mysql.sock3 port = 3308 pid-file = /usr/local/mysql/var3/hostname.pid3 datadir = /usr/local/mysql/var3 language = /usr/local/share/mysql/swedish user = monty [mysqld4] socket = /tmp/mysql.sock4 port = 3309 pid-file = /usr/local/mysql/var4/hostname.pid4 datadir = /usr/local/mysql/var4 language = /usr/local/share/mysql/estonia user = tonu [mysqld6] socket = /tmp/mysql.sock6 port = 3311 pid-file = /usr/local/mysql/var6/hostname.pid6 datadir = /usr/local/mysql/var6 language = /usr/local/share/mysql/japanese user = jani
Cette section présente la configuration du serveur MySQL :
-
Options de démarrage que le serveur supporte
-
Comment utiliser le mode SQL du serveur
-
Les variables serveurs
-
Les variables de statut du serveur
Lorsque vous démarrez le serveur mysqld, vous pouvez spécifier les options de programme en utilisant les méthodes décrites dans la section Section 4.3, « Spécifier des options aux programmes ». Les méthodes les plus courantes sont celles du fichier d'options et celle de la ligne de commande. Cependant, dans la plupart des cas, vous devrez vous assurer que le serveur utilise toujours les mêmes options à chaque redémarrage : il est recommandé de les mettre dans le fichier d'options. See Section 4.3.2, « Fichier d'options my.cnf ».
mysqld et mysqld.server lisent les options des groupes mysqld et server. mysqld_safe lit les options des groupes mysqld, server, mysqld_safe et safe_mysqld. Un serveur MySQL intégré lit généralement les options dans les groupes server, embedded et xxxxx_SERVER, où xxxxx est le nom de l'application.
mysqld accepte de nombreuses options de ligne de commande. Pour une liste complète, utilisez la commande mysqld --help. Avant MySQL 4.1.1, --help affiche un message d'aide complet. Depuis 4.1.1, il affiche un bref message. Pour voir la liste complète, utilisez mysqld --verbose --help.
La liste suivante montre les options de serveur les plus courantes. Les options supplémentaires sont détaillées ailleurs.
-
Options qui affectent la sécurité : voir Section 5.4.3, « Options de démarrage qui concernent la sécurité ».
-
Options liées à SSL : voir Section 5.6.7.5, « Options SSL en ligne de commande ».
-
Options de contrôle des logs binaires : voir Section 5.9.4, « Le log binaire ».
-
Options de réplication : voir Section 6.8, « Options de démarrage de la réplication ».
-
Options spécifiques à un moteur de table particulier : voir Section 14.1.1, « Options de démarrage
MyISAM», Section 14.4.3, « Options de démarrageBDB», Section 15.5, « Options de démarrageInnoDB».
Vous pouvez aussi modifier les valeurs des variables système en utilisant le nom de l'option comme variable système, tel que décrit ultérieurement.
-
--help, -?Affiche l'aide courte et termine le programme. Avant MySQL 4.1.1,
--helpaffiche un message d'aide complet. Depuis 4.1.1, il affiche un bref message. Pour voir la liste complète, utilisezmysqld --verbose --help. -
--allow-suspicious-udfsCette option contrôle le fait que les fonctions utilisateurs qui disposent d'un seul symbôle
xxxpuissent être chargées. Par défaut, cette option est désactivée, et seule les UDF qui ont au moins un symbole auxiliaire peuvent être chargées. Cela évite de charger des fonctions issues d'un objet partagé qui ne serait pas une fonction utilisateur légitime. Cette option a été ajoutée en MySQL 4.0.24, 4.1.10a et 5.0.3. See Section 27.2.3.6, « Précautions à prendre avec les fonctions utilisateur ». -
--ansiUtilise la syntaxe ANSI SQL au lieu de la syntaxe MySQL. See Section 1.5.3, « Exécuter MySQL en mode ANSI ». Pour un contrôle plus précis sur le mode SQL serveur, utilisez l'option
--sql-mode. -
--basedir=path, -b pathChemin jusqu'au dossier d'installation. Tous les chemins sont généralement relatifs à celui-ci.
-
--big-tablesAutorise la sauvegarde de grands résultats dans des fichiers temporaires. Cela résout le problème des erreurs "
table full", mais ralentit les requêtes alors que des tables en mémoire suffirait. Depuis la version version 3.23.2, MySQL est capable de résoudre automatiquement ce problème en utilisant de la mémoire pour toutes les tables temporaires de petite taille, et en passant sur le disque au besoin. -
--bind-address=IPL'adresse IP à utiliser.
-
--consoleEcrit les messages d'erreurs du log d'erreur sur la sortie standard, même si
--log-errorest spécifiée. Sous Windows,mysqldne ferme pas l'écran de console si cette option est utilisée. -
--character-sets-dir=pathDossier contenant les jeux de caractères. See Section 5.8.1, « Le jeu de caractères utilisé pour les données et le stockage ».
-
--chroot=pathMet le démon
mysqlden environnement chroot au démarrage. Recommandé pour la sécurité depuis MySQL 4.0. (MySQL 3.23 n'est pas capable de fournir un encadrementchroot()qui soit 100% étanche). Cela limite les commandesLOAD DATA INFILEetSELECT ... INTO OUTFILE. -
--core-fileEcrire le fichier core lorsque
mysqlds'arrête inopinément. Pour certains fichiers, vous devez aussi spécifier--core-file-sizeàsafe_mysqld. See Section 5.1.3, «safe_mysqld, le script père demysqld». Notez que sur certains systèmes, comme Solaris, vous n'aurez pas de fichier de core si vous avez aussi utilisé l'option--user. -
--datadir=path, -h pathChemin jusqu'au dossier de données.
-
--debug[=debug_options], -# [debug_options]Si MySQL est configuré avec
--with-debug, vous pouvez utiliser cette option pour obtenir un fichier de trace de ce quemysqldfait. See Section D.1.2, « Créer un fichier de tra¸age ». -
--default-character-set=charsetSpécifie le jeu de caractères par défaut. See Section 5.8.1, « Le jeu de caractères utilisé pour les données et le stockage ».
-
--default-collation=collationSpécifie la
collationpar défaut. Cette option est disponible depuis MySQL 4.1.1. See Section 5.8.1, « Le jeu de caractères utilisé pour les données et le stockage ». -
--default-storage-engine=typeCette option est un synonyme de
--default-table-type. Cette option est disponible depuis MySQL 4.1.2. -
--default-table-type=typeSpécifie le type de table par défaut. See Chapitre 14, Moteurs de tables MySQL et types de table.
-
--delay-key-write[= OFF | ON | ALL]Comment l'option
DELAYED KEYSdoit être utilisée. Les écritures différées font que les buffers de clés ne sont pas écrits entre deux écriture pour les tablesMyISAM.OFFdésactive les écritures différées.ONactive les écritures différées pour les tables qui ont été créées avec l'optionDELAYED KEYS.ALLactive les écritures différées pour les tablesMyISAM. Cette option est disponible depuis MySQL 4.0.3. See Section 7.5.2, « Réglage des paramètres du serveur ». See Section 14.1.1, « Options de démarrageMyISAM».Note : Si vous avez donné la valeur de
ALLà cette option, vous ne devez pas utiliser les tablesMyISAMdepuis un autre programme (commemyisamchk) lorsque la tables utilisée. En faisant cela, vous obtiendrez une corruption d'index. -
--delay-key-write-for-all-tablesAncienne forme de
--delay-key-write=ALLà utiliser sur les versions antérieures à la version 4.0.3. Depuis la version 4.0.3, utilisez--delay-key-write. -
--des-key-file=file_nameLit les clés par défaut utilisées par
DES_ENCRYPT()etDES_DECRYPT()dans ce fichier. -
--enable-named-pipeActive le support des pipes nommés (seulement sur NT/Win2000/XP). Cette option ne s'applique qu'aux systèmes Windows NT, 2000 et XP, et peut être utilisé avec les serveurs
mysqld-ntetmysqld-max-ntqui supportent les pipes nommés. -
--exit-info, -TCette option est la combinaison d'options que vous pouvez utiliser pour le débogage du serveur
mysqld. Si vous ne savez pas ce que ca fait exactement, ne l'utilisez pas ! -
--external-lockingActive le verrouillage système. Notez que si vous utilisez cette option sur un système pour qui
lockdne fonctionne pas (comme Linux), vous allez bloquer rapidementmysqldavec les verrous. Anciennement appelée--enable-locking.Note : si vous utilisez cette option pour activer des modifications de tables
MyISAMdepuis plusieurs processus MySQL, vous devez vous assurer de trois conditions :-
Vous n'utilisez pas de cache de requête pour les requêtes qui utilisent les tables sont modifiées par un autre processus.
-
Vous ne devez pas utiliser
--delay-key-write=ALLouDELAY_KEY_WRITE=1sur des tables partagées.
Le plus simple pour s'assurer de cela est de toujours utiliser l'option
--external-lockingavec--delay-key-write=OFF --query-cache-size=0.(Ceci n'est pas fait par défaut, car dans de nombreuses configurations, il est pratique de faire un mélange des options ci-dessus).
-
-
--flushEcrit toutes les données sur le disque après chaque requête SQL. Normalement, MySQL fait des écritures sur le disque après chaque requête, et laisse le système d'exploitation assurer la synchronisation avec le disque. See Section A.4.2, « Que faire si MySQL plante constamment ? ».
-
--init-file=fileLit les commandes SQL dans ce fichier au démarrage. Chaque commande doit être sur une ligne, et ne pas utiliser de commentaires.
-
--language=lang_name, -L lang_nameSpécifie la langue utilisée pour les messages d'erreur du client. Le chemin complet doit être utilisé. See Section 5.8.2, « Langue des messages d'erreurs ».
-
--log[=file], -l [file]Enregistre les connexions et les requêtes dans ce fichier. See Section 5.9.2, « Le log général de requêtes ». Si vous ne le faites pas, MySQL va utiliser
host_name.logcomme nom de fichier. -
--log-bin=[file]Enregistre toutes les requêtes qui modifient des données dans un log. See Section 5.9.4, « Le log binaire ». Ce log est utilisé pour la sauvegarde et la réplication. Si vous ne le faites pas, MySQL va utiliser
host_name-bincomme nom de fichier. -
--log-bin-index[=file]Fichier d'index pour les noms de fichiers de log binaire. See Section 5.9.4, « Le log binaire ». Si vous ne le faites pas, MySQL va utiliser
host_name-bin.indexcomme nom de fichier. -
--log-error[=file]Enregistre les messages d'erreurs et les messages de démarrage dans ce fichier. See Section 5.9.1, « Le log d'erreurs ». Si vous ne le faites pas, MySQL va utiliser
host_name.errcomme nom de fichier. -
--log-isam[=file]Enregistre toutes les modifications des tables
ISAM/MyISAMdans ce fichier (uniquement nécessaire pour déboguerISAM/MyISAM). -
--log-long-formatEnregistre des informations supplémentaires dans les fichiers de log (log de modifications, log binaire de modifications, log de requêtes lentes, n'importe quel log en fait). Par exemple, le nom d'utilisateur et un timestamp sont enregistrés avec la requête. Si vous utilisez
--log-slow-querieset--log-long-format, alors les requêtes qui n'utilisent pas d'index seront aussi enregistrées. Notez que--log-long-formatest obsolète depuis la version 4.1, où--log-short-formata été introduite (le format de log long est la configuration par défaut en version 4.1). Notez aussi que depuis la version MySQL 4.1 l'option--log-queries-not-using-indexesest disponible pour enregistre spécifiquement les requête qui n'utilisent pas d'index, dans le log de requêtes lentes. -
--log-queries-not-using-indexesSi vous utilisez cette option avec
--log-slow-queries, alors les requêtes qui n'utilisent pas d'index seront aussi enregistrées dans le log de requêtes lentes. Cette option est disponible depuis MySQL 4.1. See Section 5.9.5, « Le log des requêtes lentes ». -
--log-short-formatEnregistre moins d'information dans les fichiers de log (log de modifications, log binaire de modifications, log de requêtes lentes, n'importe quel log en fait). Par exemple, les noms d'utilisateur et un timestamp ne seront pas enregistrés avec les requêtes. Cette option a été ajoutée en MySQL 4.1.
-
--log-slow-queries[=file]Enregistre toutes les requêtes qui prennent plus de
long_query_timesecondes a s'exécuter. Notez que la quantité d'information enregistrée par défaut a changé en MySQL 4.1. Voyez les options--log-long-formatet--log-long-formatpour plus de détails. See Section 5.9.5, « Le log des requêtes lentes ». -
--log-update[=file]Enregistre les modifications de données dans le fichier
file.#où#est un nombre unique, s'il n'est pas fourni. See Section 5.9.3, « Le log de modification ». Le log de modification est obsolète et supprimé en MySQL 5.0.0; vous devriez utiliser le log binaire à la place. (--log-bin). See Section 5.9.4, « Le log binaire ». Depuis la version 5.0.0, utilisez--log-updateva simplement activer le log binaire. (see Section C.1.7, « Changements de la version 5.0.0 (22 décembre 2003 : Alpha) »). -
--log-warnings, -WAffiche les alertes comme
Aborted connection...dans le fichier d'erreur.err. Activer cette option est recommandé, par exemple, si vous utilisez la réplication : vous obtiendrez plus d'informations sur ce qui se passe, comme les erreurs de connexion réseau, ou les reconnexions. Cette option est activée par défaut depuis MySQL 4.1.2; pour la désactiver, utilisez--skip-log-warnings. See Section A.2.10, « Erreurs de communication / Connexion annulée ».Cette option s'appelait
--warningsavant MySQL 4.0. -
--low-priority-updatesLes opérations de modifications de table (
INSERT/DELETE/UPDATE) auront une priorité inférieure aux sélections. Cela peut être aussi fait via l'attribut{INSERT | REPLACE | UPDATE | DELETE} LOW_PRIORITY ...pour baisser la priorité d'une requête, ou avecSET LOW_PRIORITY_UPDATES=1pour changer la priorité dans plus d'un thread. See Section 7.3.2, « Problème de verrouillage de tables ». -
--memlockVerrouille le processus
mysqlden mémoire. Cela fonctionne si votre système support la fonctionmlockall()(comme Solaris). Ceci peut être utile si vous avez des problèmes avec le système d'exploitation qui forcemysqldà utiliser le swap sur le disque. -
--myisam-recover [=option[,option...]]]Cette option est la combinaison de
DEFAULT,BACKUP,FORCEetQUICK. Vous pouvez aussi lui donner la valeur explicite de""si vous voulez désactiver cette option. Si cette option est utilisée,mysqldva vérifier si la table est marquée comme corrompue à l'ouverture de chaque table (cette dernière option ne fonctionne que si vous utilisez l'option--skip-external-locking). Si c'est le cas,mysqldva essayer de vérifier la table. Si la table était corrompue,mysqldessaie alors de la réparer.L'option suivante va affecter la manière avec la quelle la réparation s'effectue.
Option Description DEFAULTIdentique à ne pas donner d'option à --myisam-recover.BACKUPSi la table a été modifiée durant la réparation, sauver une copie du fichier table_name.MYD, sous le nom detable_name-datetime.BAK.FORCEExécute une réparation même si nous allons perdre une ou plusieurs lignes dans le fichier .MYD.QUICKNe vérifie pas les lignes dans la table si il n'y a pas eu d'effacement. Avant que la table ne soit automatiquement réparée, MySQL va ajouter une note dans le fichier de log d'erreurs. Si vous voulez être capable de restaurer la plupart des erreurs sans intervention de l'utilisateur, il vaut utiliser les options
BACKUP,FORCE. Cela va forcer la réparation de la table, même si quelques lignes sont effacées, et conserve le vieux fichier de données comme sauvegarde, pour examen ultérieur.Cette option est disponible depuis MySQL 3.23.25.
-
--newDepuis la version 4.0.12, l'option
--newsert à dire au serveur d'adopter le comportement de la version 4.1 pour certains aspects, afin de simplifier la migration de 4.0 en 4.1 :-
TIMESTAMPest retourné sous forme de chaîne avec le format'YYYY-MM-DD HH:MM:SS'. See Chapitre 11, Types de colonnes.
Cette option peut vous aider à voir comment vos applications vont se comporter en MySQL 4.1, sans réellement changer de version.
-
-
--pid-file=pathLe chemin jusqu'au fichier de
PIDutilisé parsafe_mysqld. -
--port=port_num, -P port_numNuméro de port utilisé pour attendre les connexion TCP/IP.
-
--old-protocol, -oUtilise le protocole 3.20, pour la compatibilité avec de très vieux clients. See Section 2.6.6, « Passer de la version 3.20 à la version 3.21 ».
-
--one-threadUtilise uniquement un thread (pour débogage sous Linux). Cette option est disponible uniquement si le serveur est compilé avec les options de débogage. See Section D.1, « Déboguer un serveur MySQL ».
-
--open-files-limit=countPour changer le nombre de pointeurs de fichiers disponibles pour
mysqld. Si cette option n'est pas configurée, ou qu'elle vaut 0, alorsmysqldva utiliser cette valeur pour réserver ce nombre de pointeurs de fichiers, à utiliser avecsetrlimit(). Si la valeur est 0 alorsmysqldva réservermax_connections*5oumax_connections + table_cache*2(le plus grand des deux) pointeurs de fichiers. Il est recommandé d'augmenter cette valeur simysqldémet des erreurs de type'Too many open files'. -
--safe-modeIgnore certains étapes d'optimisation.
-
--safe-show-databaseAvec cette option, la commande
SHOW DATABASESretourne uniquement les bases pour lesquelles l'utilisateur a des droits. Depuis la version 4.0.2, cette option est abandonnée, et ne fait plus rien (l'option est activée par défaut) car nous avons désormais le droit deSHOW DATABASES. See Section 13.5.1.3, « Syntaxe deGRANTetREVOKE». -
--safe-user-createSi cette option est activée, un utilisateur ne peut pas créer de nouveaux utilisateurs avec la commande GRANT si l'utilisateur n'a pas les droits de
INSERTdans la tablemysql.userou dans aucune colonne de cette table. -
--secure-authInterdit l'identification des comptes qui ont des mots de passe ancien (avant la version 4.1). Cette option est disponible depuis MySQL 4.1.1.
-
--skip-bdbDésactive l'utilisation des tables
BDB. Cela va économiser de la mémoire et accélérer le serveur un peu. N'utilisez pas cette option si vous avez besoin des tablesBDB. -
--skip-concurrent-insertDésactive la possibilité de sélectionner et insérer en même temps dans les tables
MyISAM(cela n'est utile que si vous pensez que vous avez trouvé un bug dans cette fonctionnalité). -
--skip-delay-key-writeIgnore l'option
DELAY_KEY_WRITEde toutes les tables. Depuis MySQL 4.0.3, vous devez utiliser--delay-key-write=OFFà la place. See Section 7.5.2, « Réglage des paramètres du serveur ». -
--skip-external-lockingNe pas utiliser le verrouillage du système. Pour utiliser les utilitaires
isamchkoumyisamchkvous devez alors éteindre le système. See Section 1.2.3, « Jusqu'à quel point MySQL est il stable ? ». Notez qu'en MySQL version 3.23 vous pouvez utiliser la commandeREPAIRetCHECKpour réparer ou vérifier des tablesMyISAMtables. Cette option s'appelait auparavant--skip-locking. -
--skip-grant-tablesCette option force le serveur à ne pas utiliser le système de privilège du tout. Cela donne à tous l'accès complet à toutes les bases de données ! Vous pouvez demander à un serveur en exécution d'utiliser à nouveau les tables de droits en exécutant la commande
mysqladmin flush-privilegesoumysqladmin reload). -
--skip-host-cacheNe pas utiliser le cache de nom de domaine pour une résolution des IP plus rapide, mais interroger le serveur DNS à chaque connexion. See Section 7.5.6, « Comment MySQL utilise le DNS ».
-
--skip-innodbDésactive l'utilisation des tables
InnoDB. Cela va économiser de la mémoire et accélérer le serveur un peu. N'utilisez pas cette option si vous avez besoin des tablesInnoDB. -
--skip-isamDésactive l'utilisation des tables
ISAM. Cela va économiser de la mémoire et accélérer le serveur un peu. Depuis MySQL 4.1,ISAMest désactivé par défaut, ce qui fait que cette option n'apparaît que si le serveur a été configuré avec le support N'utilisez pas cette option si vous avez besoin des tablesISAM. -
--skip-name-resolveLes noms d'hôtes ne sont pas résolus. Toutes les colonnes
Hostdans vos tables de droits doivent être des IP numériques ou le motlocalhost. See Section 7.5.6, « Comment MySQL utilise le DNS ». -
--skip-networkingNe pas attendre les connexions TCP/IP du tout. Toutes les interactions du serveur
mysqldseront faites avec les sockets Unix. Cette option est particulièrement recommandée pour les systèmes qui utilisent des requêtes locales. See Section 7.5.6, « Comment MySQL utilise le DNS ». -
--skip-newNe pas utiliser les nouvelles routines qui sont possiblement erronées.
-
--skip-symlinkC'est l'ancienne forme de
--skip-symbolic-links, à utiliser avant MySQL 4.0.13. -
--symbolic-links, --skip-symbolic-linksActive ou désactive le support des liens symboliques. Cette option a différents effets sur Windows et sur Unix.
-
Sous Windows, activer les liens symboliques vous permet d'établir un lien symbolique vers une base de données, en créant un fichier
directory.symqui contient le chemin réel. See Section 7.6.1.3, « Utiliser des liens symboliques pour les bases de données sous Windows ». -
Sous Unix, activer les liens symboliques signifie que vous pouvez mettre un fichier d'index
MyISAMou un autre fichier de données dans un autre dossier, avec les optionsINDEX DIRECTORYouDATA DIRECTORYde la commandeCREATE TABLE. Si vous effacer ou renommez la table, les fichiers qui sont des liens symboliques seront aussi effacés ou renommés. See Section 13.2.5, « Syntaxe deCREATE TABLE».
Cette option est disponible depuis MySQL 4.0.13.
-
-
--skip-show-databaseSi MySQL est configuré avec
--with-debug=full, tous les programmes vérifieront la mémoire pour rechercher les écrasements de zone lors des allocations et libérations de mémoire. Comme ce test est lent, vous pouvez l'éviter, si vous n'avez pas besoin de tester la mémoire, en utilisant cette option. -
--skip-show-databaseNe pas autoriser la commande
SHOW DATABASES, a moins que l'utilisateur n'ait les droits deSHOW DATABASES. Depuis la version 4.0.2, vous n'avez plus besoin de cette option, car les droits pour ce faire sont distribués avec le droit deSHOW DATABASES. -
--skip-stack-traceNe pas écrire les piles de traces. Cette option est pratique lorsque vous utilisez
mysqldavec un débogueur. Sur certains systèmes, vous devez aussi utiliser cette option pour obtenir un fichier de core. See Section D.1, « Déboguer un serveur MySQL ». -
--skip-thread-priorityDésactive les priorités des threads pour améliorer la vitesse de réponse.
-
--socket=pathSous Unix, le fichier de socket pour les connexions locales. (par défaut,
/tmp/mysql.sock). Sous Windows, le nom du pipe à utiliser pour les connexions locales qui utilisent un pipe nommé (par défaut, MySQL). -
--sql-mode=value[,value[,value...]]Spécifie le mode SQL. See Section 5.2.2, « Le mode SQL du serveur ». Cette option est disponible depuis 3.23.41.
-
--temp-poolEn utilisant cette option, vous allez réduire le jeu de noms qui sont utilisés lors de la création de fichier temporaires, plutôt qu'un nom unique à chaque fois. Ceci est un palliatif au noyau Linux qui crée plusieurs fichiers nouveaux avec des noms différents. Avec l'ancien comportement, Linux semble "perdre de la mémoire", car ils sont alloués au cache d'entrées du dossier au lieu de celui du disque.
-
--transaction-isolation=levelConfigure le niveau d'isolation des transactions. Le niveau peut être
READ-UNCOMMITTED,READ-COMMITTED,REPEATABLE-READouSERIALIZABLE. See Section 13.4.6, « Syntaxe deSET TRANSACTION». -
--tmpdir=path, -t pathChemin vers les fichiers temporaires. Il peut s'avérer pratique si votre dossier par défaut
/tmpréside dans une partition qui est trop petite pour absorber les tables temporaires. Depuis MySQL MySQL 4.1, cette option accepte différents chemins, qui sont utilisés en alternance. Les chemins doivent être séparés par des deux points (‘:’) sous Unix et des points-virgules (‘;’) sous Windows. Il est possible de dire àtmpdirde pointer sur un système de fichiers en mémoire, hormis si le serveur MySQL est un esclave. Si c'est un esclave, il faut un système de fichiers permanents (pour que la réplication des tables temporaires et des commandesLOAD DATA INFILE) survive a un redémarrage de la machine : un système de fichiers en mémoiretmpdir, qui est effacé au lancement de la machine n'est pas acceptable. Un disque est nécessaire pourtmpdir, dans ce contexte. -
--user={user_name | user_id}, -u {user_name | user_id}Exécute le démon
mysqldavec l'utilisateuruser_nameouuserid(numérique). (``utilisateur'' dans ce contexte fait référence à l'utilisateur du système d'exploitation, mais pas l'utilisateur MySQL, listé dans les tables de droits.)Cette option est obligatoire lorsque vous démarrez
mysqlden tant queroot. Le serveur va changer d'ID durant le lancement du serveur, pour utiliser un autre utilisateur queroot. See Section 5.4, « Sécurité générale du serveur ».Depuis MySQL 3.23.56 et 4.0.12: Pour éviter des trous de sécurité si un utilisateur ajoute
--user=rootdans un fichiermy.cnf(et donc, faisant que le serveur fonctionne en tant que utilisateur systèmeroot),mysqldutilise uniquement la première option--userspécifiée, et produit une alerte s'il rencontre d'autres options--user. Les options des fichiers/etc/my.cnfetdatadir/my.cnfsont traités avant les options de ligne de commande, et il est recommandé que vous ajoutiez l'option--userdans le fichier/etc/my.cnfpuis spécifiez une valeur autre queroot. L'option de/etc/my.cnfpeut être placée avant toute autre option--user, ce qui assure que le serveur fonctionnera avec l'utilisateur autre queroot, et qu'une alerte apparaîtra si une autre option--userest découverte. -
--version, -VAffiche les informations de version.
Vous pouvez assigner une valeur à une variable système en utilisant une option de la forme --nom_de_variable=valeur. Par exemple, --key_buffer_size=32M donne à la variable key_buffer_size la valeur de 32 Mo.
Notez que lorsque vous donnez une valeur à une variable, MySQL peut corriger automatiquement la valeur pour qu'elle reste dans un intervalle donné, ou peut ajuster la valeur à la valeur possible la plus proche.
Il est aussi possible de donner des valeurs aux variables avec la syntaxe --set-variable=var_name=value ou -O var_name=value. Notez que cette syntaxe est abandonnée depuis MySQL 4.0.
Vous pouvez trouver une description complète de toutes les variables dans la section Section 5.2.3, « Variables serveur système ». La section sur le paramétrage du serveur inclut des détails sur l'optimisation. See Section 7.5.2, « Réglage des paramètres du serveur ».
Vous pouvez changer la valeur de la plupart des variables système sur un serveur en fonctionnement avec la commande SET. See Section 13.5.2.8, « Syntaxe de SET ».
Si vous voulez limiter la valeur maximale qu'une option recevra avec la commande SET, vous pouvez la définir en utilisant l'option --maximum-nom_de_variable en ligne de commande.
Le serveur MySQL peut fonctionner avec différent modes SQL, et, depuis MySQL 4.1, il peut appliquer ces modes au niveau de la connexion du client. Cela permet aux applications d'adapter le comportement du serveur en fonction de leur attentes.
Le mode définit quelle syntaxe SQL MySQL doit supporter, et quels types de vérification il doit faire. Cela rend plus facile l'utilisation de MySQL dans différents environnement, et la connexion avec les autres serveurs de base de données.
Vous pouvez donner un mode SQL par défaut au démarrage de mysqld avec l'option --sql-mode="modes". Lav aleur peut aussi être vide (--sql-mode="") si vous voulez la remettre à 0.
Depuis MySQL 4.1, vous pouvez aussi changer le mode après le démarrage en modifiant la variable sql_mode avec la commande SET [SESSION|GLOBAL] sql_mode='modes'. Modifier la variable GLOBAL affecte les opérations de tous les clients qui se connecteront. En modifiant la variable SESSION, cela n'affectera que le client courant.
modes est une liste de modes différents, séparés par des virgules (‘,’). Vous pouvez lire le mode courant avec la commande SELECT @@sql_mode. La valeur par défaut est vide (par de modes configurés).
-
Change la syntaxe et le comportement pour être plus compatible avec le standard SQL. (Nouveau en MySQL 4.1.1)
-
Si une valeur n'a pas pu être insérée dans une table transactionnelle sans modification, la commande est annulée. Pour une table non-transactionnelle, la commande est annulée si cela survient dans une ligne unique ou dans la première ligne d'une insertion multiple. Plus de détails sont donnés ultérieurement dans cette section. (Nouveau en MySQL 5.0.2)
-
MySQL se comporte comme un système SQL ``traditionnel''. Une description simple est que ce mode ``émet une erreur et non pas une alerte'' lors de l'insertion d'une valeur incorrecte dans une colonne. Note : si vous utilisez un moteur de table non-transactionnel, les commandes
INSERT/UPDATEs'arrêteront dès que l'erreur est repérée, ce qui n'est pas forcément ce que vous voudrez. (Nouveau en MySQL 5.0.2)
Lorsque cette documentation fait référence au mode strict, cela signifie qu'au moins un des modes STRICT_TRANS_TABLES ou STRICT_ALL_TABLES est activé.
La liste suivante présente les différents modes supportés :
-
N'autorise pas la vérification totale des dates. Vérifie simplement que le mois est dans l'intervalle de 1 à 12, et que le jour est dans l'intervalle de de 1 à 31. C'est très pratique pour les applications Web où la date est obtenue de 3 champs différents, et que vous voulez stocker exactement la date saisie sans validation. Ce mode s'applique aux colonnes de type
DATEetDATETIME. Il ne s'applique pas aux colonnesTIMESTAMP, qui demandent toujours une date valide.Ce mode est nouveau en MySQL 5.0.2. Avant 5.0.2, c'était le mode par défaut de gestion des dates. Depuis 5.0.2, activer le mode strict impose au serveur de vérifier la validité des dates, et non pas seulement les intervalles. Par exemple,
'2004-04-31'est valide sans le mode strict, mais ne l'est plus avec le mode strict. Pour permettre ces valeurs malgré le mode strict, utilisez le modeALLOW_INVALID_DATES. -
Traite ‘
"’ comme un délimiteur d'identifiant (comme le caractère MySQL ‘`’) et non comme un délimiteur de chaînes. Vous pouvez toujours utiliser ‘`’ pour délimiter les identifiants en mode ANSI. AvecANSI_QUOTESactivée, vous ne pouvez pas utiliser les guillemets doubles pour délimiter une chaîne de caractères, car ce sera uniquement interprété comme un identifiant. (Nouveau en MySQL 4.0.0.) -
Produit une erreur en mode strict et sinon une alerte, lorsque MySQL doit tenter une division par 0 ou un
MOD(X,0)) durant une commandeINSERT/UPDATE. Si ce mode n'est pas activé, MySQL retourne simplementNULLpour les divisions par zéro. Si utilisé avec l'attributIGNORE, MySQL génère une alerte pour les divisions par zéro, mais le résultat de l'opération seraNULL. (Nouveau en MySQL 5.0.2) -
Permet les espaces entre le nom de la fonction et le caractère ‘
(’. Cela force les noms de fonctions a être traités comme des mots réservés. En conséquence, si vous voulez accéder aux bases, tables et colonnes dont le nom est un mot réservé, vous devez le mettre entre délimiteurs. Par exemple, comme la fonctionUSER()existe, le nom de la tableuserde la basemysqlet la colonneUserde cette table doivent être protégés :SELECT "User" FROM mysql."user";
(Nouveau en MySQL 4.0.0.)
-
NO_AUTO_VALUE_ON_ZEROaffecte la gestion des colonnes de typeAUTO_INCREMENT. Normalement, vous générez le prochain numéro de séquence dans la colonne en insérant soitNULLsoit0dedans.NO_AUTO_VALUE_ON_ZEROsupprime ce comportement pour0pour que seule la valeurNULLgénère le prochain numéro de séquence. Ce mode est utile si vous avez stocké la valeur0dans la colonneAUTO_INCREMENTde la table. Ce n'est pas recommandé. Par exemple, si vous voulez exporter une table avecmysqldumpet que vous la rechargez, normalement MySQL va générer de nouveaux identifiants pour les lignes avec la valeur0, ce qui entraînera une différence avec la table originale. En activantNO_AUTO_VALUE_ON_ZEROavant de recharger le fichier exporter, vous éviter de problème. Depuis MySQL 4.1.1,mysqldumpva automatiquement inclure les commandes nécessaires dans l'export, pour activerNO_AUTO_VALUE_ON_ZERO. (Nouveau en MySQL 4.1.1.) -
Lors de la création d'une table, ignore les directives
INDEX DIRECTORYetDATA DIRECTORY. Cette option est pratique sur un esclave de réplication. (Nouveau en MySQL 4.0.15.) -
N'affiche pas les options spécifiques à MySQL dans le résultat de
SHOW CREATE TABLE. Ce mode est utilisé parmysqldumpdans un souci de portabilité. (Nouveau en MySQL 4.1.1.) -
N'affiche pas les options spécifiques à MySQL dans le résultat de
SHOW CREATE TABLE. Ce mode est utilisé parmysqldumpdans un souci de portabilité. (Nouveau en MySQL 4.1.1.) -
N'affiche pas les options de tables spécifiques à MySQL (comme
ENGINE) dans le résultat deSHOW CREATE TABLE. Ce mode est utilisé parmysqldumpdans un souci de portabilité. (Nouveau en MySQL 4.1.1.) -
Ne permet pas l'utilisation de
'0000-00-00'comme date valide. Vous pouvez toujours insérer des dates nulles avec l'optionIGNORE. (Nouveau en MySQL 5.0.2) -
N'accepte pas les dates où le mois ou le jour vaut 0. Si utilisé avec L'option
IGNORE, la date'0000-00-00'sera insérée pour chaque date invalide. (Nouveau en MySQL 5.0.2) -
Dans les opérations de soustraction, ne marque pas le résultat
UNSIGNEDsi un des opérandes est non signé. Notez que cela fait queUNSIGNED BIGINTn'est plus totalement utilisable dans tous les contextes. See Section 12.7, « Fonctions de transtypage ». (Nouveau en MySQL 4.0.2.) -
N'autorise pas les requêtes dont la clause
GROUP BYfait référence à une colonne qui n'est pas sélectionnée. (Nouveau en MySQL 4.0.0.) -
Traite
||comme un opérateur de concaténation (identique àCONCAT()) au lieu d'être un synonyme deOR. (Nouveau en MySQL 4.0.0.) -
Traite le type
REALcomme un synonymeFLOATplutôt que comme un synonyme deDOUBLE. (Nouveau en MySQL 4.0.0.) -
Active le mode strict pour tous les moteurs de stockage. Les valeurs invalides sont rejetées. Plus de détails suivent. (Nouveau en MySQL 5.0.2)
-
Active le mode strict pour tous les moteurs de stockage transactionnels. Les valeurs invalides sont rejetées. Plus de détails suivent. (Nouveau en MySQL 5.0.2)
Lorsque le mode strict est activé, MySQL retourne une erreur si une valeur est invalide ou manquante (aucune valeur fournie pour la colonne, et la colonne n'a pas de valeru DEFAULT explicite dans sa définition). Pour les tables transactionnelles, cela arrive lorsque le mode STRICT_ALL_TABLES et STRICT_TRANS_TABLES est activé. La commande est alors annulée. Pour les tables non-transactionnelles, MySQL gère les valeurs invalides comme ceci :
si la commande insère ou modifie une seule ligne, l'erreur survient si la valeur est invalide ou manquante. La commande est annulée et la table reste intacte. Si la commande insère ou modifie plusieurs lignes, l'effet dépend de l'option stricte activée :
-
Pour le mode
STRICT_ALL_TABLES, si une valeur est invalide ou manquante dans la première ligne, MySQL retourne une erreur et aucune ligne n'est modifiée. Si une valeur est invalide ou manquante à partir de la seconde ligne, MySQL retourne une erreur et ignore le reste des lignes. Cependant, dans ce cas, les premières lignes restent modifiées ou insérées. Cela signifie que vous risquez d'obtenir une opération partielle, ce qui n'est pas forcément souhaitable. Pour éviter cela, il est alors recommandé d'utiliser des commandes uni-lignes. -
Pour le mode
STRICT_TRANS_TABLES, si une valeur est invalide ou manquante pour la première ligne, MySQL retourne une erreur et aucune ligne n'est modifiée. Pour les lignes suivantes, si une valeur est invalide, MySQL insère la valeur valide la plus proche. Si une valeur manque, MySQL insère explicitement la valeur par défaut pour ce type de données. Dans ce cas, MySQL génère une alerte, et continue le traitement.
Le mode strict interdit l'utilisation de dates invalides comme '2004-04-31'. Il n'interdit pas les dates avec des 0 comme 2004-04-00' ou encore les dates ``zéro''. Pour les interdire, il faut activer les modes NO_ZERO_IN_DATE et NO_ZERO_DATE.
Si vous n'utilisez pas de mode strict, c'est à dire ni STRICT_TRANS_TABLES ni STRICT_ALL_TABLES, MySQL génère une alerte pour toutes les valeurs qui sont adaptées pour être insérées. See Section 13.5.3.19, « SHOW WARNINGS | ERRORS ».
Les modes suivants sont fournis comme raccourcis pour différentes combinaisons des valeurs précédentes. Tous les raccourcis sont disponibles depuis MySQL 4.1.1, hormisTRADITIONAL (5.0.2).
-
Equivalent à
REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,ONLY_FULL_GROUP_BY. See Section 1.5.3, « Exécuter MySQL en mode ANSI ». -
Equivalent à
PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS. -
Equivalent à
PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS. -
Equivalent à
PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS. -
Equivalent à
NO_FIELD_OPTIONS. -
Equivalent à
NO_FIELD_OPTIONS. -
Equivalent à
PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS. -
Equivalent à
PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS. -
Equivalent à
STRICT_TRANS_TABLES,STRICT_ALL_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO.
Le serveur entretient de nombreuses variables système qui indiquent comment il est configuré. Toutes les variables ont des valeurs par défaut. Elles peuvent être configuré au lancement du serveur, avec les options de ligne de commande, ou bien durant l'exécution, avec la commande SET.
Depuis MySQL version 4.0.3, le serveur mysqld entretient deux types de variables. Les variables globales, qui affectent les opérations générales du serveur. Et les variables de session qui affectent les comportements individuels des connexions.
Lorsque mysqld démarre, toutes les variables globales sont initialisées à partir des arguments passés en ligne de commande et des fichiers de configuration. Vous pouvez changer ces valeurs avec la commande SET GLOBAL. Lorsqu'un nouveau thread est créé, les variables spécifiques aux threads sont initialisées à partir des variables globales et ne changeront pas même si vous utilisez la commande SET GLOBAL var_name. Pour changer une variable globale, vous devez avoir les droits de SUPER.
Le serveur entretient aussi un jeu de variables de session pour chaque client qui se connecte. Les variables de session du serveur sont initialisées au moment de la connexion, en utilisant les valeurs correspondantes des variables globales. Pour les variables de session qui sont dynamiques, le client peut les changer avec la commande SET SESSION var_name. Modifier une variable de session ne requiert aucun droit spécifique, mais le client ne modifiera le comportement du serveur que pour sa connexion, et non pour les connexions des autres.
Une modification de variable globale est visible par tous les clients qui accèdent aux variables globales. Cependant, elle n'affectera les connexions des clients que pour les nouvelles connexions. Les variables de sessions déjà en court continueront à fonctionner avec la même configuration, jusqu'à leur déconnexion. Même le client qui a émis la commande SET GLOBAL ne verra aucun changement.
Lorsque vous modifiez une variable avec une option de démarrage, les valeurs de variables peuvent être spécifiées avec le suffixe K, M ou G, pour indiquer des kilo-octets, des megaoctets ou des gigaoctets. Par exemple, pour lancer le serveur avec une taille de buffer de clé de 16 Mo, vous pouvez utiliser :
mysqld --key_buffer_size=16M
Avant MySQL 4.0, vous deviez utiliser la syntaxe suivante :
mysqld --set-variable=key_buffer_size=16M
La lettre de suffixe peut être en majuscule ou en minuscule : 16M et 16m sont équivalents.
Durant l'exécution, utilisez la commande SET pour donner de nouvelles valeurs aux variables système. Dans ce contexte, les lettres de suffixes ne pourront pas être utilisées. Leur valeur peut être calculée avec l'expression suivante :
mysql> SET sort_buffer_size = 10 * 1024 * 1024;
Pour spécifier explicitement si vous voulez modifier une variable globale ou une variable de session, utilisez les options GLOBAL et SESSION :
mysql>SET GLOBAL sort_buffer_size = 10 * 1024 * 1024;mysql>SET SESSION sort_buffer_size = 10 * 1024 * 1024;
Si cette option est omise, la variable de session sera modifiée.
Les variables qui peuvent être modifiées durant l'exécution sont listées dans la section Section 5.2.3.1, « Variables système dynamiques ».
Si vous voulez restreindre le maximum possible d'une variable système, modifiée avec SET, vous pouvez spécifier ce maximum avec les options de la forme --maximum-var_name au lancement du serveur. Par exemple, pour éviter que la valeur de query_cache_size dépasse 32 Mo, utilisez l'option --maximum-query_cache_size=32M. Cette fonctionnalité est disponible depuis MySQL 4.0.2.
Vous pouvez découvrir les variables système et leur valeur avec la commande SHOW VARIABLES. Voyez Section 9.4, « Variables système » pour plus d'informations.
mysql> SHOW VARIABLES;
+---------------------------------+------------------------------+
| Variable_name | Value |
+---------------------------------+------------------------------|
| back_log | 50 |
| basedir | /usr/local/mysql |
| bdb_cache_size | 8388572 |
| bdb_home | /usr/local/mysql |
| bdb_log_buffer_size | 32768 |
| bdb_logdir | |
| bdb_max_lock | 10000 |
| bdb_shared_data | OFF |
| bdb_tmpdir | /tmp/ |
| bdb_version | Sleepycat Software: ... |
| binlog_cache_size | 32768 |
| bulk_insert_buffer_size | 8388608 |
| character_set | latin1 |
| character_sets | latin1 big5 czech euc_kr |
| concurrent_insert | ON |
| connect_timeout | 5 |
| convert_character_set | |
| datadir | /usr/local/mysql/data/ |
| default_week_format | 0 |
| delay_key_write | ON |
| delayed_insert_limit | 100 |
| delayed_insert_timeout | 300 |
| delayed_queue_size | 1000 |
| flush | OFF |
| flush_time | 0 |
| ft_boolean_syntax | + -><()~*:""&| |
| ft_max_word_len | 84 |
| ft_min_word_len | 4 |
| ft_query_expansion_limit | 20 |
| ft_stopword_file | (built-in) |
| have_bdb | YES |
| have_innodb | YES |
| have_isam | YES |
| have_openssl | YES |
| have_query_cache | YES |
| have_raid | NO |
| have_symlink | DISABLED |
| init_file | |
| innodb_additional_mem_pool_size | 1048576 |
| innodb_buffer_pool_size | 8388608 |
| innodb_data_file_path | ibdata1:10M:autoextend |
| innodb_data_home_dir | |
| innodb_fast_shutdown | ON |
| innodb_file_io_threads | 4 |
| innodb_flush_log_at_trx_commit | 1 |
| innodb_flush_method | |
| innodb_force_recovery | 0 |
| innodb_lock_wait_timeout | 50 |
| innodb_log_arch_dir | |
| innodb_log_archive | OFF |
| innodb_log_buffer_size | 1048576 |
| innodb_log_file_size | 5242880 |
| innodb_log_files_in_group | 2 |
| innodb_log_group_home_dir | ./ |
| innodb_mirrored_log_groups | 1 |
| innodb_thread_concurrency | 8 |
| interactive_timeout | 28800 |
| join_buffer_size | 131072 |
| key_buffer_size | 16773120 |
| key_cache_age_threshold | 300 |
| key_cache_block_size | 1024 |
| key_cache_division_limit | 100 |
| language | /usr/local/mysql/share/... |
| large_files_support | ON |
| local_infile | ON |
| locked_in_memory | OFF |
| log | OFF |
| log_bin | OFF |
| log_slave_updates | OFF |
| log_slow_queries | OFF |
| log_update | OFF |
| log_warnings | OFF |
| long_query_time | 10 |
| low_priority_updates | OFF |
| lower_case_table_names | 0 |
| max_allowed_packet | 1047552 |
| max_binlog_cache_size | 4294967295 |
| max_binlog_size | 1073741824 |
| max_connect_errors | 10 |
| max_connections | 100 |
| max_delayed_threads | 20 |
| max_error_count | 64 |
| max_heap_table_size | 16777216 |
| max_join_size | 4294967295 |
| max_relay_log_size | 0 |
| max_sort_length | 1024 |
| max_tmp_tables | 32 |
| max_user_connections | 0 |
| max_write_lock_count | 4294967295 |
| myisam_max_extra_sort_file_size | 268435456 |
| myisam_max_sort_file_size | 2147483647 |
| myisam_recover_options | force |
| myisam_repair_threads | 1 |
| myisam_sort_buffer_size | 8388608 |
| net_buffer_length | 16384 |
| net_read_timeout | 30 |
| net_retry_count | 10 |
| net_write_timeout | 60 |
| open_files_limit | 1024 |
| pid_file | /usr/local/mysql/name.pid |
| port | 3306 |
| protocol_version | 10 |
| query_cache_limit | 1048576 |
| query_cache_size | 0 |
| query_cache_type | ON |
| read_buffer_size | 131072 |
| read_rnd_buffer_size | 262144 |
| rpl_recovery_rank | 0 |
| server_id | 0 |
| skip_external_locking | ON |
| skip_networking | OFF |
| skip_show_database | OFF |
| slave_net_timeout | 3600 |
| slow_launch_time | 2 |
| socket | /tmp/mysql.sock |
| sort_buffer_size | 2097116 |
| sql_mode | |
| table_cache | 64 |
| table_type | MYISAM |
| thread_cache_size | 3 |
| thread_stack | 131072 |
| timezone | EEST |
| tmp_table_size | 33554432 |
| tmpdir | /tmp/:/mnt/hd2/tmp/ |
| tx_isolation | READ-COMMITTED |
| version | 4.0.4-beta |
| wait_timeout | 28800 |
+---------------------------------+------------------------------+
La plupart des variables système sont présentées ici. Les variables sans version sont présente depuis MySQL 3.22. Les variables système InnoDB sont listées dans Section 15.5, « Options de démarrage InnoDB ».
Les valeurs pour les tailles de buffer, longueur et taille de pile sont données en octets, à moins que cela ne soit spécifié autrement.
Les informations sur le choix des valeurs de ces paramètres est disponible dans Section 7.5.2, « Réglage des paramètres du serveur ».
-
ansi_modeVaut
ONsimysqlda été démarré en mode--ansi. See Section 1.5.3, « Exécuter MySQL en mode ANSI ». Cette variable a été ajoutée en MySQL 3.23.6 et supprimée en 3.23.41. Voyez la description desql_mode. -
back_logLe nombre de connexions sortantes que MySQL peut supporter. Cette valeur entre en jeu lorsque le thread principal MySQL re¸oit de très nombreuses requêtes de connexions en très peu de temps. MySQL prend un peu de temps (même si c'est très peu de temps), pour vérifier la connexion et démarrer un nouveau thread. La valeur de
back_logindique combien de requête seront mises en attente durant ce temps. Vous devrez augmenter ce nombre si vous voulez mettre en attente plus de requêtes durant une courte période de temps.En d'autres termes, cette valeur est la taille de la queue d'attente pour les connexions TCP/IP entrantes. Votre système d'exploitation a ses propres limites pour ce type de queue. La page du manuel Unix
listen(2)doit contenir plus de détails. Vérifiez la documentation de votre OS pour connaître la valeur maximale de votre système. Si vous donne une valeur àback_logqui est plus grande que celle que votre système supporte, cela restera sans effet. -
basedirLe dossier d'installation de MySQL. La valeur de l'option
--basedir. -
bdb_cache_sizeLe buffer qui est alloué pour mettre en cache des lignes et des index pour les tables
BDB. Si vous n'utilisez pas la tablesBDB, vous devriez démarrermysqldavec l'option--skip-bdbpour ne pas gaspiller de mémoire. Cette variable a été ajoutée en MySQL 3.23.14. -
bdb_homeLe dossier de base des tables
BDB. Cette valeur doit être la même que celle de la variabledatadir. Cette variable a été ajoutée en MySQL 3.23.14. -
bdb_log_buffer_sizeLe buffer qui est alloué pour mettre en cache des lignes et des index pour les tables
BDB. Si vous n'utilisez pas la tablesBDB, vous devriez démarrermysqldavec l'option--skip-bdbpour ne pas gaspiller de mémoire. Cette variable a été ajoutée en MySQL 3.23.31. -
bdb_logdirLe dossier où le moteur
BDBécrit les fichiers de log. C'est la valeur de l'option--bdb-logdir. Cette variable a été ajoutée en MySQL 3.23.14. -
bdb_max_lockLe nombre maximum de verrous (par défaut 10 000) que vous pouvez activer simultanément dans une table
BDB. Vous devriez augmenter cette valeur si vous obtenez des erreurs du typebdb: Lock table is out of available locksouGot error 12 from ...lorsque vous avez de longues transactions ou quemysqlddoit examiner de nombreuses lignes pour calculer la requête.bdb: Lock table is out of available locks Got error 12 from ...
Cette variable a été ajoutée en MySQL 3.23.29.
-
bdb_shared_dataVaut
ONsi vous utilisez l'option--bdb-shared-data. Cette variable a été ajoutée en MySQL 3.23.29. -
bdb_tmpdirLa valeur de l'option
--bdb-tmpdir. Cette variable a été ajoutée en MySQL 3.23.14. -
bdb_versionLa version du moteur
BDB. Cette variable a été ajoutée en MySQL 3.23.31. -
binlog_cache_sizeLa taille du cache qui contient les requêtes SQL destinées au log binaire, durant une transaction. Un cache binaire est alloué à chaque client si le serveur supporte les moteurs transactionnel, et depuis MySQL 4.1.2, si le serveur a un log binaire activé (option
--log-bin). Si vous utilisez souvent de grandes transactions multi-requêtes, vous devez augmenter cette valeur pour améliorer les performances. Les variablesBinlog_cache_useetBinlog_cache_disk_usesont aussi utiles pour optimiser la taille de cette variable. Cette variable a été ajoutée en MySQL 3.23.29. See Section 5.9.4, « Le log binaire ». -
bulk_insert_buffer_sizeMyISAMutilise une cache hiérarchisé pour les insertions de masses (c'est à direINSERT ... SELECT,INSERT ... VALUES (...), (...), ..., etLOAD DATA INFILE). Cette variable limite la taille du cache en octets, par threads. Utiliser la valeur de 0 va désactiver cette optimisation. Note : ce cache est uniquement utilisé lorsque vous ajoutez des données dans une table non-vide. Par défaut, cette option vaut 8 Mo. Cette variable a été ajoutée en MySQL 4.0.3. Cette variable s'appelaitmyisam_bulk_insert_tree_size. -
character_setLe jeu de caractères par défaut. Cette variable a été ajoutée en MySQL 3.23.3, puis retirée en MySQL 4.1.1 et remplacées par différentes variables
character_set_xxx. -
character_set_clientLe jeu de caractères pour les commandes du client. Cette variable a été ajoutée en MySQL 4.1.1.
-
character_set_connectionLe jeu de caractères utilisé pour les littéraux qui n'ont pas d'indication de jeu de caractères, pour certaines fonctions et pour les conversions de nombres vers une chaîne. Cette variable a été ajoutée en MySQL 4.1.1.
-
character_set_databaseLe jeu de caractères par défaut pour les bases de données. Le serveur modifie cette variable à chaque fois que la base de données par défaut change. S'il n'y a pas de base de données par défaut, cette variable prend la valeur de
character_set_server. Cette variable a été ajoutée en MySQL 4.1.1. -
character_set_resultsLe jeu de caractères utilisé pour retourner des résultats au client. Cette variable a été ajoutée en MySQL 4.1.1.
-
character_set_serverLe jeu de caractères par défaut pour le serveur. Cette variable a été ajoutée en MySQL 4.1.1.
-
character_set_systemLe jeu de caractères utilisé par le serveur pour stocker des identifiants. Cette valeur est toujours
utf8. Cette variable a été ajoutée en MySQL 4.1.1. -
character_setsLes jeux de caractères supportés. Cette variable a été ajoutée en MySQL 3.23.15.
-
collation_connectionCette variable a été ajoutée en MySQL 4.1.1.
-
collation_databaseLa collation utilisée par la base de données par défaut. Le serveur modifie cette variable à chaque fois que la base de données par défaut change. S'il n'y a pas de base de données par défaut, cette variable prend la valeur de
collation_server. Cette variable a été ajoutée en MySQL 4.1.1. -
collation_serverLa collation par défaut du serveur. Cette variable a été ajoutée en MySQL 4.1.1.
-
concurrent_insertSi cette option vaut
ON, MySQL va vous permettre de réaliser des commandesINSERTsur les tablesMyISAMen même temps que d'autres commandesSELECTseront exécutées. Vous pouvez désactiver cette option en démarrantmysqldavec l'option--safeor--skip-new. Cette variable a été ajoutée en MySQL 3.23.7. -
Le nombre de secondes d'attente d'un paquet de connexion avant de conclure avec une erreur
Bad handshake. -
datadirLe dossier de données de MySQL. C'est la valeur de l'option
--datadir. -
default_week_formatLe mode par défaut pour la fonction
WEEK(). Cette variable a été ajoutée en MySQL 4.0.14. -
delay_key_writeLes options pour les tables
MyISAM. Elles peuvent prendre l'une des valeurs suivantes :Option Description OFFDELAYED_KEY_WRITEest ignoré.ON(Par défaut) MySQL va honorer l'option DELAY_KEY_WRITEdeCREATE TABLE.ALLToutes les nouvelles tables ouvertes sont traitées comme si elles étaient créées avec l'option DELAY_KEY_WRITE.Si
DELAY_KEY_WRITEest activé, cela signifie que le buffer de clé des tables ayant cette option ne seront pas écrit sur le disque dès la fin de la modification de la table, mais attendrons que la table soit écrite. Cela accélère notablement les écritures des modifications, mais il faut penser à ajouter une vérification automatique des tables au démarrage avec--myisam-recover=BACKUP,FORCE. Voir aussi Section 5.2.1, « Options de ligne de commande demysqld» et Section 14.1.1, « Options de démarrageMyISAM».Notez que
--external-lockingn'offre aucune protection contre les corruptions d'index pour les tables qui utilisent les écritures retardées de clés.Cette variable a été ajoutée en MySQL 3.23.8.
-
delayed_insert_limitAprès avoir inséré
delayed_insert_limitlignes, le gestionnaire deINSERT DELAYEDva vérifiez si il n'y a pas de commandeSELECTen attente. Si c'est le cas, il va autoriser ces commandes avant de continuer. -
delayed_insert_timeoutCombien de temps le thread
INSERT DELAYEDdoit attendre les commandesINSERTavant de s'achever. -
delayed_queue_sizeQuelle taille de file (en lignes) doit être allouée pour gérer les commandes
INSERT DELAYED. Si la file se remplit, tous les clients qui émettent des commandesINSERT DELAYEDdevront attendre un peu de place avant de pouvoir continuer. -
flushCette option vaut
ONsi vous avez démarré MySQL avec l'option--flush. Cette variable a été ajoutée en MySQL 3.22.9. -
flush_timeSi cette option a une valeur non nulle, toutes les
flush_timesecondes, toutes les tables seront fermées (pour libérez des ressources et synchroniser les index sur le disque). Nous ne recommandons cette option que sur les systèmes Windows 9x/Me, ou les systèmes qui ont très peu de ressources. Cette variable a été ajoutée en MySQL 3.22.18. -
ft_boolean_syntaxListe des opérateurs supportés par
IN BOOLEAN MODE. Cette variable a été ajoutée en MySQL 4.0.1. See Section 12.6.1, « Booléens de recherches en texte intégral ».La valeur par défaut de cette variable est
'+ -><()~*:""&|'. Les règles pour modifier cette valeur sont les suivantes :-
La fonction de l'opérateur est déterminée par sa position dans la chaîne.
-
La chaîne de remplacement doit faire 14 caractères.
-
Chaque caractère doit être ASCII, non-alphanumérique.
-
Le premier ou le deuxième caractère doit être un espace.
-
Aucun doublon n'est autorisé, hormis les opérateurs guillemets aux positions 11 et 12. Ceux deux caractères ne sont pas obligatoirement les mêmes, mais ils sont les deux qui peuvent l'être.
-
Les positions 10, 13 et 14 (qui sont par défaut ‘
:’, ‘&’ et ‘|’) sont réservées pour une utilisation ultérieure.
-
-
ft_max_word_lenLa taille maximale d'un mot à inclure dans un index
FULLTEXT. Cette variable a été ajoutée en MySQL 4.0.0.Note : les index
FULLTEXTdoivent être reconstruits après chaque modification de cette variable. UtilisezREPAIR TABLE tbl_name QUICK. -
ft_min_word_lenLa taille minimale d'un mot à inclure dans un index
FULLTEXT. Cette variable a été ajoutée en MySQL 4.0.0.Note : les index
FULLTEXTdoivent être reconstruits après chaque modification de cette variable. UtilisezREPAIR TABLE tbl_name QUICK. -
ft_query_expansion_limitLe nombre de solutions générales à utiliser pour les extensions de recherche avec
WITH QUERY EXPANSION. Cette variable a été ajoutée en MySQL 4.1.1. -
ft_stopword_fileUne fichier dans lequel lire une liste de mots interdits pour les recherches en texte plein. Tous les mots du fichier seront utilisés : les commentaires ne sont pas respectés. Par défaut, des listes de mots interdits internes sont utilisés, tels que définis dans
myisam/ft_static.c). En donnant à cette option la valeur d'une chaîne vide"", vous désactivez le filtre de mots interdits.Note : les index
FULLTEXTdoivent être reconstruits après chaque modification de cette variable. Utilisez la commandeREPAIR TABLE tbl_name QUICK. Cette variable a été ajoutée en MySQL 4.1.0. -
group_concat_max_lenLa taille maximale de la chaîne résultat de
GROUP_CONCAT(). Cette variable a été ajoutée en MySQL 4.1.0. -
have_bdbYESsimysqldsupporte les tablesBDB.DISABLEDsi--skip-bdba été utilisé. Cette variable a été ajoutée en MySQL 3.23.30. -
have_innodbYESsimysqldsupporte les tablesInnoDB.DISABLEDsi--skip-innodba été utilisé. Cette variable a été ajoutée en MySQL 3.23.37. -
have_isamYESsimysqldsupporte les tablesISAM.DISABLEDsi--skip-isama été utilisé. Cette variable a été ajoutée en MySQL 3.23.30. -
have_raidYESsimysqldsupporte les tablesRAID. Cette variable a été ajoutée en MySQL 3.23.30. -
have_opensslYESsimysqldsupporte le chiffrement SSL avec le protocole de communication client / serveur. Cette variable a été ajoutée en MySQL 3.23.43. -
init_connectUne chaîne a exécuter sur le serveur lors de chaque connexion. La chaîne est constituée d'une ou plusieurs commandes SQL. Pour spécifier une commande multiple, séparez les requêtes individuelles par des points-virgules. Cette variable a été ajoutée en MySQL version 4.1.2.
Par exemple, chaque client commence par défaut avec le mode d'auto-validation activé. Il n'y a pas de variable globale à spécifier pour désactiver l'auto-validation, et
init_connectpeut servir à ¸a :SET GLOBAL init_connect='SET AUTOCOMMIT=0';
Cette variable peut aussi être configurée en ligne de commande ou dans un fichier d'options. Pour assigner la variable comme montré dans le fichier d'options, ajoutez ces lignes là :
[mysqld] init_connect='SET AUTOCOMMIT=0'
Cette variable a été ajoutée en MySQL 4.1.2.
-
init_fileLe nom du fichier spécifié avec l'option
--init-filelorsque vous démarrez le serveur. C'est un fichier qui contient les requêtes SQL que vous voulez voir exécutées dès le démarrage. Chaque commande doit être sur une seule ligne, et ne doit pas inclure de commentaires. Cette variable a été ajoutée en MySQL 3.23.2. -
init_slaveCette variable est similaire à
init_connect, mais la chaîne doit être exécutée par l'esclave, à chaque démarrage du thread SQL. Le format de la chaîne est le même que pour la variableinit_connect. Cette variable a été ajoutée en MySQL 4.1.2. -
innodb_xxxLes variables système de
InnoDBsont listées dans Section 15.5, « Options de démarrageInnoDB». -
interactive_timeoutLe nombre de secondes durant lequel le serveur attend une activité de la part de la connexion avant de la fermée. Un client interactif est un client qui utilise l'option
CLIENT_INTERACTIVEavecmysql_real_connect(). Voir aussiwait_timeout. -
join_buffer_sizeLa taille du buffer qui est utilisée pour les jointures complètes (les jointures qui n'utilisent pas d'index). Ce buffer est alloué une fois pour chaque jointure entre deux tables. Augmentez cette valeur si vous voulez obtenir des jointures plus rapides, lorsque l'ajout d'index n'est pas possible. Normalement, le mieux est d'ajouter de bons index.
-
Les blocs d'index des tables
MyISAMetISAMsont mis en buffer et partagés par tous les threads.key_buffer_sizeest la taille du buffer utilisé. Le buffer de clé est aussi appelé le cache de clé.Augmentez cette valeur pour obtenir une meilleure gestion des index (pour les lectures et écritures multiples), autant que vous le pouvez : 64 Mo sur une machine de 256 Mo est une valeur répandue. Toutefois, si vous utilisez une valeur trop grande (par exemple, plus de 50% de votre mémoire totale), votre système risque de commencer à utiliser sa mémoire swap, et devenir très lent. N'oubliez pas que MySQL ne met pas en cache les données lues, et il faut laisser le système d'exploitation respirer.
Pour obtenir encore plus de vitesse lors de l'écriture de plusieurs lignes en même temps, utilisez
LOCK TABLES. See Section 13.4.5, « Syntaxe deLOCK TABLES/UNLOCK TABLES».Vous pouvez vérifier les performances du buffer de clés avec la commande
SHOW STATUSet en examinant les variablesKey_read_requests,Key_reads,Key_write_requestsetKey_writes. See Section 13.5.3, « Syntaxe deSHOW».Le ratio
Key_reads/Key_read_requestsdoit normalement être inférieur à 0.01. Le ratioKey_writes/Key_write_requestsest généralement près de 1 si vous utilisez essentiellement des modifications et des effacements mais il peut être plus petit si vous avez des modifications qui changent plusieurs lignes en même temps, ou si vous utilisez l'optionDELAY_KEY_WRITE.La fraction du buffer de clé utilisée est déterminée avec la variable
key_buffer_sizeen conjonction avec la variableKey_blocks_usedet la taille de bloc de buffer. Depuis MySQL 4.1.1, la taille de bloc de buffer est disponible dans la variable serveurkey_cache_block_size. La fraction utilisée du buffer est :(Key_blocks_used * key_cache_block_size) / key_buffer_size
Avant MySQL 4.1.1, les blocs du cache de clé étaient de 1024 octets, ce qui fait que la fraction utilisée était :
(Key_blocks_used * 1024) / key_buffer_size
-
key_cache_age_thresholdCette valeur contrôle le transit des buffers d'une sous-chaîne de cache de clé vers une autre, moins prioritaire. Les valeurs les plus basses accroissent la vitesse de transit. La valeur minimale est de 100. La valeur par défaut est 300. Cette variable a été ajoutée en MySQL 4.1.1. See Section 7.4.6, « Le cache de clé des tables
MyISAM». -
key_cache_block_sizeLa taille du bloc de cache de clé, en octets. La valeur par défaut est 1024. Cette variable a été ajoutée en MySQL 4.1.1. See Section 7.4.6, « Le cache de clé des tables
MyISAM». -
key_cache_division_limitLe point de division entre la sous-chaîne prioritaire et la seconde sous-chaîne. Cette valeur est le pourcentage du buffer à utiliser pour la sous-chaîne secondaire. Les valeurs possibles vont de 1 à 100. La valeur par défaut est 100. Cette variable a été ajoutée en MySQL 4.1.1. See Section 7.4.6, « Le cache de clé des tables
MyISAM». -
languageLa langue utilisée pour les message d'erreurs.
-
large_file_supportSi
mysqlda été compilé avec le support des grands fichiers. Cette variable a été ajoutée en MySQL 3.23.28. -
local_infileSi
mysqlda été configuré avec le support deLOCALpour les commandesLOAD DATA INFILE. Cette variable a été ajoutée en MySQL 4.0.3. -
locked_in_memorySi
mysqlda été verrouillé en mémoire avec--memlockCette variable a été ajoutée en MySQL 3.23.25. -
logSi le log de toutes les requêtes est activé. See Section 5.9.2, « Le log général de requêtes ».
-
log_binSi le log binaire est activé. Cette variable a été ajoutée en MySQL 3.23.14. See Section 5.9.4, « Le log binaire ».
-
log_slave_updatesSi les modifications des esclaves doivent être enregistrées. Le log binaire doit être activé pour que cette option fonctionne. Cette variable a été ajoutée en MySQL 3.23.17. See Section 6.8, « Options de démarrage de la réplication ».
-
log_slow_queriesIndique si les requêtes lentes doivent être enregistrées. ``Lente'' est déterminé par la valeur de
long_query_time. Cette variable a été ajoutée en MySQL 4.0.2. See Section 5.9.5, « Le log des requêtes lentes ». -
log_updateSi le log de modification est activé. Cette variable a été ajoutée en MySQL 3.22.18. Notez que le log binaire est préférable au log de modifications, qui n'est plus disponible en MySQL 5.0. See Section 5.9.3, « Le log de modification ».
-
long_query_timeSi une requête prend plus de
long_query_timesecondes, le compteur de requêtes lentesSlow_queriessera incrémenté. Si vous utilisez l'option--log-slow-queries, ces requêtes seront enregistrées dans un historique de requêtes lentes. Cette durée est mesurée en temps réel, et non pas en temps processus, ce qui fait que les requêtes qui seraient juste sous la limite avec un système légèrement chargé, pourrait être au dessus avec le même système, mais chargé. See Section 5.9.5, « Le log des requêtes lentes ». -
low_priority_updatesSi cette option vaut
1, toutes les requêtesINSERT,UPDATE,DELETEetLOCK TABLE WRITEattendent qu'il n'y ait plus deSELECTou deLOCK TABLE READen attente pour cette table. Cette variable s'appelait avantsql_low_priority_updates. Cette variable a été ajoutée en MySQL 3.22.5. -
lower_case_table_namesSi cette option vaut 1, les noms de tables sont stockées en minuscules sur le disque, et les comparaisons de nom de tables seront insensibles à la casse. Depuis la version 4.0.2, cette option s'applique aussi aux noms de bases. Depuis la version 4.1.1 cette option s'applique aussi aux alias de table. See Section 9.2.2, « Sensibilité à la casse pour les noms ».
Vous ne devez pas mettre cette variable à 0 si vous utilisez MySQL sur un serveur qui n'a pas de sensibilité à la casse au niveau du système de fichiers (comme Windows ou Mac OS X). Nouveau en 4.0.18 : si cette variable vaut 0 est que le système de fichier n'est pas sensible à la casse, MySQL va automatiquement donner la valeur de 2 à
lower_case_table_names. -
max_allowed_packetLa taille maximale d'un paquet.
Le buffer de message est initialisé avec
net_buffer_lengthoctets, mais peut grandir jusqu'àmax_allowed_packetoctets lorsque nécessaire. Cette valeur est par défaut petit, pour intercepter les gros paquets, probablement erronés.Vous devez augmenter cette valeur si vous utilisez de grandes colonnes
BLOB. Cette valeur doit être aussi grande que le plus grandBLOBque vous utiliserez. Le protocole limite actuellementmax_allowed_packetà 16 Mo en MySQL 3.23 et 1 Go en MySQL 4.0. -
max_binlog_cache_sizeSi une transaction multi-requête requiert plus que cette quantité de mémoire, vous obtiendrez une erreur
"Multi-statement transaction required more than 'max_binlog_cache_size' bytes of storage". Cette variable a été ajoutée en MySQL 3.23.29. -
max_binlog_sizeDisponible depuis la version 3.23.33. Si vous écrivez dans le log binaire (de réplication) et que cela dépasse la taille de
max_binlog_size, une erreur sera indiquée. Vous ne pouvez pas donner àmax_binlog_sizeune valeur inférieure à 1024 octets, ou plus grande que 1 Go. Cette variable a été ajoutée en MySQL 3.23.33.Notez bien si vous utilisez les transactions : une transaction est écrite en une seule fois dans le log binaire, et elle ne peut pas être répartie en plusieurs fichiers. Par conséquent, si vous avez de grandes transactions, vous verrez peut être des fichiers de log plus grand que
max_binlog_size.Si
max_relay_log_sizevaut 0, la valeur demax_binlog_sizes'applique aussi aux logs de relais.max_relay_log_sizea été ajoutée en MySQL 4.0.14. -
max_connect_errorsS'il y a plus que
max_connect_errorsconnexion interrompues depuis un même hôte, cet hôte sera bloqué dans ses prochaines tentatives de connexions. Vous pouvez débloquer un hôte avec la commandeFLUSH HOSTS. -
max_connectionsLe nombre maximal de clients simultanés accepté. En augmentant cette valeur, vous augmentez le nombre de pointeur de fichier que requiert
mysqld. Voyez la section Section 7.4.8, « Quand MySQL ouvre et ferme les tables » pour des commentaires sur les pointeurs de fichiers. Voyez aussi la section Section A.2.6, « ErreurToo many connections». -
max_delayed_threadsNe pas lancer plus que
max_delayed_threadsthreads pour gérer les insertionsINSERT DELAYED. Si vous essayez d'insérer des données dans une nouvelle table alors que tous les gestionnairesINSERT DELAYEDsont utilisés, la ligne sera insérée comme si l'optionDELAYEDn'avait pas été spécifiée. Cette variable a été ajoutée en MySQL 3.23.0. -
max_error_countLe nombre maximum d'erreur, alertes et messages de note à stocker pour afficher avec
SHOW ERRORSouSHOW WARNINGS. Cette variable a été ajoutée en MySQL 4.1.0. -
max_heap_table_sizeNe pas autoriser la création de tables de type
MEMORY(HEAP) plus grande quemax_heap_table_size. La valeur de la variable est utilisée pour calculer la valeur maximale deMAX_ROWSpour la tableMEMORY. Modifier cette variable n'a pas d'effet sur les tables existantes, à moins que la table ne soit recrée, avec une commande commeCREATE TABLEouTRUNCATE TABLE, ou encore modifiée avecALTER TABLE. Cette variable a été ajoutée en MySQL 3.23.0. -
max_insert_delayed_threadsCette variable est un synonyme de
max_delayed_threads. Cette variable a été ajoutée en MySQL 4.0.19. -
max_join_sizeLes jointures qui liront probablement plus de
max_join_sizelignes, retourneront une erreur. Utilisez cette valeur si vos utilisateurs font des jointures avec de mauvaises clausesWHERE, qui prennent trop de temps, et retournent des millions de lignes.En donnant une valeur à cette variable qui est autre que
DEFAULTremet la valeur deSQL_BIG_SELECTSà0. Si vous modifiez à nouveau la valeur deSQL_BIG_SELECTS, la variablemax_join_sizesera ignorée.Si un résultat de requête est déjà dans le cache de requête, aucune limite de taille n'est vérifiée, car le résultat a déjà été compilé, et cela ne posera aucun problème au serveur pour l'envoyer à nouveau.
Cette variable s'appelait précédemment
sql_max_join_size. -
max_relay_log_sizeDisponible depuis la version 4.0.14. Si vous écrivez des données dans un log de relais et que leur taille dépasse la valeur donnée, le log de relais passe au fichier suivant. Cette variable vous permet de placer différentes contraintes de taille sur les logs binaire et de relais. Cependant, en donnant la valeur de 0 à cette valeur, MySQL utilisera
max_binlog_sizepour les deux logs, binaire et de relais. Vous devez donner àmax_relay_log_sizela valeur de 0 ou plus de 4096, et moins que 1 Go. Par défaut, c'est 0. Cette variable a été ajoutée en MySQL 4.0.14. See Section 6.3, « Détails d'implémentation de la réplication ». -
max_seeks_for_keyLa limite de recherche lors de recherche de lignes basées sur un index. L'optimiseur MySQL va supposer que lorsque vous recherchez des lignes dans une table en analysant les index, vous n'aller pas générer plus de ce nombre de recherches, indépendamment de la cardinalité de la clé. En donnant une valeur faible à cette variable (100 ?) vous pouvez forcer MySQL a préférer les scans d'index plutôt que les scans de tables. Cette variable a été ajoutée en MySQL 4.0.14.
-
max_sort_lengthLe nombre d'octets à utiliser lors du tri des colonnes de type
BLOBetTEXT. Seuls lesmax_sort_lengthoctets de chaque valeur seront utilisés pour le tri. Le reste est ignoré. -
max_tmp_tablesCette option ne fait encore rien. Le nombre maximal de tables temporaires qu'un client peut garder ouverte en même temps.
-
max_user_connectionsLe nombre maximum de connexions actives pour un utilisateur particulier (0 = pas de limite). Cette variable a été ajoutée en MySQL 3.23.34.
-
max_write_lock_countAprès
max_write_lock_countpose de verrou en écriture, autorise quelques verrous en lecture. Cette variable a été ajoutée en MySQL 3.23.7. -
myisam_data_pointer_sizeLa taille par défaut du pointeur à utiliser avec
CREATE TABLEpour les tablesMyISAMlorsque qu'aucune optionMAX_ROWSn'est spécifiée. Cette variable ne peut pas être inférieure à 2 ni supérieure à 8. La valeur par défaut est de 4. Cette variable a été ajoutée en MySQL 4.1.2. See Section A.2.11, « ErreurThe table is full». -
myisam_max_extra_sort_file_sizeSi un fichier temporaire est utilisé pour créer rapidement un fichier d'index pour une table
MyISAMest plus grand que la valeur de cette variable, alors préfère la méthode du cache de clé. C'est surtout utilisé pour forcer les grands index à utiliser la méthode plus lente du cache de clé pour créer l'index. Cette variable a été ajoutée en MySQL 3.23.37. Note : la valeur donnée est en megaoctets avant 4.0.3 et en octets après. -
myisam_max_sort_file_sizeLa taille maximale du fichier temporaire que MySQL est autorisé à utiliser durant la recréation des fichiers d'index (avec
REPAIR,ALTER TABLEouLOAD DATA INFILE). Si la taille du fichier dépassemyisam_max_sort_file_size, l'index sera créé avec un cache de clé (plus lent). Cette variable a été ajoutée en MySQL 3.23.37. Note : ce paramètre est spécifié en megaoctets avant la version 4.0.3 et en octets depuis. -
myisam_recover_optionsLa valeur de l'option
--myisam-recover. Cette variable a été ajoutée en MySQL 3.23.36. -
myisam_repair_threadsSi cette valeur est plus grande que 1, les index des tables
MyISAMdurant un processus deRepair by sortingseront créés en parallèle : chaque index avec son propre thread. Note : les réparations multi-threadées sont encore en développement, et en qualité alpha. Cette variable a été ajoutée en MySQL 4.0.13. -
myisam_sort_buffer_sizeLe buffer qui est alloués lors du tri d'index avec la commande
REPAIRou lors de la création d'index avecCREATE INDEXouALTER TABLE. Cette variable a été ajoutée en MySQL 3.23.16. -
named_pipeSous Windows, indique si le serveur supporte les connexions via les pipes nommés. Cette variable a été ajoutée en MySQL 3.23.50.
-
net_buffer_lengthLe buffer de communication est remis à zéro entre deux requêtes. Cela ne devrait pas être modifié, mais si vous avez très peu de mémoire, vous pouvez le remettre à la taille présumée de la requête (c'est à dire, la taille de requête envoyé par le client. Si la requête dépasse cette taille, le buffer est automatiquement agrandi jusqu'à
max_allowed_packetoctets). -
net_read_timeoutNombre de secondes d'attente des dernières données, avant d'annuler la lecture. Notez que lorsque nous n'attendons pas de données d'une connexion, le délai d'expiration est donné par
write_timeout. Voir aussislave_net_timeout. Cette variable a été ajoutée en MySQL 3.23.20. -
net_retry_countSi une lecture sur une port de communication est interrompu,
net_retry_counttentatives sont faites avant d'abandonner. Cette valeur doit être particulièrement grande pourFreeBSDcar les interruptions internes sont envoyés à tous les threads. Cette variable a été ajoutée en MySQL 3.23.7. -
net_write_timeoutNombre de secondes d'attente pour qu'un bloc soit envoyé à une connexion, avant d'annuler l'écriture. Voir aussi
net_read_timeout. Cette variable a été ajoutée en MySQL 3.23.20. -
open_files_limitSi
open_files_limitne vaut pas 0, alorsmysqldva utiliser cette valeur pour réserver des pointeurs de fichiers à utiliser avecsetrlimit(). Si cette valeur est 0, alorsmysqldva réservermax_connections*5oumax_connections + table_cache*2(le plus grand des deux) pointeurs de fichiers. Vous devriez augmenter cette valeur simysqldvous donne des erreurs du type'Too many open files'. -
pid_fileLe chemin vers le fichier de processus (
PID). La valeur de l'option--pid-file. Cette variable a été ajoutée en MySQL 3.23.23. -
portLe port de connexion sur lequel le serveur attend les connexions TCP/IP. Cette variable peut être spécifiée avec
--port. -
protocol_versionLa version du protocole utilisé par le serveur MySQL. Cette variable a été ajoutée en MySQL 3.23.18.
-
query_alloc_block_sizeTaille des blocs de mémoire alloués pour les objets durant l'analyse et la préparation des requêtes. Si vous avez un problème avec la fragmentation de la mémoire, cela peut être utile d'augmenter cette valeur. Cette variable a été ajoutée en MySQL 4.0.16.
-
query_cache_limitNe met pas en cache les résultats qui sont plus grands que
query_cache_limit. Par défaut, 1 Mo. Cette variable a été ajoutée en MySQL 4.0.1. -
query_cache_min_res_unitLa taille minimale pour les blocs alloués par le cache de requête. La valeur par défaut est de 4 ko. Des informations sur l'optimisation de cette variable sont données dans la section Section 5.11.3, « Configuration du cache de requêtes ». Cette variable a été ajoutée en MySQL 4.1.
-
query_cache_sizeLa mémoire allouée pour stocker les résultats des vieilles requêtes. Si
query_cache_sizevaut 0, le cache de requête est désactivé (par défaut). Cette variable a été ajoutée en MySQL 4.0.1. -
query_cache_typeChoisit le type de cache de requête. Modifier la variable
GLOBALmodifie le cache pour tous les clients. Les clients peuvent modifier la variable deSESSIONpour l'adapter à leur utilisation.query_cache_typepeut prendre les valeurs numériques suivantes :Option Description 0orOFFNe met pas en cache les résultats. Notez que cela ne va pas libérer le buffer de requête. Pour cela, il faut donner à query_cache_sizela valeur de 0.1orONMet en cache tous les résultats exceptés les requêtes SELECT SQL_NO_CACHE ....2orDEMANDMet en cache uniquement les requêtes SELECT SQL_CACHE ....Cette variable a été ajoutée en MySQL 4.0.3.
-
query_cache_wlock_invalidateNormalement, lorsqu'un client pose un verrou
WRITEsur une tableMyISAM, les autres clients ne sont pas empêchés d'émettre des requêtes sur la table, si le résultat est déjà en cache. En donnant la valeur de 1 à cette variable, le verrouWRITEempêchera toutes les requêtes qui feront référence à cette table. Cela force les autres clients à attendre que le verrou se libère. Cette variable a été ajoutée en MySQL 4.0.19. -
query_prealloc_sizeLa taille du buffer persistant utilisé pour l'analyse des requêtes et leur exécution. Ce buffer n'est pas libéré entre deux requêtes. Si vous manipulez des requêtes complexes, une valeur plus grande pour
query_prealloc_sizesera plus utile pour améliorer les performances, car elle peut réduire les allocations complémentaires de mémoire durant l'exécution des requêtes.Cette variable a été ajoutée en MySQL 4.0.16.
-
range_alloc_block_sizeLa taille de bloc qui est alloué lors de l'optimisation d'intervalle. Cette variable a été ajoutée en MySQL 4.0.16.
-
read_buffer_sizeChaque thread qui fait une recherche séquentielle alloue un buffer de cette taille pour son scan. Si vous faites de nombreux scan séquentiels, vous pourriez avoir besoin d'augmenter cette valeur. Cette variable a été ajoutée en MySQL 4.0.3. Auparavant, cette variable s'appelait
record_buffer. -
read_onlyLorsque cette variable vaut
ONpour un serveur de réplication esclave, cela fait que le serveur ne permet aucune modification, hormis celles de la réplication, ou des utilisateurs ayant le droit deSUPER. Cela peut être pratique pour s'assurer qu'un esclave n'accepte aucune modification des clients. Cette variable a été ajoutée en MySQL 4.0.14. -
read_rnd_buffer_sizeLors de la lecture des lignes triées, les lignes sont lues dans un buffer, pour éviter les accès disques. En donnant à cette variable une grande valeur, vous améliorerez les performances des clauses
ORDER BY. Cependant, ce buffer est alloué pour chaque client : il est recommandé de ne pas donner une valeur globale trop importante. Au lieu de cela, modifiez cette valeur si votre client a besoin de faire de gros tris. Cette variable a été ajoutée en MySQL 4.0.3. Auparavant, cette variable s'appelaitrecord_rnd_buffer. -
safe_show_databaseNe montre pas les bases pour lesquelles un utilisateur n'a pas des droits de bases ou de tables. Cela peut améliorer considérablement la sécurité si vous craignez de voir les utilisateurs découvrir ce que les autres ont mis en place. Voir aussi
skip_show_database.Cette variable a été supprimée en MySQL 4.0.5. A la place, utilisez le droit
SHOW DATABASESpour contrôler les accès aux noms des bases de données. -
secure_authSi le serveur MySQL a été lancé avec l'option
--secure-auth, il va empêcher les connexions des comptes qui ont un compte au format pre-version 4.1. Dans ce cas, la valeur de cette variable vautON, sinon, c'estOFF.Vous devriez activer cette option si vous voulez empêcher l'utilisation des mots de passe à l'ancien format (et donc, améliorer la sécurité de votre serveur). Cette variable a été ajoutée en MySQL 4.1.1.
Le démarrage du serveur échouera avec une erreur si cette option est activée, mais que la table de droits est toujours au format pre-version 4.1.
Lorsqu'elle est utilisée comme une option du client, le client va refuser de se connecter au serveur si le serveur requiert un mot de passe à l'ancien format.
-
server_idLa valeur de l'option
--server-id. Elle sert à la réplication. Cette variable a été ajoutée en MySQL 3.23.26. -
skip_external_lockingskip_lockingvautOFFsimysqldutilise le verrouillage externe. Cette variable a été ajoutée en MySQL 4.0.3. Auparavant, cette variable s'appelaitskip_locking. -
skip_networkingskip_networkingvaut ON si seules les connexions locales (via socket) sont autorisées. Sous Unix, les connexions locales utilisent un fichier de socket Unix. Sous Windows, les connexions locales utilisent les pipes nommés. Sous NetWare, seules les connexions TCP/IP sont supportées, alors ne donnez pas la valeur deONà cette variable. Cette variable a été ajoutée en MySQL 3.22.23. -
skip_show_databaseskip_show_databaseempêche les utilisateurs d'exécuter des commandesSHOW DATABASESsi ils n'ont pas les droits dePROCESS. Cela peut améliorer la sécurité si vous craignez de voir les utilisateurs découvrir ce que les autres ont mis en place. Voir aussisafe_show_database. Cette variable a été ajoutée en MySQL 3.23.4. Depuis MySQL 4.0.2, son effet dépend aussi du droitSHOW DATABASES: si la variable vautON, la commandeSHOW DATABASESn'est autorisée qu'aux comptes ayant le droit deSHOW DATABASES, et la commande affiche tous les noms de bases. Si la valeur estOFF,SHOW DATABASESest autorisé à tous les utilisateurs, mais il n'affichera que les noms de bases de données pour lesquelles l'utilisateur a le droit deSHOW DATABASESou un droit quelconque dans la base. -
slave_net_timeoutNombre de secondes d'attente de données en lecture ou écriture sur une connexion maître / esclave avant d'annuler. Cette variable a été ajoutée en MySQL 3.23.40.
-
slow_launch_timeSi la création du thread prend plus de
slow_launch_timesecondes, le compteur de threads lentsSlow_launch_threadssera incrémenté. Cette variable a été ajoutée en MySQL 3.23.15. -
socketLa socket Unix utilisé par le serveur. Sous Unix, c'est le fichier de socket Unix, pour les connexions locales. Sous Windows, c'est le nom du pipe nommé, pour les connexions locales.
-
sort_buffer_sizeChaque thread qui doit faire un tri alloue un buffer de cette taille. Augmentez cette taille pour accélérer les clauses
ORDER BYouGROUP BY. See Section A.4.4, « Où MySQL stocke les fichiers temporaires ? ». -
sql_modeLe mode SQL courant. Cette variable a été ajoutée en MySQL 3.23.41. See Section 5.2.2, « Le mode SQL du serveur ».
-
storage_engineCette variable est un synonyme de
table_type. Cette variable a été ajoutée en MySQL 4.1.2. -
table_cacheLe nombre de tables ouvertes pour tous les threads réunis. En augmentant cette valeur, vous augmentez le nombre de pointeurs de fichiers que
mysqldutilise. Vous pouvez vérifier si vous avez besoin de plus de cache de tables en étudiant la valeur de la variableOpened_tables. See Section 5.2.4, « Variables de statut du serveur ». Si cette variable est grande, c'est que vous ne faites pas souvent de commandesFLUSH TABLES(qui force les tables à se recharger), vous devrez alors augmenter cette valeur.Pour plus d'informations sur le cache de table, voyez Section 7.4.8, « Quand MySQL ouvre et ferme les tables ».
-
table_typeLe type de table par défaut. Pour configurer le type de table par défaut au démarrage, utilisez
--default-table-type. Cette variable a été ajoutée en MySQL 3.23.0. See Section 5.2.1, « Options de ligne de commande demysqld». -
thread_cache_sizeCombien de threads nous allons conserver en cache pour réutilisation. Lorsqu'un client se déconnecte, les threads du client sont mis en cache s'il n'y en a pas déjà
thread_cache_sizede conservé. Tous les nouveaux threads sont d'abord prélevé dans le cache, et uniquement lorsque le cache est vide, un nouveau thread est créé. Cette variable peut vous permettre d'améliorer les performances si vous avez de nombreuses connexions. Normalement,thread_cache_sizene donne pas d'amélioration notable si vous avez une bonne implémentation des threads. En examinant la différence entre les variables de statutConnectionsetThreads_createdvous pouvez voir comment votre système de cache de threads est efficace. (see Section 5.2.4, « Variables de statut du serveur » pour plus de détails) Cette variable a été ajoutée en MySQL 3.23.16. -
thread_concurrencySous Solaris,
mysqldva appelerthr_setconcurrency()avec cette valeur.thr_setconcurrency()permet à l'application de donner au système de threads une indication sur le nombre de threads qui seront exécutés en même temps. Cette variable a été ajoutée en MySQL 3.23.7. -
thread_stackLa taille de la pile pour chaque thread. De nombreuses limites détectées par
crash-mesont dépendantes de cette valeur. La valeur par défaut est suffisamment grande pour des opérations normales. See Section 7.1.4, « La suite de tests MySQL ». -
timezoneLe fuseau horaire du serveur. Cette option prend la valeur de la variable d'environnement
TZlorsquemysqldest démarré. Elle peut aussi être modifiée avec l'argument--timezonedemysqld_safe. Cette variable a été ajoutée en MySQL 3.23.15. See Section A.4.6, « Problèmes de fuseaux horaires ». -
tmp_table_sizeSi une table temporaire en mémoire excède cette taille, MySQL va automatiquement la convertir en une table
MyISAMsur le disque. Augmentez la valeur detmp_table_sizesi vous faites un usage intensif de la clauseGROUP BYet que vous avez beaucoup de mémoire. -
tmpdirLe dossier utilisé pour les fichiers temporaires et les tables temporaires. Depuis MySQL 4.1, cette variable peut prendre une liste de différents chemins, qui sont utilisés circulairement. Les chemins doivent être séparés par des deux points (‘
:’) sous Unix et des points-virgules (‘;’) sous Windows, NetWare et OS/2.Cette fonctionnalité permet de répartir la charge en plusieurs disques. Si le serveur MySQL sert d'esclave de réplication, vous ne devez pas faire pointer
tmpdirsur un dossier en mémoire, car il sera vidé si le serveur redémarre. Un esclave de réplication doit pouvoir reprendre ses fichiers temporaires pour que la réplication puisse redémarrer, en incluant les tables temporaires et les opérations deLOAD DATA INFILE. Si les fichiers du dossier temporaire sont perdus au redémarrage, la réplication s'arrêtera.Cette variable a été ajoutée en MySQL 3.22.4.
-
transaction_alloc_block_sizeLa taille de bloc d'allocation de mémoire pour le stockage des requêtes qui font partie d'une transaction, qui sera stockée dans le log binaire durant une validation. Cette variable a été ajoutée en MySQL 4.0.16.
-
transaction_prealloc_sizeLe buffer persistant pour
transaction_alloc_blocks, qui n'est pas libéré entre deux requêtes. En rendant cet buffer ``assez grand'' pour accommoder toutes les requêtes dans une transaction classique, vous pouvez éviter de nombreux appelsmalloc(). Cette variable a été ajoutée en MySQL 4.0.16. -
tx_isolationLe niveau par défaut d'isolation de transactions. Cette variable a été ajoutée en MySQL 4.0.3.
-
versionLe numéro de version du serveur.
-
wait_timeoutLe nombre de secondes d'attente du serveur sur une connexion non interactive avant de la refermer.
Lors du démarrage du thread,
SESSION.WAIT_TIMEOUTest initialisé avecGLOBAL.WAIT_TIMEOUTouGLOBAL.INTERACTIVE_TIMEOUT, suivant le type de client (tel que défini par l'option de connexionCLIENT_INTERACTIVE). Voir aussiinteractive_timeout.
Depuis MySQL version 4.0.3, de nombreuses variables système sont dynamiques, et peuvent être modifiées durant l'exécution avec les commandes SET GLOBAL ou SET SESSION. Vous pouvez aussi sélectionner leur valeurs avec SELECT. See Section 9.4, « Variables système ».
La table suivante montre la liste complète de toutes les variables dynamiques. La dernière colonne indique si les options GLOBAL ou SESSION, ou les deux, s'appliquent.
| Nom de la variable | Type de valeur | Application |
autocommit |
boolean | SESSION |
big_tables |
boolean | SESSION |
binlog_cache_size |
numeric | GLOBAL |
bulk_insert_buffer_size |
numeric | GLOBAL | SESSION |
character_set_client |
string | GLOBAL | SESSION |
character_set_connection |
string | GLOBAL | SESSION |
character_set_results |
string | GLOBAL | SESSION |
character_set_server |
string | GLOBAL | SESSION |
collation_connection |
string | GLOBAL | SESSION |
collation_server |
string | GLOBAL | SESSION |
concurrent_insert |
boolean | GLOBAL |
connect_timeout |
numeric | GLOBAL |
convert_character_set |
string | GLOBAL | SESSION |
default_week_format |
numeric | GLOBAL | SESSION |
delay_key_write |
OFF | ON | ALL |
GLOBAL |
delayed_insert_limit |
numeric | GLOBAL |
delayed_insert_timeout |
numeric | GLOBAL |
delayed_queue_size |
numeric | GLOBAL |
error_count |
numeric | SESSION |
flush |
boolean | GLOBAL |
flush_time |
numeric | GLOBAL |
foreign_key_checks |
boolean | SESSION |
ft_boolean_syntax |
numeric | GLOBAL |
group_concat_max_len |
numeric | GLOBAL | SESSION |
identity |
numeric | SESSION |
insert_id |
boolean | SESSION |
interactive_timeout |
numeric | GLOBAL | SESSION |
join_buffer_size |
numeric | GLOBAL | SESSION |
key_buffer_size |
numeric | GLOBAL |
last_insert_id |
numeric | SESSION |
local_infile |
boolean | GLOBAL |
log_warnings |
boolean | GLOBAL |
long_query_time |
numeric | GLOBAL | SESSION |
low_priority_updates |
boolean | GLOBAL | SESSION |
max_allowed_packet |
numeric | GLOBAL | SESSION |
max_binlog_cache_size |
numeric | GLOBAL |
max_binlog_size |
numeric | GLOBAL |
max_connect_errors |
numeric | GLOBAL |
max_connections |
numeric | GLOBAL |
max_delayed_threads |
numeric | GLOBAL |
max_error_count |
numeric | GLOBAL | SESSION |
max_heap_table_size |
numeric | GLOBAL | SESSION |
max_insert_delayed_threads |
numeric | GLOBAL |
max_join_size |
numeric | GLOBAL | SESSION |
max_relay_log_size |
numeric | GLOBAL |
max_seeks_for_key |
numeric | GLOBAL | SESSION |
max_sort_length |
numeric | GLOBAL | SESSION |
max_tmp_tables |
numeric | GLOBAL |
max_user_connections |
numeric | GLOBAL |
max_write_lock_count |
numeric | GLOBAL |
myisam_max_extra_sort_file_size |
numeric | GLOBAL | SESSION |
myisam_max_sort_file_size |
numeric | GLOBAL | SESSION |
myisam_repair_threads |
numeric | GLOBAL | SESSION |
myisam_sort_buffer_size |
numeric | GLOBAL | SESSION |
net_buffer_length |
numeric | GLOBAL | SESSION |
net_read_timeout |
numeric | GLOBAL | SESSION |
net_retry_count |
numeric | GLOBAL | SESSION |
net_write_timeout |
numeric | GLOBAL | SESSION |
query_alloc_block_size |
numeric | GLOBAL | SESSION |
query_cache_limit |
numeric | GLOBAL |
query_cache_size |
numeric | GLOBAL |
query_cache_type |
enumeration | GLOBAL | SESSION |
query_cache_wlock_invalidate |
boolean | GLOBAL | SESSION |
query_prealloc_size |
numeric | GLOBAL | SESSION |
range_alloc_block_size |
numeric | GLOBAL | SESSION |
read_buffer_size |
numeric | GLOBAL | SESSION |
read_only |
numeric | GLOBAL |
read_rnd_buffer_size |
numeric | GLOBAL | SESSION |
rpl_recovery_rank |
numeric | GLOBAL |
safe_show_database |
boolean | GLOBAL |
server_id |
numeric | GLOBAL |
slave_compressed_protocol |
boolean | GLOBAL |
slave_net_timeout |
numeric | GLOBAL |
slow_launch_time |
numeric | GLOBAL |
sort_buffer_size |
numeric | GLOBAL | SESSION |
sql_auto_is_null |
boolean | SESSION |
sql_big_selects |
boolean | SESSION |
sql_big_tables |
boolean | SESSION |
sql_buffer_result |
boolean | SESSION |
sql_log_bin |
boolean | SESSION |
sql_log_off |
boolean | SESSION |
sql_log_update |
boolean | SESSION |
sql_low_priority_updates |
boolean | GLOBAL | SESSION |
sql_max_join_size |
numeric | GLOBAL | SESSION |
sql_quote_show_create |
boolean | SESSION |
sql_safe_updates |
boolean | SESSION |
sql_select_limit |
numeric | SESSION |
sql_slave_skip_counter |
numeric | GLOBAL |
sql_warnings |
boolean | SESSION |
storage_engine |
enumeration | GLOBAL | SESSION |
table_cache |
numeric | GLOBAL |
table_type |
enumeration | GLOBAL | SESSION |
thread_cache_size |
numeric | GLOBAL |
timestamp |
boolean | SESSION |
tmp_table_size |
enumeration | GLOBAL | SESSION |
transaction_alloc_block_size |
numeric | GLOBAL | SESSION |
transaction_prealloc_size |
numeric | GLOBAL | SESSION |
tx_isolation |
enumeration | GLOBAL | SESSION |
unique_checks |
boolean | SESSION |
wait_timeout |
numeric | GLOBAL | SESSION |
warning_count |
numeric | SESSION |
Les variables qui sont marquées comme ``string'' prennent une valeur de chaîne de caractères. Les variables qui sont marquées comme ``numeric'' prennent un nombre. Les variables qui sont marquées comme ``boolean'' peuvent prendre 0 ou 1, ON ou OFF. Les variables qui sont marquées comme ``enumeration'' doivent normalement prendre l'une des valeurs possible de cette variable, mais elles peuvent aussi prendre le numéro de l'élément dans l'énumération. Pour les systèmes à énumération, la première énumération est 0. Cela est différent des colonnes de type ENUM, pour qui la première valeur est la 1.
SHOW STATUS affiche des informations sur le statut du serveur (comme par exemple, mysqladmin extended-status). L'affichage ressemble à ce qui est affiché ci-dessous, mais les valeurs différeront sûrement de votre propre serveur.
mysql> SHOW STATUS;
+--------------------------+------------+
| Variable_name | Value |
+--------------------------+------------+
| Aborted_clients | 0 |
| Aborted_connects | 0 |
| Bytes_received | 155372598 |
| Bytes_sent | 1176560426 |
| Connections | 30023 |
| Created_tmp_disk_tables | 0 |
| Created_tmp_files | 60 |
| Created_tmp_tables | 8340 |
| Delayed_errors | 0 |
| Delayed_insert_threads | 0 |
| Delayed_writes | 0 |
| Flush_commands | 1 |
| Handler_delete | 462604 |
| Handler_read_first | 105881 |
| Handler_read_key | 27820558 |
| Handler_read_next | 390681754 |
| Handler_read_prev | 6022500 |
| Handler_read_rnd | 30546748 |
| Handler_read_rnd_next | 246216530 |
| Handler_update | 16945404 |
| Handler_write | 60356676 |
| Key_blocks_used | 14955 |
| Key_read_requests | 96854827 |
| Key_reads | 162040 |
| Key_write_requests | 7589728 |
| Key_writes | 3813196 |
| Max_used_connections | 0 |
| Not_flushed_delayed_rows | 0 |
| Not_flushed_key_blocks | 0 |
| Open_files | 2 |
| Open_streams | 0 |
| Open_tables | 1 |
| Opened_tables | 44600 |
| Qcache_free_blocks | 36 |
| Qcache_free_memory | 138488 |
| Qcache_hits | 79570 |
| Qcache_inserts | 27087 |
| Qcache_lowmem_prunes | 3114 |
| Qcache_not_cached | 22989 |
| Qcache_queries_in_cache | 415 |
| Qcache_total_blocks | 912 |
| Questions | 2026873 |
| Select_full_join | 0 |
| Select_full_range_join | 0 |
| Select_range | 99646 |
| Select_range_check | 0 |
| Select_scan | 30802 |
| Slave_open_temp_tables | 0 |
| Slave_running | OFF |
| Slow_launch_threads | 0 |
| Slow_queries | 0 |
| Sort_merge_passes | 30 |
| Sort_range | 500 |
| Sort_rows | 30296250 |
| Sort_scan | 4650 |
| Table_locks_immediate | 1920382 |
| Table_locks_waited | 0 |
| Threads_cached | 0 |
| Threads_connected | 1 |
| Threads_created | 30022 |
| Threads_running | 1 |
| Uptime | 80380 |
+--------------------------+------------+
De nombreuses variables de statut sont remises à 0 par la commande FLUSH STATUS.
Les variables de statut ont les significations suivantes. Les variables compteur de commande Com_xxx ont été ajoutées en MySQL 3.23.47. Les variables de cache de requêtes Qcache_xxx ont été ajoutées en MySQL 4.0.1. Sinon, les variables sans versions sont présentes depuis MySQL 3.22.
-
Aborted_clientsNombre de connexions annulées parce que le client est mort sans se déconnecter correctement. See Section A.2.10, « Erreurs de communication / Connexion annulée ».
-
Aborted_connectsNombre de tentatives de connexions au serveur MySQL qui ont échouées. See Section A.2.10, « Erreurs de communication / Connexion annulée ».
-
Binlog_cache_disk_useLe nombre de transactions qui ont utilisé le cache de log binaire mais qui ont dépassé la taille de
binlog_cache_sizeet ont finalement utilisé un fichier temporaire pour stocker les commandes de la transaction. Cette variable a été ajoutée en MySQL 4.1.2. -
Binlog_cache_useLe nombre de transactions qui ont utilisé le cache de log binaire temporaire. Cette variable a été ajoutée en MySQL 4.1.2.
-
Bytes_receivedNombre d'octets re¸u de tous les clients. Cette variable a été ajoutée en MySQL 3.23.7.
-
Bytes_sentNombre d'octets envoyés à tous les clients. Cette variable a été ajoutée en MySQL 3.23.7.
-
Com_xxxNombre d'exécution de chaque commande
xxx. Il y a une variable par type de commande. Par exemple,Com_deleteetCom_insertcomptent respectivement les commandesDELETEetINSERT. -
ConnectionsNombre de tentatives de connexions au serveur MySQL, réussies ou pas.
-
Created_tmp_disk_tablesNombre de tables temporaires implicites créées sur le disque lors d'exécutions de commandes. Cette variable a été ajoutée en MySQL 3.23.24.
-
Created_tmp_filesCombien de fichiers temporaires
mysqlda créé. SiCreated_tmp_disk_tablesest grand, augmentez la taille detmp_table_sizepour que les tables temporaires restent plus souvent en mémoire. -
Created_tmp_tablesNombre de tables temporaires implicites créées en mémoire lors d'exécutions de commandes. Cette variable a été ajoutée en MySQL 3.23.28.
-
Delayed_errorsNombre de lignes écrites avec
INSERT DELAYEDpour lesquelles des erreurs sont survenues (probablement une erreur de doublons (duplicate key)). -
Delayed_insert_threadsNombre de gestionnaires d'insertion retardées sont en cours d'utilisation.
-
Delayed_writesNombre de lignes écrites avec
INSERT DELAYED. -
Flush_commandsNombre de commandes
FLUSH. -
Handler_commitNombre de commandes internes
COMMIT. Cette variable a été ajoutée en MySQL 4.0.2. -
Handler_deleteNombre de fois qu'une ligne a été effacées dans une table.
-
Handler_read_firstNombre de fois que la première ligne a été lue dans un index. Si ce chiffre est haut, c'est que le serveur fait de nombreuses recherches par analyse complète de la table, par exemple
SELECT col1 FROM foo, en supposant quecol1est indexé. -
Handler_read_keyNombre de requête de lecture de ligne basées sur une clé. Si ce chiffre est grand, c'est une bonne indication de l'indexation correcte de vos tables.
-
Handler_read_nextNombre de requête de lecture de la ligne suivante en ordre. Cela sera augmenté si vous listez une colonne avec une contrainte d'intervalle. Cette valeur sera aussi incrémentée si vous effectuez un scan d'index.
-
Handler_read_prevNombre de requête de lecture de la clé précédente, dans l'ordre. C'est souvent utilisé pour optimiser les clauses
ORDER BY ... DESC. Cette variable a été ajoutée en MySQL 3.23.6. -
Handler_read_rnd_nextNombre de requêtes de lecture de la prochaine ligne dans le fichier de données. Ce chiffre sera grand si vous faîtes de nombreux scans de tables. Généralement, cela indique que vos requêtes ne sont pas écrites pour profiter des index que vous avez mis en place.
-
Handler_read_rndNombre de lecture d'une ligne basée sur une position fixe. Ce chiffre sera grand si vous effectuez de nombreuses requêtes qui réclament le tri du résultat.
-
Handler_rollbackNombre de commandes internes
ROLLBACK. -
Handler_updateNombre de requête de modification d'une ligne dans une table.
-
Handler_writeNombre de requête pour insérer une ligne dans une table.
-
Key_blocks_usedNombre de blocs utilisés dans un cache de clé. Vous pouvez utiliser cette valeur pour déterminer l'occupation du cache de clé : voyez la discussion de
key_buffer_sizedans Section 5.2.3, « Variables serveur système ». -
Key_read_requestsNombre de requêtes de lecture d'un bloc de clé dans le cache.
-
Key_readsNombre de lecture physique d'un bloc de clé sur le disque. Si
Key_readsest grand, alors votre valeur pourkey_buffer_sizeest probablement trop petite. Le ratio peut être calculé avecKey_reads/Key_read_requests. -
Key_write_requestsNombre de requêtes d'écriture d'un bloc de clé dans le cache.
-
Key_writesNombre d'écriture physiques de bloc de clé sur le disque.
-
Max_used_connectionsNombre maximum de connexions utilisées simultanément.
-
Not_flushed_delayed_rowsNombre de lignes en attente d'écriture dans les listes
INSERT DELAY. -
Not_flushed_key_blocksNombre de blocs de clés dans le cache de clés, qui ont été modifiées, mais pas encore écrites sur le disque.
-
Open_filesNombre de fichiers ouverts.
-
Open_streamsNombre de flux ouverts (utilisés généralement pour les logs).
-
Open_tablesNombre de tables ouvertes.
-
Opened_tablesNombre de tables qui ont été ouvertes. Si
Opened_tablesest grand, votre valeur pourtable_cacheest probablement trop petite. -
Qcache_free_blocksLe nombre de blocs de mémoire libre dans le cache de requête.
-
Qcache_free_memoryLa quantité de mémoire libre dans le cache de requête.
-
Qcache_hitsLe nombre de sollicitations du cache.
-
Qcache_insertsLe nombre de requêtes ajoutées dans le cache.
-
Qcache_lowmem_prunesLe nombre de requêtes qui ont été effacées du cache, pour libérer de la place.
-
Qcache_not_cachedLe nombre de requêtes non-cachées (elles ne peuvent pas être mises en cache, ou à cause de
query_cache_type). -
Qcache_queries_in_cacheLe nombre de requêtes enregistrées dans le cache.
-
Qcache_total_blocksLe nombre total de blocs dans le cache de requêtes.
-
QuestionsNombre de requêtes envoyées au serveur.
-
Rpl_statusStatut de la réplication sans erreur (réservé pour utilisation ultérieure).
-
Select_full_joinNombre de jointures sans clé (si cette variable vaut 0, vous devriez vérifier soigneusement les index de vos tables). Cette variable a été ajoutée en MySQL 3.23.25.
-
Select_full_range_joinNombre de jointures où une recherche d'intervalle a été utilisée. Cette variable a été ajoutée en MySQL 3.23.25.
-
Select_range_checkNombre de jointures sans clé, où l'utilisation de clé a été vérifiée après chaque ligne (si cette variable vaut 0, vous devriez vérifier soigneusement les index de vos tables). Cette variable a été ajoutée en MySQL 3.23.25.
-
Select_rangeNombre de jointures où une recherche d'intervalle a été utilisée sur la première table. (Ce n'est généralement pas important, même si cette valeur est importante). Cette variable a été ajoutée en MySQL 3.23.25.
-
Select_scanNombre de jointures où la première table a été totalement analysée. Cette variable a été ajoutée en MySQL 3.23.25.
-
Slave_open_temp_tablesNombre de tables temporaires actuellement utilisée par le thread esclave. Cette variable a été ajoutée en MySQL 3.23.29.
-
Slave_runningCette variable vaut
ONsi ce serveur est un esclave connecté au maître. Cette variable a été ajoutée en MySQL 3.23.16. -
Slow_launch_threadsNombre de threads qui ont pris plus de
slow_launch_timesecondes pour être créés. Cette variable a été ajoutée en MySQL 3.23.15. -
Slow_queriesNombre de requêtes qui ont pris plus de
long_query_timepour s'exécuter. See Section 5.9.5, « Le log des requêtes lentes ». -
Sort_merge_passesNombre de passes que l'algorithme de tri a du faire. Si cette valeur est grande, vous devriez vérifier la taille de
sort_buffer. -
Sort_rangeNombre de tris qui ont été fait sur des intervalles.
-
Sort_rowsNombre de lignes triées.
-
Sort_scanNombre de tris qui ont été fait en analysant la table.
-
ssl_xxxVariables utilisées par SSL; Réservée pour utilisation ultérieure. Ces variables ont été ajoutées en MySQL 4.0.0.
-
Table_locks_immediateNombre de fois que la table a re¸u immédiatement un verrou. Disponible depuis 3.23.33. Cette variable a été ajoutée en MySQL 3.23.33.
-
Table_locks_waitedNombre de fois qu'une table n'a pu recevoir de verrou immédiatement, et qu'il a fallu attendre. Si ce chiffre est haut, vous avez des problèmes de performance, et vous devriez optimiser vos requêtes, couper vos tables en deux, ou utiliser la réplication. Disponible depuis la version 3.23.33. Cette variable a été ajoutée en MySQL 3.23.33.
-
Threads_cachedNombre de threads dans le cache de thread. Cette variable a été ajoutée en MySQL 3.23.17.
-
Threads_connectedNombre de connexions actuellement ouvertes.
-
Threads_createdNombre de threads créés pour gérer les connexions. Si
Threads_createdest grand, vous pouvez augmenter la valeur de -
Threads_runningNombre de threads qui ne dorment pas.
-
UptimeDurée de vie du serveur, en secondes depuis le redémarrage.
Le processus d'extinction du serveur peut se résumer comme ceci :
-
Le processus est activé
-
Le serveur crée un thread d'extinction, si nécessaire
-
Le serveur cesse d'accepter les nouvelles connexions
-
Le serveur conclut les activités en cours
-
Les moteurs de stockages se ferment
-
Le serveur se termine
Voici une version plus détaillée de ce synopsis :
-
Le processus est activé
L'extinction du serveur peut être initiée par plusieurs méthodes. Par exemple, un utilisateur avec le droit de
SHUTDOWNpeut exécuter la commande mysqladmin shutdown. mysqladmin peut être utilisée sur n'importe quelle plate-forme supportée par MySQL. Les autres méthodes d'extinction spécifiques aux systèmes d'exploitation existent aussi : le serveur s'éteind lorsqu'il re¸oit un signalSIGTERMsous Unix. Un serveur installé comme service Windows s'éteind sur ordre du gestionnaire. -
Le serveur crée un thread d'extinction, si nécessaire
En fonction de l'origine de l'extinciton, le serveur peut lancer un thread qui gèrera l'extinction. Si l'extinction a été demandée par un client, un thread d'extinction est créé. Si l'extinction est le résultat d'un signal
SIGTERM, le thread signal pourra gérer l'extinction lui-même, ou alors lancer un autre thread. SI le serveur essaie de créer un thread et ne peut pas le faire (par exemple, plus de mémoire), il va émettre un message qui apparaitra comme ceci dans les logs :Error: Can't create thread to kill server
-
Le serveur cesse d'accepter les nouvelles connexions
Pour éviter de voir de nouvelles opérations se lancer, le serveur commence par arrêter d'accepter les nouvelles connexions. Il fait cela en fermant les connexions au réseau qui attendent les connexions : le port TCP/IP, la socket Unix ou le Pipe Windows.
-
Le serveur conclut les activités en cours
Pour chaque thread associé à une connexion réseau, la connexion est interrompue, et le thread est marqué comme mort. Le thread s'arrête lorsqu'il remarque qu'il a été tué. Les threads qui sont inactifs meurent rapidement. Les threads qui traitent des requêtes vérifient périodiquement leur état, et prennent plus de temps pour s'arrêter. Pour plus d'information sur la fin des threads, voyez Section 13.5.4.3, « Syntaxe de
KILL», en particulier à propos des commandesREPAIR TABLEouOPTIMIZE TABLEsur les tablesMyISAM.Pour les threads qui ont une transaction ouverte, la transaction est annulée. Notez que si un thread modifie une table non-transactionnelle, une opération comme un
UPDATEmulti-ligne ou unINSERTpeuvent laisser la table partiellement modifiée, car l'opération peut se terminer avant sa fin logique.Si le serveur est un serveur de réplication, les threads associés avec les esclaves sont traités comme n'importe quel autre client. C'est à dire, ils sont marqués comme terminés, et se termine à leur prochaine vérification d'état.
Si le serveur est un esclave de réplication, le thread d'entre/sortie et le thread SQL sont arrêtés avant que le thread client ne soit tué. Le thread SQL est autorisé à terminer sa commande en cours (pour éviter des problèmes de réplication), puis cesse. Si le thread SQL était au milieu d'une transaction, elle sera annulée.
-
Les moteurs de stockages se ferment
A ce stade, les cache de tables ont envoyés sur le disque, et toutes les tables ouvertes sont fermées.
Chaque moteur de stockage effectue les opérations nécessaire pour fermer les tables qu'il gère. Par exemple, MyISAM envoye les dernières écritures pour la table. InnoDB vide ses buffers sur le disque, écrit le LSN courant dans l'espace de table, et termine ses propres threads.
-
Le serveur se termine
Cette section décrit certaines règles générales de sécurité a bien connaître pour rendre votre installation MySQL plus sécuritaire contre des attaques ou des erreurs de manipulations. Pour des informations sur le contrôle d'accès à MySQL, voyez Section 5.5, « Règles de sécurité et droits d'accès au serveur MySQL ».
Tous ceux qui utilisent MySQL avec un serveur connecté à Internet doivent lire cette section, pour éviter les erreurs les plus communes.
En parlant de sécurité, nous devons insister sur la nécessiter de protéger tout le serveur, et non pas juste MySQL, contre tous les types d'attaques : surveillance des communications, usurpation, ré-exécution et dénis de service. Nous ne pouvons pas couvrir tous les aspects de tolérance aux fautes et de disponibilité ici.
MySQL dispose d'un système de sécurité basé sur des listes de contrôle d'accès (Access Control Lists, or ACL) pour toutes les connexions, requêtes et opérations que l'utilisateur peut faire. Il y a aussi le support des connexions SSL entre le client et le serveur MySQL. De nombreux concepts présentés ici ne sont pas spécifiques à MySQL : le même concept s'applique à de nombreuses applications.
Lorsque vous utilisez MySQL, suivez ces règles aussi souvent que possible :
-
Ne donnez jamais à personne (sauf aux comptes MySQL
root) accès à la tableuserde la basemysql! C'est primordial. Le mot de passe chiffré est le vrai mot de passe de MySQL. Toute personne qui connaît le mot de passe de la tableuseret qui a accès à l'hôte associé peut facilement se connecter sous le nom de cet utilisateur. -
Apprenez à fond le système de droits MySQL. Les commandes
GRANTetREVOKEsont utilisées pour contrôler les accès à MySQL. Ne donnez pas plus de droits que nécessaire. Ne donnez jamais de droits à tous les serveurs hôtes.Liste de vérification :
-
Essayez la commande en ligne
mysql -u root. Si vous pouvez vous connecter, sans donner de mot de passe, vous avez un problème. Toute personne peut se connecter au serveur comme utilisateurrootavec le maximum de droits! Passez en revue les instructions d'installation de MySQL, en insistant sur les passages où le mot de passerootest configuré. See Section 2.5.3, « Création des premiers droits MySQL ». -
Utilisez la commande
SHOW GRANTSet vérifiez qui a accès à quoi. Puis, utilisez la commandeREVOKEpour retirer les droits inutiles.
-
-
Ne stockez jamais de mot de passe en clair dans votre base de données. Si votre serveur est compromis, le pirate aura alors la liste complète des mots de passe, et pourra les utiliser. A la place, utilisez
MD5(),SHA1()ou une autre fonction de signature injective. -
Ne choisissez pas vos mots de passe dans un dictionnaire. Il y a des programmes spéciaux pour les rechercher. Même des mots de passe tels que ``
xfish98'' est très faible. Par contre, ``duag98'' est bien mieux : il contient aussi le mot ``fish'' mais décalé d'une touche sur un clavierQWERTY. Une autre méthode de génération consiste à prendre la première lettre de chaque mot d'une phrase : ``Maupa'' est issu de ``Marie a un petit agneau.'' C'est facile à retenir, mais difficile à devenir pour un attaquant. -
Investissez dans un coupe-feu. Cela protège de 50% de tous les types d'attaque et vulnérabilité. Placez MySQL derrière le coupe-feu, ou dans une zone démilitarisée (
DMZ).Liste de vérification :
-
Essayez de scanner vos portes depuis l'Internet, avec des outils comme
nmap. MySQL utilise le port 3306 par défaut. Ce port ne doit pas être accessible à tous les serveurs. Une autre méthode simple pour vérifier si le port MySQL est ouvert ou non, est d'essayez la commande suivante depuis une machine distante, oùserver_hostest le serveur qui héberge MySQL :shell>
telnet server_host 3306Si vous obtenez une connexion et des caractères binaires, le port est ouvert, et il devrait être fermé par votre routeur ou votre coupe-feu, à moins d'avoir une bonne raison pour le garder ouvert. Si
telnetattend, ou que la connexion est refusée, tout va bien : le port est bloqué.
-
-
Ne faîtes confiance à aucune donnée entrée par les utilisateurs de votre application. Ils peuvent déjouer vos filtres en entrant des séquences spéciales via les formulaires Web, les URL ou tout autre point d'entrée de l'application. Assurez vous que votre application reste sûre si un utilisateur entre une chaîne telle que ``
; DROP DATABASE mysql;''. C'est un exemple extrêmement simple, mais il dévoilera un trou de sécurité important. Il engendrera aussi des pertes de données si un pirate, utilisant cette technique, vous attaque.Une erreur courante est de ne protéger que les chaînes de caractères. N'oubliez pas de protéger aussi les valeurs numériques. Si une application génère une requête telle que
SELECT * FROM table WHERE ID=234où l'utilisateur fournit le234, alors ce dernier peut proposer la valeur234 OR 1=1pour conduire à la requêteSELECT * FROM table WHERE ID=234 OR 1=1. Par conséquent, le serveur va lire toutes les lignes de la table. Cela va diffuser toutes les lignes de votre application, et générer un trafic excessif. Pour vous prémunir contre ce type d'attaque, ajoutez toujours des guillemets autour des constantes numériques :SELECT * FROM table WHERE ID='234'. Si un utilisateur entre des informations supplémentaires, elles seront intégrées dans la chaîne. Dans un contexte numérique, MySQL supprimera automatiquement les caractères incompréhensibles.Parfois, les gens pensent que si une base de données contient des informations publiques, elle n'a pas besoin d'être défendue. C'est faux. Même si vous pouvez accéder à toutes les lignes de la table, il faut toujours se prémunir contre les dénis de service (par exemple, en utilisant la technique ci-dessus pour générer un trafic excessif). Sinon, votre serveur sera inutilisable.
Liste de vérification :
-
Essayez d'entrer des caractères ‘
'’ et ‘"’ dans tous vos formulaires Web. Si vous obtenez une erreur MySQL, étudiez immédiatement le problème. -
Essayez de modifier une URL dynamique en ajoutant les séquences
%22(‘"’),%23(‘#’) et%27(‘'’). -
Essayez de modifier les types de données des URL dynamiques de numériques en textuels, avec les caractères cités ci-dessus. Votre application doit être sécurisée contre ce type d'attaque.
-
Essayez d'entrer des caractères, des espaces et d'autres symboles spéciaux, autre que des nombres, dans un champ numérique. Votre application devrait supprimer tous ces caractères avant de les passer à MySQL, ou générer une erreur. Passer à MySQL des valeurs non vérifiées est très dangereux.
-
Vérifiez la taille des chaînes avant de les passer à MySQL.
-
Essayez de faire connecter votre application en utilisant un autre nom que celui qui est utilisé pour les tâches d'administration. Ne donnez pas à votre application des droits dont elle n'a pas besoin.
-
-
De nombreuses interfaces de programmation disposent de moyens pour protéger les valeurs. Correctement utilisés, ils évitent aux utilisateurs de l'application de faire passer des caractères qui auront un effet différent de celui attendu :
-
MySQL C API : Utilisez la fonction
mysql_real_escape_string(). -
MySQL++ : Utilisez les options
escapeetquotedans le flux de requête. -
PHP : Utilisez la fonction
mysql_escape_string(), qui est basée sur la fonction C du même nom. Avant PHP 4.0.3, utilisezaddslashes(). -
Perl
DBI: Utilisez la méthodequote()ou utilisez les variables de requête. -
Java JDBC : Utilisez un objet
PreparedStatementou utilisez les variables de requête.
Les autres interfaces ont des fonctionnalités similaires.
-
-
Ne transmettez pas de données déchiffrées sur Internet. Cette information est accessible à tout ceux qui ont le temps et la capacité d'intercepter et d'utiliser ces mots de passe. Utilisez plutôt un protocole sécurisé comme SSL ou SSH. MySQL supporte les connexions SSL depuis la version 4.0.0. SSH peut être utilisé pour créer un tunnel chiffré et compressé de communication.
-
Apprenez à utiliser les programmes
tcpdumpetstrings. Dans la plupart des cas, vous pouvez vérifier si un flux MySQL est chiffré avec la commande suivante :shell>
tcpdump -l -i eth0 -w - src or dst port 3306 | strings(Cette commande fonctionne sous Linux, et devrait être adaptée facilement dans les autres systèmes.) Attention : si vous ne voyez pas de données en clair, cela ne signifie pas toujours que les informations sont chiffrées. Si vous avez besoin de haute sécurité, consultez un expert.
Lorsque vous vous connectez à MySQL, vous devriez avoir besoin d'un mot de passe. Ce mot de passe n'est pas transmis en texte clair sur le réseau. La gestion des mots de passe durant l'identification des utilisateurs a été améliorée en MySQL 4.1.1 pour être très sécurisée. Si vous utilisez une vieille version de MySQL, ou si vous utilisez toujours les mots de passe de type pre-4.1.1, l'algorithme de chiffrement n'est pas très fort, quelques efforts permettront à un pirate d'obtenir votre mot de passe s'il est capable de surveiller le trafic entre le client et le serveur. (Voyez Section 5.5.9, « Hashage de mots de passe en MySQL 4.1 » pour une discussion des différentes méthodes de gestions des mots de passe). Si la connexion entre le client et le serveur utilise des réseaux non fiables, il est alors recommandé d'utiliser un tunnel SSH.
Toutes les autres informations sont transférées comme du texte clair, et quiconque surveille la connexion pourra les lire. Si vous souhaitez relever ce niveau de sécurité, il est recommandé d'utiliser le protocole compressé (avec les versions de MySQL 3.22 et plus récentes), pour compliquer considérablement le problème. Pour rendre la communication encore plus sûre, vous pouvez aussi utiliser ssh. Vous trouverez une version Open Source du client ssh sur le site http://www.openssh.org/, et une version commerciale du client ssh sur le site de http://www.ssh.com/. Avec eux, vous pouvez mettre en place une connexion TCP/IP chiffrée entre le serveur et le client MySQL.
Si vous utilisez MySQL 4.0, vous pouvez aussi utiliser le support OpenSSL interne. See Section 5.6.7, « Utilisation des connexions sécurisées ».
Pour rendre le système MySQL encore plus sûr, nous vous recommandons de suivre les suggestions suivantes :
-
Utilisez des mots de passe pour tous les utilisateurs MySQL. N'oubliez pas que tout le monde peut se connecter avec un nom d'utilisateur quelconque, simplement avec l'option
mysql -u autre_utilisateur nom_de_base, siautre_utilisateurn'a pas de mot de passe. C'est un comportement classique pour les applications client/serveur que le client spécifie son nom d'utilisateur. Il sera plus difficile à un attaquant de pénétrer dans votre serveur si tous les comptes ont un mot de passe.Vous pouvez modifier les mots de passe de tous les utilisateurs en modifiant le script
mysql_install_dbavant de l'exécuter, ou vous pouvez modifier seulement le mot de passe durootMySQL comme ceci@ :shell>
mysql -u rootmysql>UPDATE mysql.user SET Password=PASSWORD('nouveau_mot_de_passe')->WHERE User='root';mysql>FLUSH PRIVILEGES; -
N'exécutez jamais le démon MySQL avec l'utilisateur Unix
root. C'est très dangereux, car tout personne ayant le droit deFILEpour créer des fichiers au nom duroot(par exemple,~root/.bashrc). Pour éviter cela,mysqldrefusera de s'exécuter au nom derootà moins que soit précisé l'option--user=root.mysqldpeut être exécuté avec un utilisateur ordinaire sans droits particuliers. Vous pouvez aussi créer un utilisateur Unixmysqlpour rendre cela encore plus sûr. Si vous exécutezmysqldsous un autre utilisateur Unix, vous n'avez pas à changer le mot de passerootdans la tableuser, car les noms d'utilisateurs MySQL n'ont rien à voir avec les noms d'utilisateurs Unix. Pour démarrermysqldsous un autre nom d'utilisateur Unix, ajoutez la ligneuser, qui spécifie le nom de l'utilisateur, dans le fichier d'options de[mysqld]/etc/my.cnfou dans le fichiermy.cnfprésent dans le dossier de données du serveur. Par exemple :[mysqld] user=mysql
Cette ligne va forcer le serveur à démarrer en tant qu'utilisateur
mysql, même si vous démarrez le serveur manuellement ou avec les scriptssafe_mysqld, oumysql.server. Pour plus de détails, voyez Section A.3.2, « Comment exécuter MySQL comme un utilisateur normal ».Exécuter
mysqlsous un autre compte Unix querootne signifie pas que vous devez changer le nom derootdans la tableuser. Les comptes utilisateurs de MySQL n'ont rien à voir avec ceux du compte Unix. -
N'autorisez pas l'utilisation de liens symboliques pour les tables. Cette fonctionnalité peut être désactivée avec l'option
--skip-symbolic-links. C'est particulièrement important si vous utilisezmysqldcommeroot, car tout utilisateur a alors le droit d'écrire des données sur le disque, n'importe où sur le système!! See Section 7.6.1.2, « Utiliser les liens symboliques avec les tables sous Unix ». -
Vérifiez que l'utilisateur Unix qui exécute
mysqldest le seul utilisateur avec les droits de lecture et écriture dans le dossier de base de données. -
Ne donnez pas le droit de
PROCESSà tous les utilisateurs. La liste fournie parmysqladmin processlistaffiche le texte des requêtes actuellement exécutées, ce qui permet à toute personne pouvant exécuter cette commande de lire des valeurs qui seraient en clair, comme :UPDATE user SET password=PASSWORD('not_secure').mysqldréserve une connexion supplémentaire pour les utilisateurs qui ont le droit dePROCESS, afin que lerootMySQL puisse toujours se connecter et vérifier que tout fonctionne bien, même s'il ne reste plus de connexions libres pour les autres utilisateurs.Le droit
SUPERpeut être utilisé pour fermer des connexions clients, changer les variables systèmes et contrôler la réplication. -
Ne donnez pas le droit de
FILEà tous les utilisateurs. Tout utilisateur qui possède ce droit peut écrire un fichier n'importe où sur le serveur, avec les droits hérités du démonmysqld! Pour rendre cela plus sécuritaire, tous les fichiers générés parSELECT ... INTO OUTFILEsont lisibles par tous, mais personne ne peut les modifier.Le droit de
FILEpeut aussi être utilisé pour lire n'importe quel fichier accessible en lecture au démon qui fait tourner MySQL. Il devient donc possible, suivant les configurations, d'utiliser la commandeLOAD DATAsur le fichier/etc/passwdpour tout mettre en table, et ensuite le relire avec la commandeSELECT. -
Si vous ne faites pas confiance à votre DNS, vos pouvez simplement utiliser des adresses IP au lieu des noms d'hôtes. Dans ce cas, soyez très prudents lors de la création de droits qui utilisent des caractères joker.
-
Si vous voulez restreindre le nombre de connexions d'un utilisateur, vous pouvez le faire en utilisant la variable
max_user_connectionsdemysqld. La commandeGRANTdispose aussi d'option de contrôle des ressources, pour limiter l'utilisation du serveur par un compte utilisateur.
Les options suivantes de mysqld affectent la sécurité :
-
--local-infile[=(0|1)]Si vous utilisez
--local-infile=0alors vous ne pourrez pas utiliserLOAD DATA LOCAL INFILE. See Section 5.4.4, « Problèmes de sécurité avec LOAD DATA LOCAL ». -
--safe-show-databaseAvec cette option, la commande
SHOW DATABASESne retourne que les bases pour lesquelles l'utilisateur courant a des droits. Depuis la verison 4.0.2, cette option est abandonnée, et ne sert plus à rien (elle est activée par défaut), car désormais, il y a le droit deSHOW DATABASES. See Section 13.5.1.3, « Syntaxe deGRANTetREVOKE». -
--safe-user-createSi cette option est activée, tout utilisateur ne peut créer d'autres utilisateurs avec les droits de
GRANT, s'il ne dispose pas des droits d'insertion dans la tablemysql.user. Si vous voulez donner un accès à un utilisateur pour qu'il puisse créer des utilisateurs avec les droits dont il dispose, vous pouvez lui donner les droits suivants :mysql>
GRANT INSERT(user) ON mysql.user TO 'user'@'hostname';Cela va s'assurer que l'utilisateur ne peut par modifier une colonne directement, mais qu'il peut exécuter la commande
GRANTsur d'autres utilisateurs. -
--secure-authInterdit l'identification pour les comptes qui ont d'anciens mot de passe (avant la version 4.1). Cette option est valable depuis MySQL 4.1.1.
-
--skip-grant-tablesCette option force le serveur à ne pas utiliser les tables de droits. Cette option donne donc tous les droits à tout le monde sur le serveur ! Vous pouvez forcer un serveur en fonctionnement à reprendre les tables de droits en exécutant la commande
mysqladmin flush-privilegesoumysqladmin reload.) -
--skip-name-resolveLes noms d'hôtes ne sont pas résolus. Toutes les valeurs de la colonne
Hostdans les tables de droits doivent être des adresses IP, ou bienlocalhost. -
--skip-networkingNe pas accepter les connexions TCP/IP venant du réseau. Toutes les connexions au serveur
mysqlddoivent être faîtes avec les sockets Unix. Cette option n'existe pas pour les versions antérieures à la 3.23.27, avec les MIT-pthread, car les sockets Unix n'étaient pas supportés par lesMIT-pthreadsà cette époque. -
--skip-show-databaseNe pas autoriser la commande
SHOW DATABASES, à moins que l'utilisateur n'ait les droits deSHOW DATABASES. Depuis la version 4.0.2, vous n'avez plus besoin de cette option, car les accès sont désormais donnés spécifiquement avec le droitSHOW DATABASES.
La commande LOAD DATA peut lire des données sur le serveur hôte, ou bien charger un fichier sur le client, avec l'option LOCAL.
Il existe deux problèmes particuliers pour le support de cette commande :
-
Comme la lecture du fichier est réalisée depuis le serveur, il est possible théoriquement de créer un serveur MySQL modifié qui pourrait lire n'importe quel fichier de la machine cliente, qui serait accessible à l'utilisateur.
-
Dans un environnement web, où les clients se connectent depuis un serveur web, un utilisateur peut se servir de la commande
LOAD DATA LOCALpour lire les fichiers qui sont sur le serveur web, et auquel ce dernier a accès (en supposant qu'un utilisateur peut exécuter n'importe quelle commande sur le serveur).
Pour traiter ces problèmes, nous avons changé la gestion des commandes LOAD DATA LOCAL depuis MySQL version 3.23.49 et MySQL version 4.0.2 (4.0.13 pour Windows) :
-
Par défaut, tous les clients MySQL et les bibliothèques des distributions binaires sont compilées avec l'option
--enable-local-infile, pour être compatible avec MySQL 3.23.48 et plus ancien. -
Si vous ne configurez pas MySQL avec l'option
--enable-local-infile, alorsLOAD DATA LOCALsera désactivé par tous les clients, à moins que l'optionmysql_options(... MYSQL_OPT_LOCAL_INFILE, 0)soit activée dans le client. See Section 24.2.3.43, «mysql_options()». -
Pour le client en ligne de commande
mysql,LOAD DATA LOCALpeut être activé en spécifiant l'option--local-infile[=1], ou désactivé avec--local-infile=0. -
Vous pouvez désactiver toutes les commandes
LOAD DATA LOCALdu serveur MySQL en démarrantmysqldavec--local-infile=0. Similairement, pourmysqlimport, les options--localet-Lactive le chargement distant de fichiers. Dans ce cas, il faut que le serveur accepte aussi cette configuration pour que l'opération fonctionne. -
Au cas où
LOAD DATA LOCAL INFILEest désactivé sur le serveur ou le client, vous obtiendrez le message d'erreur (1148) :The used command is not allowed with this MySQL version
- 5.5.1. Rôle du système de privilèges
- 5.5.2. Comment fonctionne le système de droits
- 5.5.3. Droits fournis par MySQL
- 5.5.4. Se connecter au serveur MySQL
- 5.5.5. Contrôle d'accès, étape 1 : Vérification de la connexion
- 5.5.6. Contrôle d'accès, étape 2 : Vérification de la requête
- 5.5.7. Quand les modifications de privilèges prennent-ils effets ?
- 5.5.8. Causes des erreurs
Access denied - 5.5.9. Hashage de mots de passe en MySQL 4.1
MySQL est pourvu d'un système avancé mais non standard de droits. Cette section décrit son fonctionnement.
La fonction première du système de privilèges de MySQL est d'authentifier les utilisateurs se connectant à partir d'un hôte donné, et de leur associer des privilèges sur une base de données comme SELECT, INSERT, UPDATE et DELETE.
Les fonctionnalités additionnelles permettent d'avoir un utilisateur anonyme et de contrôler les privilèges pour les fonctions spécifiques à MySQL comme LOAD DATA INFILE et les opérations administratives.
Le système de droits de MySQL s'assure que les utilisateurs font exactement ce qu'ils sont supposés pouvoir faire dans la base. Lorsque vous vous connectez au serveur, vous identité est déterminée par l'hôte d'où vous vous connectez et le nom d'utilisateur que vous spécifiez. Le système donne les droits en fonction de votre identité et de ce que vous voulez faire.
MySQL considère votre nom d'hôte et d'utilisateur pour vous identifier, car il n'y pas que peu de raisons de supposer que le même nom d'utilisateur appartient à la même personne, quelque soit son point de connexion sur Internet. Par exemple, l'utilisateur joe qui se connecte depuis office.com n'est pas forcément la même personne que joe qui se connecte depuis elsewhere.com. MySQL gère cela en vous aidant à distinguer les différents utilisateurs et hôtes qui ont le même nom : vous pourriez donner des droits à joe lorsqu'il utilise sa connexion depuis office.com, et un autre jeu de droits lorsqu'il se connecte depuis elsewhere.com.
Le contrôle d'accès de MySQL se fait en deux étapes :
-
Etape 1 : Le serveur vérifie que vous êtes autorisé à vous connecter.
-
Etape 2 : En supposant que vous pouvez vous connecter, le serveur vérifie chaque requête que vous soumettez, pour vérifier si vous avez les droits suffisants pour l'exécuter. Par exemple, si vous sélectionnez des droits dans une table, ou effacez une table, le serveur s'assure que vous avez les droits de
SELECTpour cette table, ou les droits deDROP, respectivement.
Si vos droits ont changé (par vous-mêmes ou bien par un administrateur), durant votre connexion, ces changements ne prendront peut être effets qu'à la prochaine requête. Voyez la section Section 5.5.7, « Quand les modifications de privilèges prennent-ils effets ? » pour plus détails.
Le serveur stocker les droits dans des tables de droits, situées dans la base mysql. Le serveur lit le contenu de ces tables en mémoire lorsqu'il démarre, et les relit dans différentes circonstances, détaillées dans Section 5.5.7, « Quand les modifications de privilèges prennent-ils effets ? ». Le contrôle d'accès se fait par rapport aux tables en mémoire.
Normalement, vous manipulez le contenu des tables indirectement, via les commandes GRANT et REVOKE pour configurer des comptes et des droits. See Section 13.5.1.3, « Syntaxe de GRANT et REVOKE ». La discussion de cette section décrit la structure des tables de droits, et comment elle interagit avec les clients.
Le serveur utilise les tables user, db et host dans la base mysql durant les deux étapes. Les champs de cette table sont les suivants :
| Table name | utilisateur | base | hôte |
| Scope fields | Host |
Host |
Host |
User |
Db |
Db |
|
Password |
User |
||
| Privilege fields | Select_priv |
Select_priv |
Select_priv |
Insert_priv |
Insert_priv |
Insert_priv |
|
Update_priv |
Update_priv |
Update_priv |
|
Delete_priv |
Delete_priv |
Delete_priv |
|
Index_priv |
Index_priv |
Index_priv |
|
Alter_priv |
Alter_priv |
Alter_priv |
|
Create_priv |
Create_priv |
Create_priv |
|
Drop_priv |
Drop_priv |
Drop_priv |
|
Grant_priv |
Grant_priv |
Grant_priv |
|
References_priv |
References_priv |
References_priv |
|
Reload_priv |
|||
Shutdown_priv |
|||
Process_priv |
|||
File_priv |
|||
Show_db_priv |
|||
Super_priv |
|||
Create_tmp_table_priv |
Create_tmp_table_priv |
Create_tmp_table_priv |
|
Lock_tables_priv |
Lock_tables_priv |
Lock_tables_priv |
|
Execute_priv |
|||
Repl_slave_priv |
|||
Repl_client_priv |
|||
ssl_type |
|||
ssl_cypher |
|||
x509_issuer |
|||
x509_cubject |
|||
max_questions |
|||
max_updates |
|||
max_connections |
Lors de la seconde étape du contrôle d'accès (vérification de la requête), le serveur peut, suivant la requête, consulter aussi les tables tables_priv et columns_priv. Les champs de ces tables sont :
| Nom de la table | tables_priv | columns_priv |
| Champ | Host |
Host |
Db |
Db |
|
User |
User |
|
Table_name |
Table_name |
|
Column_name |
||
| Droit | Table_priv |
Column_priv |
Column_priv |
||
| Autre champ | Timestamp |
Timestamp |
Grantor |
Chaque table de droit contient des champs d'identification et des champs de droits.
-
Les champs d'identification déterminent quels utilisateurs correspondent à cette ligne dans la table. Par exemple, une ligne dans la table
useravec les valeurs dans les colonnesHostetUserde'thomas.loc.gov'et'bob'servira à identifier les connexions qui sont faites par l'utilisateurbobdepuis l'hôtethomas.loc.gov. De même, une ligne dans la tabledbavec les valeurs des colonnesHost,UseretDbde'thomas.loc.gov','bob'et'reports'sera utilisée lorsque l'utilisateurbobse connecte depuis l'hôtethomas.loc.govpour accéder à la basereports. Les tablestables_privetcolumns_privcontiennent en plus des champs indiquant les tables et combinaisons tables et colonnes auxquelles les lignes s'appliquent. -
Les champs de droits indiquent si le droit est donné, c'est à dire si l'opération indiquée peut être exécuté. Le serveur combine les informations dans différentes tables pour former une description complète de l'utilisateur. Les règles utilisées sont décrites dans Section 5.5.6, « Contrôle d'accès, étape 2 : Vérification de la requête ».
Les champs d'identification sont des chaînes, déclarées comme suit. La valeur par défaut de chacun des champs est la chaîne vide.
| Nom de la colonne | Type |
Host |
CHAR(60) |
User |
CHAR(16) |
Password |
CHAR(16) |
Db |
CHAR(64) |
Table_name |
CHAR(60) |
Column_name |
CHAR(60) |
Avant MySQL 3.23, la colonne Db valait CHAR(32) dans certaines tables, et CHAR(60) dans d'autres.
Pour vérifier les accès, la comparaison sur les valeurs de la colonne Host sont sensibles à la casse. User, Password, Db et Table_name sont insensibles. Les valeurs de Column_name sont insensibles depuis MySQL 3.22.12.
Dans les tables user, db et host, tous les champs de droits sont déclarés avec le type ENUM('N','Y') : il peuvent prendre tous les valeurs de 'N' (non) ou 'Y' (oui, YES), et la valeur par défaut est 'N'.
Dans les tables tables_priv et columns_priv, les champs de droits sont déclarés comme des champs de type SET :
| Nom de la table | Nom du champs | Valeurs possibles |
tables_priv |
Table_priv |
'Select', 'Insert', 'Update', 'Delete', 'Create', 'Drop', 'Grant', 'References', 'Index', 'Alter' |
tables_priv |
Column_priv |
'Select', 'Insert', 'Update', 'References' |
columns_priv |
Column_priv |
'Select', 'Insert', 'Update', 'References' |
En bref, le serveur utilise les tables de droits comme ceci :
-
La table
userdétermine si le serveur accepte ou rejette la connexion. Pour les connexions acceptées, tous les privilèges donnés dans la tableuserindiquent des privilèges globaux. Ces droits d'appliquent à toutes les bases du serveur. -
Les champs d'identification de la table
dbdéterminent quels utilisateurs peuvent accéder à quelles bases, depuis quel hôte. Les champs de droits indiquent alors les opérations permises. Les droits s'appliquent alors à toutes les bases sur le serveur. -
La table
hostest utilisée comme extension de la tabledblorsque vous voulez qu'une ligne de la tabledbs'applique à plusieurs hôtes. Par exemple, si vous voulez qu'un utilisateur soit capable d'utiliser une base depuis plusieurs hôtes dans votre réseau, laissez la colonneHostvide dans la tabledb, Ce mécanisme est décrit en détails dans Section 5.5.6, « Contrôle d'accès, étape 2 : Vérification de la requête ». -
Les tables
tables_privetcolumns_privsont similaires à la tabledb, mais sont plus atomiques : elle s'appliquent au niveau des tables et des colonnes, plutôt qu'au niveau des bases.
Notez que les droits d'administration tels que (RELOAD, SHUTDOWN, etc...) ne sont spécifiés que dans la table user. En effet, ces opérations sont des opérations au niveau serveur, et ne sont pas liées à une base de données, ce qui fait qu'il n'y a pas de raison de les lier avec les autres tables. En fait user doit être consulté pour déterminer les autorisations d'administration.
Le droit de FILE est spécifié par la table user. Ce n'est pas un droit d'administration, mais votre capacité à lire ou écrire des fichiers sur le serveur hôte et dépendant de la base à laquelle vous accédez.
Le serveur mysqld lit le contenu des tables de droits une fois, au démarrage. Lorsqu'il y a des modifications dans les tables, elles prennent effet tel qu'indiqué dans Section 5.5.7, « Quand les modifications de privilèges prennent-ils effets ? ».
Lorsque vous modifiez le contenu des tables de droits, c'est une bonne idée que de s'assurer que vous avez bien configuré les droits qui vous intéressent. Un moyen de vérifier les droits pour un compte est d'utiliser la commande SHOW GRANTS. Par exemple, pour déterminer les droits qui sont donnés à un compte avec les valeurs Host et User de pc84.example.com et bob, utilisez cette commande :
mysql> SHOW GRANTS FOR 'bob'@'pc84.example.com';
Un outil de diagnostique pratique est le script mysqlaccess, que Yves Carlier a fourni à la distribution MySQL. Appelez mysqlaccess avec l'option the --help pour comprendre comment il fonctionne. Notez que mysqlaccess ne vérifie les accès que pour les tables user, db et host. Il n'utilise pas les tables de droit de niveau table ou colonne.
Pour plus d'aide au diagnostique pour les problèmes de droits, voyez la section Section 5.5.8, « Causes des erreurs Access denied ». Pour des conseils généraux sur la sécurité, voyez la section Section 5.4, « Sécurité générale du serveur ».
Les droits des utilisateurs sont stockés dans les tables user, db, host, tables_priv et columns_priv de la base mysql (c'est-à-dire, la base nommée mysql). Le serveur MySQL lit ces tables au démarrage, et dans les circonstances indiquées dans la section Section 5.5.7, « Quand les modifications de privilèges prennent-ils effets ? ».
Les noms utilisés dans ce manuel font référence aux droits fournis par MySQL version 4.0.2, tel que présentés dans la table ci-dessous, avec le nom de la colonne associée au droit, dans la table de droits, et dans le contexte d'application. Plus d'informations sur la signification de chaque droit sont disponibles à Section 13.5.1.3, « Syntaxe de GRANT et REVOKE ».
| Droit | Colonne | Contexte |
ALTER |
Alter_priv |
tables |
DELETE |
Delete_priv |
tables |
INDEX |
Index_priv |
tables |
INSERT |
Insert_priv |
tables |
SELECT |
Select_priv |
tables |
UPDATE |
Update_priv |
tables |
CREATE |
Create_priv |
bases de données, tables ou index |
DROP |
Drop_priv |
bases de données ou tables |
GRANT |
Grant_priv |
bases de données ou tables |
REFERENCES |
References_priv |
bases de données ou tables |
CREATE TEMPORARY TABLES |
Create_tmp_table_priv |
administration du serveur |
EXECUTE |
Execute_priv |
administration du serveur |
FILE |
File_priv |
accès aux fichiers du serveur |
LOCK TABLES |
Lock_tables_priv |
administration du serveur |
PROCESS |
Process_priv |
administration du serveur |
RELOAD |
Reload_priv |
administration du serveur |
REPLICATION CLIENT |
Repl_client_priv |
administration du serveur |
REPLICATION SLAVE |
Repl_slave_priv |
administration du serveur |
SHOW DATABASES |
Show_db_priv |
administration du serveur |
SHUTDOWN |
Shutdown_priv |
administration du serveur |
SUPER |
Super_priv |
administration du serveur |
Les droits de SELECT, INSERT, UPDATE et DELETE vous permettent de faire des opérations sur les lignes qui existent, dans une table existante d'une base.
La commande SELECT requiert le droit de SELECT uniquement si des lignes sont lues dans une une table. Vous pouvez exéctuer une commande SELECT même sans aucun droit d'accès à une base de données dans le serveur. Par exemple, vous pourriez utiliser le client mysql comme une simple calculatrice :
mysql>SELECT 1+1;mysql>SELECT PI()*2;
Le droit de INDEX vous donne le droit de créer et détruire des index de table.
Le droit de ALTER vous donne le droit de modifier une table avec la commande ALTER TABLE.
Les droits de CREATE et DROP vous permettent de créer de nouvelles tables et bases de données, et de les supprimer.
Notez que si vous donnez le droit de DROP pour la base de données mysql à un utilisateur, cet utilisateur pourra détruire la base qui contient les droits d'accès du serveur !
Le droit de GRANT vous permet de donner les droits que vous possédez à d'autres utilisateurs.
Le droit de FILE vous donne la possibilité de lire et écrire des fichiers sur le serveur avec les commandes LOAD DATA INFILE et SELECT ... INTO OUTFILE. Tout utilisateur qui possède ce droit peut donc lire ou écrire dans n'importe quel fichier à l'intérieur duquel le serveur MySQL peut lire ou écrire.
Les autres droits sont utilisés pour les opérations administratives qui sont exécutées par l'utilitaire mysqladmin. La table ci-dessous montre quelle commande est associée à mysqladmin avec un de ces droits :
| Droit | Commande autorisée |
RELOAD |
reload, refresh, flush-privileges, flush-hosts, flush-logs et flush-tables |
SHUTDOWN |
shutdown |
PROCESS |
processlist |
SUPER |
kill |
La commande reload indique au serveur de relire les tables de droits. La commande refresh vide les tables de la mémoire, écrit les données et ferme le fichier de log. flush-privileges est un synonyme de reload. Les autres commandes flush-* effectuent des fonctions similaires à la commande refresh mais sont plus limitées dans leur application, et sont préférables dans certains contextes. Par exemple, si vous souhaitez simplement vider les tampons dans le fichier de log, utilisez flush-logs, qui est un meilleur choix que refresh.
La commande shutdown éteint le serveur.
La commande processlist affiche les informations sur les threads qui s'exécutent sur le serveur. La commande kill termine un des threads du serveur. Vous pouvez toujours afficher et terminer vos propres threads, mais vous aurez besoin des droits de PROCESS pour afficher les threads, et le droit de SUPER pour terminer ceux qui ont été démarrés par d'autres utilisateurs. See Section 13.5.4.3, « Syntaxe de KILL ».
C'est une bonne idée en général, de ne donner les droits de Grant qu'aux utilisateurs qui en ont besoin, et vous devriez être particulièrement vigilant pour donner certains droits :
-
Le droit de
GRANTpermet aux utilisateurs de donner leurs droits à d'autres utilisateurs. Deux utilisateurs avec des droits différents et celui deGRANTpourront combiner leurs droits respectifs pour gagner un autre niveau d'utilisation du serveur. -
Le droit de
ALTERpeut être utilisé pour tromper le système en renommant les tables. -
Le droit de
FILEpeut servir à lire des fichiers accessibles à tous sur le serveur, et les placer dans une base de données. Le contenu pourra alors être lu et manipulé avecSELECT. Cela inclus le contenu de toutes les bases actuellement hébergées sur le serveur ! -
Le droit de
SHUTDOWNpeut conduire au dénis de service, en arrêtant le serveur. -
Le droit de
PROCESSpermet de voir en texte clair les commandes qui s'exécutent actuellement, et notamment les changements de mot de passe. -
Le droit de
SUPERpeut être utilisé pour terminer les connexions ou modifier le mode opératoire du serveur. -
Les droits sur la base de données
mysqlpeuvent être utilisés pour changer des mots de passe ou des droits dans la table des droits (Les mots de passe sont stockés chiffrés, ce qui évite que les intrus ne les lisent). S'ils accèdent à un mot de passe dans la tablemysql.user, ils pourront l'utiliser pour se connecter au serveur avec cet utilisateur (avec des droits suffisants, le même utilisateur pourra alors remplacer un mot de passe par un autre).
Il y a des choses qui ne sont pas possibles avec le système de droits de MySQL :
-
Vous ne pouvez pas explicitement interdire l'accès à un utilisateur spécifique. C'est à dire, vous ne pouvez pas explicitement décrire un utilisateur et lui refuser la connexion.
-
Vous ne pouvez pas spécifier qu'un utilisateur a les droits de créer et de supprimer des tables dans une base, mais qu'il n'a pas les droits pour créer et supprimer cette base.
Les clients MySQL requièrent généralement que vous spécifiez les paramètres de connexion pour vous connecter au serveur MySQL :
-
l'hôte que vous voulez utiliser
-
votre nom d'utilisateur
-
votre mot de passe
Par exemple, le client mysql peut être démarré comme ceci :
shell> mysql [-h nom_d_hote] [-u nom_d_utilisateur] [-pvotre_mot_de_passe]
Les formes alternatives des options -h, -u et -p sont --host=host_name, --user=user_name et --password=your_pass. Notez qu'il n'y a aucun espace entre l'option -p ou --password= et le mot de passe qui le suit.
Si vous utilisez les options -p et --password mais que vous ne spécifiez pas de mot de passe, le client vous le demandera interactivement. Le mot de passe ne sera alors pas affiché. C'est la méthode la plus sécuritaire. Sinon, n'importe quel utilisateur du système pourra voir le mot de passe de la ligne de commande en exécutant une commande telle que ps auxww. See Section 5.6.6, « Garder vos mots de passe en lieu sûr ».
mysql utilise des valeurs par défaut pour chacun des paramètres qui manquent en ligne de commande :
-
Le nom d'hôte par défaut est
localhost. -
Le nom d'utilisateur par défaut est votre nom d'utilisateur de système Unix.
-
Aucun mot de passe n'est transmis si
-pmanque.
Par exemple, pour un utilisateur Unix joe, les commandes suivantes sont équivalentes :
shell>mysql -h localhost -u joeshell>mysql -h localhostshell>mysql -u joeshell>mysql
Les autres clients MySQL se comportent de manière similaire.
Sous Unix, vous pouvez spécifier différentes valeurs par défaut qui seront utilisées lorsque vous établirez la connexion, de manière à ce que vous n'ayez pas à entrer ces informations en ligne de commande lorsque vous invoquez un programme client. Cela peut se faire de plusieurs fa¸ons :
-
Vous pouvez spécifier les informations de connexion dans la section
[client]du fichier de configuration.my.cnfde votre dossier personnel. La section qui vous intéresse ressemble à ceci :[client] host=nom_d_hote user=nom_d'utilisateur password=votre_mot_de_passe
Les fichiers d'options sont présentés dans la section Section 4.3.2, « Fichier d'options
my.cnf». -
Vous pouvez spécifier les paramètres de connexion avec les variables d'environnement. L'hôte peut être spécifié à
mysqlavec la variableMYSQL_HOST. L'utilisateur MySQL peut être spécifié avec la variableUSER(uniquement pour Windows). Le mot de passe peut être spécifié avecMYSQL_PWD: mais ceci est peu sécuritaire voyez Section 5.6.6, « Garder vos mots de passe en lieu sûr ». Voyez aussi la prochaine section Annexe E, Variables d'environnement.
Lorsque vous tentez de vous connecter au serveur MySQL, le serveur accepte ou rejette la connexion en fonction de votre identité et du mot de passe que vous fournissez. Si le mot de passe ne correspond pas à celui qui est en base, le serveur vous interdit complètement l'accès. Sinon, le serveur accepte votre connexion et passe à l'étape 2, et la gestion de commandes.
Votre identité est basée sur trois informations :
-
L'hôte depuis lequel vous vous connectez
-
Votre nom d'utilisateur MySQL
La vérification d'identité est réalisée avec les trois colonnes de la table user (Host, User et Password). Le serveur accepte la connexion uniquement si une entrée dans la table user correspond à votre hôte, et que vous fournissez le mot de passe qui correspond.
Les valeurs de la table user peuvent être paramétrées comme ceci :
-
Une valeur de la colonne
Hostpeut être un nom d'hôte, une adresse IP numérique, ou encore'localhost', qui représente l'hôte local. -
Vous pouvez utiliser les caractères jokers ‘
%’ et ‘_’ dans le champHost. Ces caractères ont la même valeur que pour les opérations de recherches avec l'opérateurLIKE. Par exemple, une valeurHostde'%'remplace n'importe quel nom d'hôte, alors que la valeur'%.mysql.com'représente tous les hôtes du domainemysql.com. -
Depuis MySQL version 3.23, les valeurs de
Hostspécifiées sous la forme d'IP numériques peuvent être complétées avec le masque de réseau qui indique combien de bits d'adresse sont utilisés. Par exemple :mysql>
GRANT ALL PRIVILEGES ON db.*->TO david@'192.58.197.0/255.255.255.0';Cela permet à toute personne se connectant depuis une adresse IP qui satisfait la contrainte suivante :
user_ip & netmask = host_ip
C'est à dire, pour la commande
GRANTci-dessus :client_ip & 255.255.255.0 = 192.58.197.0
Les adresses IP qui satisfont cette condition et qui peuvent se connecter au serveur MySQL sont dans l'intervalle
192.58.197.0à192.58.197.255. -
Une valeur vide pour la colonne
Hostindique que les droits doivent être gérés avec les entrées de la tablehostqui correspond à l'hôte se connectant. Vous trouverez plus d'informations à ce sujet dans le chapitre Section 5.5.6, « Contrôle d'accès, étape 2 : Vérification de la requête ».Une valeur vide dans la colonne
Hostdes autres tables de droits revient à'%'.
Comme vous pouvez utiliser des jokers dans les valeurs IP de Host (par exemple, '144.155.166.%' pour tous les hôtes d'un sous-réseau), il est possible d'exploiter cette possibilité en appelant un hôte 144.155.166.ailleurs.com. Pour contrer ce type d'attaque, MySQL bloque les noms de domaines qui commence par des chiffres et des points. Par conséquent, si vous avez un hôte nommé 1.2.foo.com, il ne sera jamais accepté par la colonne Host des tables de droits. Un caractère joker d'adresse IP peut remplacer uniquement des nombres d'IP, et pas un nom d'hôte.
Dans la colonne User, les caractères joker ne sont pas autorisés, mais vous pouvez laisser cette valeur vide, qui acceptera tous les noms. Si la table user contient une connexion avec un nom d'utilisateur vide, l'utilisateur est considéré comme anonyme. Cela signifie que le nom d'utilisateur vide est utilisé pour les prochaines vérifications d'accès pour la durée de la connexion.
Le champ Password peut être vide. Cela ne signifie pas que n'importe quel mot de passe est valable, mais que l'utilisateur peut se connecter sans fournir de mot de passe.
Les valeurs non vides du champ Password représentent des valeurs du mot de passe chiffrées. MySQL ne stocke pas les mots de passe en clair, à la vue de tous. Au contraire, le mot de passe fourni pas l'utilisateur qui tente de se connecter est chiffré (avec la fonction PASSWORD()). Le mot de passe ainsi chiffré est alors utilisé entre le client et le serveur pour vérifier s'il est valable. Cela évite que des mots de passe en clair circulent entre le client et le serveur, sur la connexion. Notez que du point de vue de MySQL, le mot de passe chiffré est le vrai mot de passe, ce qui fait que vous ne devez en aucun cas le donner à un tiers. En particulier, ne donnez pas accès en lecture aux utilisateurs normaux aux tables d'administration dans la base mysql! A partir de sa version 4.1, MySQL utilise un mécanisme différent pour les logins, mots de passes qui est sécurisé même si les paquets TCP/IP sont sniffés et/ou que la base de données mysql est capturée.
Depuis la version 4.1, MySQL emploie une identification forte qui protège mieux les mots de passe durant le processus de connexion. Cette méthode est sécuritaire, même si les paquets TCP/IP sont surveillés pour que la base de données mysql est capturée. Le chiffrement est présenté dans la section Section 5.5.9, « Hashage de mots de passe en MySQL 4.1 ».
Les exemples ci-dessous illustrent comment différentes variantes de Host et User dans la table user s'appliquent aux connexion entrantes :
Host value |
User value |
Connexions autorisées |
'thomas.loc.gov' |
'fred' |
fred, se connectant depuis thomas.loc.gov |
'thomas.loc.gov' |
'' |
N'importe quel utilisateur, se connectant depuis thomas.loc.gov |
'%' |
'fred' |
fred, se connectant depuis n'importe quel hôte |
'%' |
'' |
N'importe quel utilisateur, se connectant depuis n'importe quel hôte |
'%.loc.gov' |
'fred' |
fred, se connectant depuis n'importe quel hôte dans le domaine loc.gov |
'x.y.%' |
'fred' |
fred, se connectant depuis x.y.net, x.y.com,x.y.edu, etc. (Ceci n'est probablement pas très utilisé) |
'144.155.166.177' |
'fred' |
fred, se connectant depuis l'hôte d'IP 144.155.166.177 |
'144.155.166.%' |
'fred' |
fred, se connectant depuis un hôte d'IP dans la classe C 144.155.166 |
'144.155.166.0/255.255.255.0' |
'fred' |
Identique à l'exemple précédent |
Comme vous pouvez utiliser des caractères jokers dans les adresses IP de la colonne Host (par exemple, '144.155.166.%' pour identifier tout un sous-réseau), il est possible d'exploiter cette fonctionnalité en nommant un hôte 144.155.166.kekpart.com. Pour contrer de telles tentatives, MySQL interdit les caractères jokers avec les noms d'hôtes qui commencent par des chiffres ou des points. Par exemple, si vous avez un nom d'hôte tel que 1.2.foo.com, il ne sera jamais trouvé dans la colonne Host des tables de droits. Seule une adresse IP numérique peut être comparée avec un masque à caractère joker.
Une connexion entrante peut être identifiée par plusieurs entrées dans la table user. MySQL résout ce problème comme ceci :
-
Lorsque le serveur lit la table
useren mémoire, il trie les lignes. -
Lorsqu'un client tente de se connecter, le serveur lit les lignes dans l'ordre.
-
Le serveur utilise la première ligne qui correspond au nom du client et à son nom d'utilisateur.
Supposons que votre table user ressemble à ceci :
+-----------+----------+- | Host | User | ... +-----------+----------+- | % | root | ... | % | jeffrey | ... | localhost | root | ... | localhost | | ... +-----------+----------+-
Lorsque le serveur lit cette table, il ordonne les lignes depuis les valeurs les plus spécialisées de la colonne Host jusqu'aux plus générales ('%' dans la colonne Host signifie ``tous les hôtes'' et elle est la moins spécifique). Les entrées identiques dans la colonne Host sont ordonnées en fonction de la spécificité des valeurs de la colonne User (une entrée vide dans la colonne User signifie ``n'importe quel utilisateur'' et est spécifique). Le résultat de ce tri donne quelque chose comme ceci :
+-----------+----------+- | Host | User | ... +-----------+----------+- | localhost | root | ... | localhost | | ... | % | jeffrey | ... | % | root | ... +-----------+----------+-
Lorsqu'une connexion est en cours de mise en place, le serveur regarde dans cette liste, et utilisera la première entrée trouvée. Pour une connexion depuis l'hôte localhost avec le nom d'utilisateur jeffrey, les entrées 'localhost' dans la colonne Host sont trouvées en premier. Parmi celles-la, la ligne avec un utilisateur vide satisfait les deux contraintes sur le nom et l'hôte. '%'/'jeffrey' pourrait avoir fonctionné, mais comme ce n'est pas le premier rencontré, il n'est pas utilisé.
Voici un autre exemple. Supposons que la table user ressemble à ceci :
+----------------+----------+- | Host | User | ... +----------------+----------+- | % | jeffrey | ... | thomas.loc.gov | | ... +----------------+----------+-
La table triée ressemble à ceci :
+----------------+----------+- | Host | User | ... +----------------+----------+- | thomas.loc.gov | | ... | % | jeffrey | ... +----------------+----------+-
Une connexion depuis l'hôte thomas.loc.gov avec jeffrey satisfait les conditions de la première ligne, tandis qu'une connexion depuis whitehouse.gov avec jeffrey satisfait la seconde ligne.
Une erreur commune est de penser que pour un utilisateur donné, toutes les entrées qui utilisent explicitement ce nom seront utilisées en premier lorsque la connexion est en cours d'établissement. Ceci est tout simplement faux. L'exemple précédent illustre cette situation, car la connexion depuis l'hôte thomas.loc.gov avec jeffrey est la première ligne qui est trouvée, alors que la ligne contenant 'jeffrey' dans la colonne User est ignorée, car il n'y a pas de nom d'utilisateur.
Si vous arrivez à vous connecter au serveur, mais que les droits ne sont pas ce que vous attendez, vous vous êtes probablement identifié avec un autre compte. Pour savoir quel compte le serveur utilise lors de votre identification, utilisez la fonction CURRENT_USER(). Elle retourne la valeur au format user_name@host_name qui indique les valeurs des colonne User et Host de la table user qui vous est affectée. Supposons que jeffrey se connecte et utilise la requête suivante :
mysql> SELECT CURRENT_USER();
+----------------+
| CURRENT_USER() |
+----------------+
| @localhost |
+----------------+
Le résultat affiché ci-dessus indique que la ligne de la table user est l'utilisateur User vide. En d'autres termes, le serveur traite jeffrey comme un utilisateur anonyme.
La fonction CURRENT_USER() est disponible depuis MySQL 4.0.6. See Section 12.8.3, « Fonctions d'informations ». Une autre piste à explorer : imprimez le contenu de la table user et triez la manuellement pour voir quelle est la première ligne qui est utilisée.
Une fois que vous avez établi la connexion, le serveur passe à l'étape 2. Pour chaque requête qui est fournie avec la connexion, le serveur vérifie si vous avez les droits suffisants pour exécuter une commande, en fonction du type de commande. C'est à ce moment que les colonnes de droits des tables d'administration entrent en scène. Ces droits peuvent provenir de la table user, db, host, tables_priv ou columns_priv. Les tables d'administration sont manipulées avec les commandes GRANT et REVOKE. (Vous pouvez aussi vous reporter à la section Section 5.5.2, « Comment fonctionne le système de droits » qui liste les champs présents dans chaque table d'administration).
La table d'administration user donne les droits aux utilisateurs au niveau global, c'est à dire que ces droits s'appliquent quelle que soit la base de données courante. Par exemple, si la table user vous donne le droit d'effacement ,DELETE, vous pouvez effacer des données dans n'importe quelle base de ce serveur. En d'autres termes, les droits stockés dans la table user sont des droits de super utilisateur. Il est recommandé de ne donner des droits via la table user uniquement aux super utilisateurs, ou aux administrateurs de bases. Pour les autres utilisateurs, il vaut mieux laisser les droits dans la table user à 'N' et donner des droits au niveau des bases uniquement, avec les tables db et host.
Les tables db et host donnent des droits au niveau des bases. Les droits peuvent être spécifiés dans ces tables comme ceci :
-
Les caractères ‘
%’ et ‘_’ peuvent être utilisés dans la colonneHostetDbdes deux tables. Si vous souhaitez utiliser le caractère ‘_’ comme nom de base, utiliser la séquence ‘\_’ dans la commandeGRANT. -
La valeur
'%'dans la colonneHostde la tabledbsignifie ``tous les hôtes''. Une valeur vide dans la colonneHostde la tabledbsignifie ``consulte la tablehostpour plus de détails''. -
La valeur
'%'ou vide dans la colonneHostde la tablehostsignifie ``tous les hôtes''. -
La valeur
'%'ou vide dans la colonneDbdes deux tables signifie ``toutes les bases de données''. -
Un utilisateur vide dans la colonne
Userde l'une des deux tables identifie l'utilisateur anonyme.
Les tables db et host sont lues et triées par le serveur au démarrage (en même temps que la table user. La table db est triée suivant les valeurs des colonnes Host, Db et User, et la table host est triée en fonction des valeurs des colonnes Host et Db. Comme pour la table user, le tri place les entrées les plus spécifiques au début, et les plus générales à la fin. Lorsque le serveur recherche une ligne, il utilise la première qu'il trouve.
Les tables tables_priv et columns_priv spécifient les droits au niveau des tables et des colonnes. Les valeurs des droits dans ces tables peuvent être spécifiés avec les caractères spéciaux suivants :
-
Les caractères ‘
%’ et ‘_’ peuvent être utilisés dans la colonneHostdes deux tables. -
La valeur
'%'dans la colonneHostdes deux tables signifie ``tous les hôtes''. -
Les colonnes
Db,Table_nameetColumn_namene peuvent pas contenir de valeur vide ou de caractères jokers, dans les deux tables.
Les tables tables_priv et columns_priv sont triées en fonction des colonnes Host, Db et User. Ce tri est similaire à celui du tri de la table db, même si le tri est bien plus simple, car seul le champ Host peut contenir des caractères jokers.
Le processus de vérification est décrit ci-dessous. Si vous êtes familier avec le code source de contrôle d'accès, vous noterez que la description diffère légèrement de l'algorithme utilisé. La description est équivalente à ce que fait en réalité le code. La différence permet une meilleure approche pédagogique.
Pour les requêtes d'administration comme SHUTDOWN, RELOAD, etc., le serveur vérifie uniquement l'entrée dans la table user, car c'est la seule table qui spécifie des droits d'administration. Le droit est donné si la ligne utilisée dans la connexion courante dans la table user donne le droit, et sinon, ce droit est interdit. Par exemple, si vous souhaitez exécuter la commande mysqladmin shutdown mais que votre ligne dans la table user ne vous en donne pas le droit (SHUTDOWN), vous n'aurez pas le droit sans même vérifier les tables db ou host : ces tables ne contiennent pas de colonne Shutdown_priv, ce qui évite qu'on en ait besoin.
Pour les requêtes exploitant une base de données, comme INSERT, UPDATE, etc., le serveur vérifie d'abord les droits globaux de l'utilisateur (droits de super utilisateur), en regardant dans la table user. Si la ligne utilisée dans cette table donne droit à cette opération, le droit est donné. Si les droits globaux dans user sont insuffisants, le serveur déterminera les droits spécifiques à la base avec les tables db et host :
-
Le serveur recherche dans la table
dbdes informations en se basant sur les colonnesHost,DbetUser. Les champsHostetUsersont comparés avec les valeurs de l'hôte et de l'utilisateur qui sont connectés. Le champDbest comparé avec le nom de la base de données que l'utilisateur souhaite utiliser. S'il n'existe pas de ligne qui corresponde àHostetUser, l'accès est interdit. -
S'il existe une ligne dans la table
dbet que la valeur de la colonneHostn'est pas vide, cette ligne définit les droits de l'utilisateur. -
Si dans la ligne de la table
db, la colonneHostest vide, cela signifie que la tablehostspécifie quels hôtes doivent être autorisés dans la base. Dans ce cas, une autre recherche est faite dans la tablehostpour trouver une ligne avec les colonnesHostetDb. Si aucune ligne de la tablehostn'est trouvée, l'accès est interdit. S'il y a une ligne, les droits de l'utilisateur sont calculés comme l'intersection (NON PAS l'union !) des droits dans les tablesdbethost, c'est-à-dire que les droits doivent être marqués'Y'dans les deux tables (de cette fa¸on, vous pouvez donner des droits généraux dans la tabledbpuis les restreindre sélectivement en fonction des hôtes, en utilisant la tablehost.
Après avoir déterminé les droits spécifiques à l'utilisateur pour une base grâce aux tables db et host, le serveur les ajoute aux droits globaux, donnés par la table user. Si le résultat autorise la commande demandée, l'accès est donné. Sinon, le serveur vérifie les droits au niveau de la table et de la colonne dans les tables tables_priv et columns_priv, et les ajoute aux droits déjà acquis. Les droits sont alors donnés ou révoqués en fonction de ces résultats.
Exprimée en termes booléens, la description précédente du calcul des droits peut être résumé comme ceci :
droits globaux OR (droits de base AND droits d'hôte) OR droits de table OR droits de colonne
Il n'est peut-être pas évident pourquoi, si les droits globaux issus de la table user sont initialement insuffisants pour l'opération demandée, le serveur ajoute ces droits à ceux de base, table ou colonne ? La raison est que la requête peut demander l'application de plusieurs droits. Par exemple, si vous exécutez une commande INSERT ... SELECT, vous aurez besoin des droits de INSERT et de SELECT. Vos droits peuvent être tels que la table user donne un droit, mais que la table db en donne un autre. Dans ce cas, vous aurez les droits nécessaires pour faire une opération, mais le serveur ne peut le déduire d'une seule table : les droits de plusieurs tables doivent être combinés pour arriver à la bonne conclusion.
La table host sert à gérer une liste d'hôtes reconnus et sécuritaires.
Chez TcX, la table host contient une liste de toutes les machines du réseau local. Ces machines re¸oivent tous les droits.
Vous pouvez aussi utiliser la table host pour spécifier les hôtes qui ne sont pas sécuritaires. Supposons que la machine public.votre.domaine t est placée dans une zone publique que vous considérez comme peu sûre. Vous pouvez autoriser l'accès de toutes les machines, hormis celle-ci, grâce à la table host configurée comme ceci :
+--------------------+----+- | Host | Db | ... +--------------------+----+- | public.your.domain | % | ... (tous les droits à 'N') | %.your.domain | % | ... (tous les droits à 'Y') +--------------------+----+-
Naturellement, vous devriez toujours tester vos requêtes dans la table de droits, en utilisant l'utilitaire mysqlaccess pour vous assurer que vous disposez des droits nécessaires pour réaliser cette opération.
Lorsque mysqld est lancé, toutes les tables de droits sont lues, et sont utilisées.
Les modifications aux tables de droits que vous faites avec GRANT, REVOKE et SET PASSWORD sont immédiatement prises en compte par le serveur.
Si vous modifiez les tables de droits manuellement (avec INSERT, UPDATE, etc...), vous devez exécuter la commande FLUSH PRIVILEGES ou la commande mysqladmin flush-privileges, ou encore mysqladmin reload pour dire au serveur de relire les tables de droits. Sinon, vos modifications n'auront aucun effet jusqu'au redémarrge du serveur. Si vous modifiez les tables de droits manuellement, mais que vous oubliez de recharger les droits, vous vous demanderez sûrement pourquoi vos modifications n'ont pas d'effet.
Lorsque le serveur remarque que les tables de droits ont été modifiées, les connexions existantes avec les clients sont modifiées comme ceci :
-
Les droits de table et colonnes prennent effet à la prochaine requête du client.
-
Les droits de bases prennent effet à la prochaine commande
USE nom_de_base. -
Les droits globaux et les modifications de droits prennent effets lors de la prochaine connexion.
Si vous rencontrez des erreurs Access denied quand vous essayez de vous connecter au serveur MySQL, la liste suivante indique quelques actions à entreprendre pour corriger le problème :
-
Assurez vous que le serveur fonctionne. S'il ne fonctionne pas, vous ne pourrez pas vous y connecter. Par exemple, si vous tentez de vous connecter au serveur, et que vous recevez un message comme celui-ci, c'est peut-être que le serveur ne fonctionne pas :
shell>
mysqlERROR 2003: Can't connect to MySQL server on 'host_name' (111) shell>mysqlERROR 2002: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (111)Il se peut aussi que le serveur fonctionne, mais que vous essayez de vous connecter en utilisant un port TCP/IP, un pipe nommé ou un fichier de socket Unix qui n'est pas celui que le serveur utilise. Pour corriger cela, lorsque vous utilisez un client, spécifiez l'option
--portpour indiquer le bon port, et l'option--socketpour indiquer le bon fichier de socket Unix ou le pipe nommé Windows. Pour connaître le port utilisé, et le chemin jusqu'à la socket, vous pouvez utiliser cette commande :shell>
netstat -l | grep mysql -
Les tables de droits doivent être correctement configurée pour que le serveur les utilise lors de l'identification. Les installations Windows qui utilisent une distribution binaire ou les installations binaires Unix
RPMinitialisent automatiquement la basemysqlcontenant les tables de droits. Pour les autres types d'installation, vous devez initialiser les tables de droits manuellement, avec le scriptmysql_install_db. Pour plus de détails, voyez Section 2.5.2, « Procédures de post-installation sous Unix ».Un moyen de déterminer si vous avez besoin d'initialiser les tables de droits est de regarder dans le dossier
mysqldans le dossier de données. Le dossier de données s'appelledataouvaret est situé dans le dossier d'installation de MySQL. Assurez vous que vous avez un fichier appeléuser.MYDdans le dossiermysql. Si vous ne le trouvez pas, exécutez le scriptmysql_install_db. Après exécution de ce script, et redémarrage du serveur, testez les premiers droits avec la commande :shell>
mysql -u root testLe serveur doit vous laisser vous connecter sans erreur.
-
Après une installation toute fraîche, vous devez vous connecter au serveur et créer les utilisateurs en réglant leurs permissions d'accès :
shell>
mysql -u root mysqlLe serveur devrait vous laisser vous connecter car l'utilisateur
rootde MySQL n'a pas de mot de passe initial. Ceci est aussi une faille de sécurité, et donc, vous devez choisir un mot de passe pour l'utilisateurrooten même tant que les autres utilisateurs MySQL. Pour des instructions sur la configuration des mots de passe initiaux, voyez la section Section 2.5.3, « Création des premiers droits MySQL ». -
Si vous avez mis à jour une version de MySQL avec une nouvelle versions, avez-vous utilisé le script
mysql_fix_privilege_tables? Si ce n'est pas le cas, faîtes-le. La structure des tables de droits change occasionnellement, lorsque de nouvelles fonctionnalités sont ajoutées : après une mise à jour, assurez-vous que vos tables ont la bonne structure. Pour des instructions, voyez Section 2.6.7, « Mise à jour des tables de droits ». -
Si un programme client re¸oit l'erreur suivante lorsqu'il essaie de se connecter, cela signifie que le serveur attend un mot de passe dans un nouveau format, alors que le client fournit un ancien format :
shell>
mysqlClient does not support authentication protocol requested by server; consider upgrading MySQL clientPour des informations sur comment traiter ce type de situations, voyez Section 5.5.9, « Hashage de mots de passe en MySQL 4.1 » et Section A.2.3, « Erreur
Client does not support authentication protocol». -
Si vous essayez de vous connecter en tant que
rootet que vous recevez l'erreur suivante, cela signifie que vous n'avez pas d'entrée dans la tableuseravec une valeur'root'dans la colonneUseret quemysqldne peut pas résoudre le nom d'hôte du client :Access denied for user: ''@'unknown' to database mysql
Dans ce cas, vous devez relancer le serveur avec l'option
--skip-grant-tables, et éditer votre fichier/etc/hostsou\windows\hostspour ajouter une ligne vous votre hôte. -
N'oubliez pas que les clients utilisent les paramètres de connexions placés dans les fichiers d'options ou les variables d'environnement. Si un client semble envoyer des paramètres de connexions invalides, lorsque vous n'en spécifiez aucun, vérifiez votre environnement, et les options appropriées. Par exemple, si vous recevez l'erreur
Access deniedavec un client utilisé sans option, assurez vous que vous n'avez pas spécifié un ancien mot de passe dans vos anciens fichiers d'options.Vous pouvez supprimer l'utilisation des fichiers d'options d'un client en utilisant l'option
--no-defaults. Par exemple :shell>
mysqladmin --no-defaults -u root versionLe fichier d'option que les clients utilisent sont listés dans la section Section 4.3.2, « Fichier d'options
my.cnf». Les variables d'environnement sont listées dans Annexe E, Variables d'environnement. -
Si vous obtenez une erreur qui ressemble à celle-ci :
shell>
mysqladmin -u root -pxxxx verAccess denied for user: 'root'@'localhost' (Using password: YES)Cela signifie que vous utilisez un mot de passe erroné.
Si l'erreur précédente survient lorsque vous n'avez pas spécifié de mot de passe, cela signifie que vous n'avez pas spécifié de mot de passe dans un fichier d'options. Essayez l'option
--no-defaultstelle décrit ci-dessus.Pour des informations sur les changements de mot de passe, voyez Section 5.6.5, « Configurer les mots de passe ».
Si vous avez oublié le mot de passe root, vous pouvez redémarrer
mysqldavec--skip-grant-tablespour changer le mot de passe. See Section A.4.1, « Comment réinitialiser un mot de passe Root oublié ». -
Si vous n'arrivez pas à faire fonctionner votre mot de passe, souvenez-vous que vous devez utiliser la fonction
PASSWORD()si vous le changez avec les commandesINSERT,UPDATE, ouSET PASSWORD. L'utilisation de la fonctionPASSWORD()n'est pas nécessaire si vous spécifiez le mot de passe en utilisant la commandeGRANT ... INDENTIFIED BYou la commandemysqladmin password. See Section 5.6.5, « Configurer les mots de passe ».mysql>
SET PASSWORD FOR 'abe'@'host_name' = 'eagle';A la place, utilisez cette commande :
mysql>
SET PASSWORD FOR 'abe'@'host_name' = PASSWORD('eagle');La fonction
PASSWORD()n'est pas nécessaire si vous spécifiez un mot de passe avec la commandeGRANTou la commande en lignemysqladmin password, qui utilisent automatiquementPASSWORD()pour chiffrer le mot de passe. -
localhostest un synonyme de votre nom d'hôte local, et est aussi l'hôte par défaut auquel le client essaye de se connecter si vous n'en spécifiez pas un explicitement. Toutefois, les connexions àlocalhostne fonctionnent pas si vous utilisez une version antérieure à la 3.23.27 qui utilise lesMIT-pthreads.Pour contourner ce problème sur de tels systèmes, vous devez utiliser l'option
--hostpour nommer l'hôte du serveur explicitement. Cela créera une connexion TCP/IP vers le serveurmysqld. Dans ce cas, vous devez avoir votre vrai nom d'hôte dans les entrées de la tableuserdu serveur hôte. (Cela est vrai même si vous utilisez un programme client sur la même machine que le serveur.) -
Si vous obtenez une erreur
Access deniedlorsque vous essayez de vous connecter à la base de données avecmysql -u nom_utilisateur nom_base, vous pouvez avoir un problème dans la tableuser. Vérifiez le en vous exécutantmysql -u root mysqlet entrant la commande SQL suivante :mysql>
SELECT * FROM user;Le résultat devrait comprendre une entrée avec les colonnes
HostetUsercorrespondante au nom d'hôte de votre ordinateur et votre nom d'utilisateur MySQL. -
Le message d'erreur
Access deniedvous dira en tant que qui vous essayez de vous identifier, l'hôte à partir duquel vous voulez le faire, et si vous utilisez ou pas un mot de passe. Normalement, vous devez avoir une entrée dans la tableuserqui correspondent au nom d'hôte et nom d'utilisateur donnés dans le message d'erreur. Par exemple, si vous obtenez une erreur qui contientUsing password: NO, cela signifie que vous avez essayé de vous connecter sans mot de passe. -
Si vous obtenez l'erreur suivante en essayant de vous connecter à partir d'un hôte différent de celui sur lequel est placé le serveur, c'est qu'il n'y a pas d'enregistrement dans la table
userqui correspond à cet hôte :Host ... is not allowed to connect to this MySQL server
Vous pouvez corriger ce problème en configurant un compte avec la combinaison hôte / nom d'utilisateur que vous utilisez lors de la connexion.
Si vous ne connaissez ni l'IP ni le nom d'hôte à partir duquel vous essayez de vous connecter, vous devez créer une entrée avec
'%'dans la colonneHostdans la tableuseret redémarrermysqldavec l'option--logsur la machine serveur. Après avoir essayé à nouveau de vous connecter à partir de la machine cliente, les informations contenues dans le log de MySQL vous apprendront comment vous vous êtes vraiment connectés. (Remplacez alors l'entrée de la tableusercontenant'%'avec le nom d'hôte qui apparaît dans le log. Sinon, vous aurez un système non-sécurisé.)Une autre raison pour cette erreur sous Linux est que vous utilisez une version binaire de MySQL qui est compilée avec une version de
glibcdifférente de celle que vous utilisez. Dans ce cas, vous devez soit mettre à jour votre système d'exploitation et sa bibliothèqueglibc, soit télécharger les sources de MySQL et les compiler vous-même. UnRPMde sources est normalement facile à compiler et installer, cela ne devrait donc pas vous poser de gros problèmes. -
Si vous obtenez une erreur où le nom d'hôte est absent ou que celui-ci est une adresse IP alors que vous avez bien entré le nom d'hôte :
shell>
mysqladmin -u root -pxxxx -h some-hostname verAccess denied for user: 'root@' (Using password: YES)Cela signifie que MySQL a rencontré des erreurs lors de la résolution de l'IP du nom d'hôte. Dans ce cas, vous pouvez exécuter
mysqladmin flush-hostspour vider le cache interne des DNS. See Section 7.5.6, « Comment MySQL utilise le DNS ».Les autres solutions sont :
-
Essayez de trouver le problème avec votre serveur DNS et corrigez le.
-
Spécifiez les IP à la place des noms d'hôtes dans les tables de droits de MySQL.
-
Ajoutez une ligne pour le nom de votre machine dans
/etc/hosts. -
Démarrez
mysqldavec--skip-name-resolve. -
Démarrez
mysqldavec--skip-host-cache. -
Sous Unix, si vous utilisez le serveur et le client sur la même machine, connectez vous à
localhost. Les connexions Unix àlocalhostutilisent une socket Unix plutôt que TCP/IP. -
Sous Windows, si vous exécutez le serveur et le client sur la même machine, et que le serveur supporte les pipes nommés, connectez vous à l'hôte
.(point). Les connexions à.utilisent les pipes nommés plutôt que TCP/IP.
-
-
Si
mysql -u root testfonctionne mais quemysql -h votre_hote -u root testprovoque une erreurAccess denied, il se peut que vous ayez entré de mauvaises informations pour votre nom d'hôte dans la tableuser. Un problème commun ici est que la valeurHostdans la tableuserspécifie un nom d'hôte non-qualifié, mais que vos routines système de résolution de noms retournent un nom de domaine pleinement qualifié (ou vice-versa). Par exemple, si vous avez une entrée avec l'hôte'tcx'dans la tableuser, mais que vos DNS disent à MySQL que votre nom d'hôte est'tcx.subnet.se', l'entrée ne fonctionnera pas. Essayez d'ajouter une entrée dans la tableuserqui contient votre adresse IP en tant que valeur de la colonneHost. (Une alternative est d'ajouter une entrée dans la tableuseravec une valeur deHostqui contient un caractère spécial, par exemple,'tcx.%'. Toutefois, l'utilisation des noms d'hôtes se terminant par ‘%’ est non-sécurisé et n'est pas recommandé !) -
Si
mysql -u utilisateur testfonctionne mais quemysql -u utilisateur autre_basene fonctionne pas, vous n'avez pas d'entrée pourautre_baselistée dans la tabledb. -
Si
mysql -u utilisateur nom_basefonctionne à partir du serveur, mais quemysql -h nom_hote -u utilisateur nom_basene fonctionne pas à partir d'une autre machine, cette machine n'est pas listée dans la tableuseroudb. -
Si vous n'arrivez pas à trouver pourquoi vous obtenez l'erreur
Access denied, effacez toutes les entrées de la tableuserdont la valeur du champHostcontiennent des caractères spéciaux (entrées contenant ‘%’ ou ‘_’). Une erreur commune est d'insérer une nouvelle entrée avecHost='%'etUser='un utilisateur', en pensant que cela vous permettra de spécifierlocalhostpour vous connecter à partir de la même machine. La raison pour laquelle cela ne fonctionnera pas est que les droits par défaut incluent une entrée avecHost='localhost'etUser=''. Puisque cette entrée possède une valeur deHostégale à'localhost', qui est plus spécifique que'%', elle est utilisée de préférence à la nouvelle entrée lors de la connexion à partir delocalhost! La procédure correcte est d'insérer une seconde entrée avecHost='localhost'etUser='un_utilisateur', ou de supprimer l'entrée avecHost='localhost'etUser=''. -
Si vous avez l'erreur suivante, vous avez peut-être un problème avec la table
dbouhost:Access to database denied
Si l'entrée sélectionnée dans la table
dbpossède un champHostvide, assurez-vous qu'il y a au moins une entrée correspondante dans la tablehostspécifiant les hôtes auxquels l'entrée dans la tabledbs'applique. -
Si vous obtenez l'erreur lors de l'utilisation des commandes SQL
SELECT ... INTO OUTFILEouLOAD DATA INFILE, votre entrée dans la tableuserne possède probablement pas les droits deFILE. -
Si vous apportez des modifications aux tables de droits directement (en utilisant une requête
INSERTouUPDATE) et que vos changements semblent ignorés, souvenez vous que vous devez exécuter une requêteFLUSH PRIVILEGESou la commandemysqladmin flush-privilegespour demander au serveur de lire à nouveau les tables de droits. Sinon, vos changements ne seront pris en compte qu'au prochain démarrage du serveur. Souvenez-vous qu'après avoir choisi le mot de passerootavec une commandeUPDATE, vous n'aurez pas à le spécifier avant de recharger les privilèges, car le serveur ne sait pas que vous l'avez modifié ! -
Si vos droits changent en milieu de session, c'est peut être qu'un administrateur MySQL a changé les droits. En rechargeant les tables de droits, il a modifié aussi les connexions existantes, comme indiqué dans Section 5.5.7, « Quand les modifications de privilèges prennent-ils effets ? ».
-
Si vous avez des problèmes d'accès avec un programme Perl, PHP, Python, ou ODBC, essayez de vous connecter au serveur avec
mysql -u utilisateur nom_baseoumysql -u utilisateur -pvotre_passe nom_base. Si vous pouvez vous connecter en utilisant le clientmysql, c'est que le problème vient de votre programme et non des droits MySQL. (Notez qu'il n'y a pas d'espace entre-pet le mot de passe; vous pouvez aussi utiliser la syntaxe--password=votre_passepour spécifier le mot de passe. Si vous utilisez l'option-ptoute seule, MySQL vous demandera le mot de passe.) -
Pour les tests, démarrez le démon
mysqldavec l'option--skip-grant-tables. Vous pourrez alors changer les tables de droits MySQL puis utiliser le scriptmysqlaccesspour vérifier si vos changements ont l'effet désiré. Lorsque vous êtes satisfait de vos modifications, exécutezmysqladmin flush-privilegespour dire au serveurmysqldde commencer à utiliser les nouvelles tables de droits. Recharger les tables de droits écrase l'option--skip-grant-tables. Cela vous permet de dire au serveur de commencer à prendre en considération les droits sans avoir à le couper et le redémarrer. -
Si rien ne fonctionne, démarrez le démon
mysqldavec l'option de débogage (par exemple,--debug=d,general,query). Cela affichera l'hôte et les informations de l'utilisateur pour chaque tentative de connexion. Les informations à propos de chaque commande exécutée seront aussi affichées. See Section D.1.2, « Créer un fichier de tra¸age ». -
Si vous avez d'autres problèmes avec les tables de droits de MySQL et que vous sentez que vous devez envoyer le problème à la liste de diffusion, fournissez toujours le contenu de vos tables de droits. Vous pouvez obtenir les données avec la commande
mysqldump mysql. Comme toujours, postez votre problème à l'aide du scriptmysqlbug. See Section 1.4.1.3, « Comment rapporter un bogue ou un problème ». Dans certains cas, vous aurez besoin de redémarrermysqldavec--skip-grant-tablespour pouvoir exécutermysqldump.
Les comptes utilisateurs de MySQL sont stockés dans la table user de la base mysql. Chaque compte MySQL a un mot de passe, même si ce qui est stocké dans la colonne Password de la table user n'est pas la version texte du mot de passe, mais un hash calculé à partir du mot de passe. La transformation est faîte avec la fonction PASSWORD().
MySQL utilise les mots de passe en deux phases, lors de la communication client/serveur :
-
Premièrement, lorsqu'un client tente de se connecter au serveur, il y a une identification initial au cours de laquelle le client doit présenter un mot de passe dont la valeur hashée est la même que celle qui est présente dans la table d'utilisateur, pour le compte que le client veut utiliser.
-
Ensuite, après la connexion du client, il peut modifier ou changer le mot de passe pour les utilisateurs du serveur (s'il a les droits nécessaires pour cela). Le client peut faire cela avec la fonction
PASSWORD(), pour générer un autre mot de passe, ou en utilisant les commandesGRANTouSET PASSWORD.
En d'autres termes, le serveur utilise les valeurs hashées durant la phase d'identification, lorsque le client tente de se connecter. Le serveur génère des valeurs hash, si un client appelle la fonction PASSWORD() ou utilise les commandes GRANT ou SET PASSWORD.
Le mécanisme de modifications des mots de passe a été modifié en MySQL 4.1, pour apporter une sécurité accrue et réduire le risque de vol de mots de passe. Cependant, ce nouveau mécanisme ne peut être compris que de la version 4.1, et des clients MySQL 4.1, ce qui pose des problèmes de compatibilité. Un client 4.1 peut se connecter sur un serveur pre-4.1, car le client comprend les deux méthodes de hashage, ancienne et nouvelle. Cependant, un client pre-4.1 qui tente se de connecter à un serveur 4.1 aura des problèmes. Par exemple, si un client mysql 4.0 essaie de se connecter au serveur 4.1, il va recevoir l'erreur suivante :
shell> mysql -h localhost -u root
Client does not support authentication protocol requested
by server; consider upgrading MySQL client
La discussion suivante décrit les différences entre les mécanismes de mots de paase, et ce que vous devez faire pour mettre à jour votre serveur en version 4.1, tout en conservant la compatibilité avec les clients pre-4.1.
Note : Cette discussion compare les comportements des versions 4.1 avec les versions d'avant (dites pre-4.1), mais le comportement 4.1 ne commence en réalité qu'avec la version 4.1.1. MySQL 4.1.0 est une version ``marginale'' car elle a un mécanisme légèrement différent de celui qui est implémenté en versions 4.1.1 et plus récent. Les différences entre les versions 4.1.0 et les versions plus récentes sont décrites ultérieurement.
Avant MySQL 4.1, les hashes calculés par PASSWORD() étaient longs de 16 octets. Des hashes ressemblait à ceci :
mysql> SELECT PASSWORD('mypass');
+--------------------+
| PASSWORD('mypass') |
+--------------------+
| 6f8c114b58f2ce9e |
+--------------------+
La colonne Password de la table user, dans laquelle les hash de mot de passse sont stockés, faisait 16 octets de long, avant MySQL 4.1.
Depuis MySQL 4.1, la fonction PASSWORD() a été modifiée, pour produire une valeur de 41 octets, comme ceci :
mysql> SELECT PASSWORD('mypass');
+-----------------------------------------------+
| PASSWORD('mypass') |
+-----------------------------------------------+
| *43c8aa34cdc98eddd3de1fe9a9c2c2a9f92bb2098d75 |
+-----------------------------------------------+
La colonne Password de la table user a été aggrandie pour faire désormais 41 octets de long :
-
Si vous faites une nouvelle installation de MySQL 4.1, la colonne
Passwordfera automatiquement 41 octets. -
Si vous mettez à jour une ancienne installation, il est recommandé d'utiliser le script
mysql_fix_privilege_tablespour mettre à jour la taille de la colonnePassword, de 16 à 41 octets. Le script ne modifie pas les valeurs elles-mêmes, qui restent à 16 octets de long.
Une colonne Password élargie peut stocker les mots de passe dans les deux formats, ancien et nouveau. Le format d'un hash de mot de passe peut être déterminer de deux manières :
-
La différence principale et évidente est la taille : 16 octets et 41 octets.
-
La seconde différence est que les hashs au nouveau format commencent par le caractère ‘
*’, alors que l'ancien format ne le fait pas.
Plus le hash du mot de passe est long, meilleure sont ses caractéristiques de chiffrement, et l'identification des client, basée sur des hash longs, est plus sécuritaire que l'ancienne méthode, dont les hashs sont plus courts.
La différence de taille entre les mots de passe est utile lors de l'utilisation des mots de passe, pour l'identification, et lors de la génération des hashs pour la modification des mots de passe, sur le client.
La fa¸on de traiter le hash de mot de passe durant la phase d'identification diffère, en fonction de la taille de la colonne Password :
-
Si la colonne est étroite, l'identification par hash court sera utilisée.
-
Si la colonne est large, elle peut contenir des hashs longs ou courts, et le serveur peut utiliser l'un ou l'autre des formats :
-
Les clients pre-4.1 peuvent se connecter, car ils connaissent l'ancien mécanisme de hashing, et ils peuvent s'identifier pour les comptes qui ont des mots de passe court.
-
Les clients 4.1 peuvent s'identifier pour les comptes qui ont des hash longs ou courts.
-
Pour les comptes à hash court, l'identification est un peut plus sécuritaire pour les clients 4.1 que pour les anciens clients. En terme de sécurité, le gradient de sécurité du plus faible au meilleur est :
-
Les clients pre-4.1 s'identifiant avec un hash court
-
Les clients 4.1 s'identifiant avec un hash court
-
Les clients 4.1 s'identifiant avec un hash long
La méthode de génération des hashs de mots de passe pour les clients connectés est aussi affectée par la taille de la colonne Password, et par l'option --old-passwords. Un serveur 4.1 génère des hashs longs sous certaines conditions : La colonne Password doit être assez grande pour acceuillir un hash de mot de passe long, et l'option --old-passwords doit être inactive. Ces conditions s'appliquent comme suit :
-
La colonne
Passworddoit être assez grande pour acceuillir des hashs de mot de passe longs (41 octets). Si la colonne n'a pas été mise à jour, et qu'elle a toujours la taille de 16 octets, le serveur le remarque, et générera des hashs de mots de passe courts lorsque le client va modifier son mot de passe avecPASSWORD(),GRANTouSET PASSWORD. Ce comportement survient si vous avez mis à jour le serveur en version 4.1, mais omis d'utiliser le scriptmysql_fix_privilege_tablespour élargir la colonnePassword. -
Si la colonne
Passwordest suffisamment grande, elle peut stocker un mot de passe long ou court. Dans ce cas,PASSWORD(),GRANTetSET PASSWORDvont générer des hashs longs, à moins que le serveur n'ait été lancé avec l'option--old-passwords. Cette option force le serveur à utiliser les hashs courts.
Le but de l'option --old-passwords est d'assurer la compatibilité ascendante avec les clients pre-4.1 clients dans certaines circonstances où le serveur aurait généré des hashs longs. Cela n'affecte pas l'identification, puisque les clients 4.1 peuvent continuer à utiliser les comptes avec des hashs longs, mias cela empêche la création de hash longs dans la table user, lors de la modification de mots de passe. Si cela arrive, le compte me pourra plus être utilisé avec les clients pre-4.1. Sans l'option --old-passwords le scénario suivant est possible :
-
Un ancient client se connecter sur un compte, avec un hash court.
-
Le client change le mot de passe. Sans l'option
--old-passwords, cela conduit à la création d'un hash long. -
Lors de la prochaine connexion, le client pre-4.1 ne peut plus se connecter, car le compte requiert désormais le nouveau mécanisme d'identification. Une fois que le hash long est dans la table
user, seuls les clients 4.1 peuvent l'utiliser, car les clients pre-4.1 ne le comprennent pas.
Ce scénario montre combien il est dangeureux d'utiliser un serveur 4.1 sans l'option --old-passwords si vous devez supporter des clients pre-4.1. En utilisant l'option --old-passwords sur le serveur, les opérations de modification de mots de passe ne génèrent pas de hashs longs, et les utilisateurs ne se barreront pas l'accès par inadvertence.
L'inconvénient de l'option --old-passwords est que tous les hashs que vous allez créer seront des hashs courts, même pour les clients 4.1. Par conséquent, vous perdez la sécurité améliorée que les hashs longs apportent. Si vous voulez créer un compte avec un hash long (par exemple, pour un client 4.1), il faudra le faire avec un serveur qui n'utilise pas l'option --old-passwords.
Les scénarios suivants sont possibles avec un serveur 4.1 :
Scenario 1 : Colonne Password courte dans la table user
-
Seuls, les hashs courts peuvent être stockés dans la colonne
Password. -
Le serveur utilise uniquement les hashs courts pour les identifications.
-
Pour les clients connectés, la génération de mot de passe avec
PASSWORD(),GRANTouSET PASSWORDutilise les mots de passe courts uniquement. Toute modification de compte entraine la création d'un hash court. -
L'option
--old-passwordspeut être utilisée, mais est superflue, car la colonnePasswordcourte impose la manipulation de hashs courts de toutes manières.
Scenario 2 : colonne Password longue dans la table user; serveur sans l'option --old-passwords
-
les hashs courts et longs peuvent être stockés dans la colonne
Password. -
Les clients 4.1 peuvent s'identifier sur leur compte avec des hashs courts ou longs.
-
Les clients pre-4.1 peuvent s'identifier sur leur compte avec des hashs courts.
-
Pour les clients connectés, la génération de mot de passe avec
PASSWORD(),GRANTouSET PASSWORDutilise les mots de passe longs uniquement. Toute modification de compte entraine la création d'un hash long.
Comme indiqué précédemment, le danger de ce scénario est qu'il est possible que les clients pre-4.1 se voient l'accès au serveur barré. Toutes les modifications du compte avec GRANT, SET PASSWORD et PASSWORD() conduisent à un hash long, qui empêrchera les clients pre-4.1 d'utiliser ce compte.
Pour régler ce problème, vous pouvez modifier le mot de passe d'une manière spéciale. Par exemple, normalement, vous pouvez utiliser la commande SET PASSWORD comme ceci pour modifier un mot de passe :
mysql>SET PASSWORD FOR->'some_user'@'some_host' = PASSWORD('mypass');
Pour changer le mot de passe avec un hash court, utilisez la fonction OLD_PASSWORD() :
mysql>SET PASSWORD FOR->'some_user'@'some_host' = OLD_PASSWORD('mypass');
OLD_PASSWORD() est pratique pour les situations où vous voulez explicitement générer un hash court.
Scenario 3 : colonne Password longue dans la table user; serveur avec l'option --old-passwords
-
les hashs courts et longs peuvent être stockés dans la colonne
Password. -
Les clients 4.1 peuvent s'identifier sur leur compte avec des hashs courts ou longs. Notez qu'il n'est alors possible de créer des hashs longs si le serveur utilise
--old-passwords). -
Les clients pre-4.1 peuvent s'identifier sur leur compte avec des hashs courts.
-
Pour les clients connectés, la génération de mot de passe avec
PASSWORD(),GRANTouSET PASSWORDutilise les mots de passe courts uniquement. Toute modification de compte entraine la création d'un hash long.
Dans ce scénario, vous ne pouvez plus créer de compte avec un hash long, car --old-passwords l'empêche. De même, si vous créez un compte avec un hash long sur un serveur qui utilise l'option --old-passwords, la modification du mot de passe tant que --old-passwords est active, aura pour effet de réduire la taille du hash, et vous perdre en sécurité.
Les inconvénients de ces scénario sont les suivants :
Scenario 1) vous ne pouvez pas tirer partie des hashs long et de leur sécurité accrue.
Scenario 2) Les comptes avec des mots de passe courts sont inaccessibles aux clients pre-4.1 si vous modifiez leur mot de passe sans utiliser la fonction OLD_PASSWORD().
Scenario 3) --old-passwords empêche les comptes avec des hashs courts d'être barrés, mais les opérations de modifications de mots de passe créeront des hashs courts, et vous ne pourrez pas les modifier tant que à --old-passwords est effective.
Une mise à jour en version MySQL 4.1 peut se révéler un problème de compatibilité pour les applications qui utilisent PASSWORD() pour générer leurs propres mots de passe. Les applications ne devraient pas faire cela, car PASSWORD() doit être réservé pour gérer les mots de passe de MySQL. Mais certaines applications utilisent PASSWORD() pour leurs propres objectifs.
Si vous passez en version 4.1 et lancez le serveur dans certaines conditions, où il va générer des hashs de mots de passe longs, l'application qui utilise PASSWORD() va sûrement planter. Notre recommandation est d'utiliser les fonctions de chiffrement SHA1() ou MD5() pour produire des signatures. Si ce n'est pas possible, vous pouvez utiliser OLD_PASSWORD(), qui est fournie pour générer des hashs courts, dans l'ancien format (mais notez que OLD_PASSWORD() pourrait être abandonné un jour aussi.
Si le serveur fonctionne dans des conditions où il génère des hashs courts, OLD_PASSWORD() est disponible comme alias de PASSWORD().
Le hashing de mot de passe de MySQL 4.1.0 diffère de celui de la version 4.1.1 et plus récents. Les différences avec la version 4.1.0 sont :
-
Les mots de passe sont stockés sur 45 octets plutôt que 41.
-
La fonction
PASSWORD()n'est pas répétable. C'est à dire, à partir du même argumentX, des appels successifs àPASSWORD(X)génèreront différents résultats.
Ces différences rendent l'identification de la version 4.1.0 incompatible avec les versions suivantes. Si vous avez mis à jour MySQL 4.1.0, il est recommandé de passer à une version plus récente aussitôt que possible. Après cela, réassignez les mots de passe de la table user pour qu'ils soient compatibles avec le format 41 octets.
- 5.6.1. Nom d'utilisateurs MySQL et mots de passe
- 5.6.2. Ajouter de nouveaux utilisateurs à MySQL
- 5.6.3. Supprimer un compte utilisateur de MySQL
- 5.6.4. Limiter les ressources utilisateurs
- 5.6.5. Configurer les mots de passe
- 5.6.6. Garder vos mots de passe en lieu sûr
- 5.6.7. Utilisation des connexions sécurisées
Cette section décrit comment configurer des comptes clients pour un serveur MySQL. Elle traite des points suivants :
-
La signification des nom de compte et mots de passes, tels qu'utilisés par MySQL, et quelle différence il y avec ceux de votre système d'exploitation.
-
Comment configurer de nouveaux comptes.
-
Comment modifier les mots de passe.
-
Des conseils de gestion des mots de passe.
-
Comment configurer des connexions sécurisées avec SSL
Il y a de nombreuses différences entre les utilisations des noms et mots de passe sous MySQL, et celles qui sont faites sous Unix ou Windows :
-
Les noms d'utilisateurs, tels qu'utilisés pour le processus d'identification sous MySQL, n'ont rien à voir avec les noms d'utilisateurs Unix ou Windows. La plupart des clients utilisent par défaut leur mot de passe Unix, mais c'est surtout parce que c'est pratique. Les programmes clients permettent d'utiliser des noms d'utilisateurs différents avec les options
-uet--user. Cela signifie que vous ne pouvez pas rendre une base de données sécuritaire sans donner de mots de passe à tous les clients. Tout le monde peut essayer de se connecter au serveur sous n'importe quel nom, et il sera possible de se connecter si un nom d'utilisateur n'a pas de mot de passe. -
Les noms d'utilisateurs MySQL peuvent avoir jusqu'à 16 caractères ; les noms d'utilisateurs Unix sont généralement limités à 8 caractères.
-
Les mots de passe MySQL n'ont aucun rapport avec le passeport Unix. Il n'y a pas nécessairement de connexion entre le mot de passe que vous utilisez pour vous connecter sur la machine Unix et celui que vous utilisez pour accéder au serveur MySQL.
-
MySQL chiffre les mots de passe avec un algorithme différent de celui qui est utilisé par Unix. Reportez-vous aux descriptions des fonctions
PASSWORD()etENCRYPT()dans Section 12.8.2, « Fonctions de chiffrements ». Notez que même si le mot de passe est enregistré 'brouillé', connaître votre mot de passe 'brouillé' est suffisant pour se connecter au serveur MySQL.
Lorsque vous installez MySQL, la table de droit contient quelques comptes initiaux. Ces comptes ont des noms et droits qui sont décrits dans Section 2.5.3, « Création des premiers droits MySQL », qui montre aussi comment donner des mots de passe. Après cela, vous pouvez créer, modifier ou supprimer normalement des comptes MySQL avec les commandes GRANT et REVOKE. See Section 13.5.1.3, « Syntaxe de GRANT et REVOKE ».
Lorsque vous vous connectez à un serveur MySQL avec un client en ligne de commande, vous devez spécifier le mot de passe avec l'option --password=mot-de-passe. See Section 5.5.4, « Se connecter au serveur MySQL ».
mysql --user=monty --password=devine nom_base
ou la version courte :
shell> mysql -u monty -pdevine nom_base
Il ne doit pas y avoir d'espace entre l'option -p et le mot de passe suivant.
Les commandes incluent la valeur d'un mot de passe en ligne de commande, ce qui n'est pas sécuritaire. See Section 5.6.6, « Garder vos mots de passe en lieu sûr ».
Pour éviter cela, spécifiez l'option --password ou -p sans aucune valeur :
shell>mysql --user=monty --password nom_baseshell>mysql -u monty -p nom_base
Le client va alors afficher une invite, et vous demander d'y saisir le mot de passe. Dans les exemples, nom_base n'est pas interprété comme un mot de passe, car il est séparé de l'option précédente par un espace.
Sur certains systèmes, l'appel que MySQL utilise pour demander le mot de passe va limiter automatiquement le mot de passe à 8 caractères. C'est un problème avec la bibliothèque système, et non pas avec MySQL. En interne, MySQL n'a pas de limite pour la taille du mot de passe. Pour contourner le problème, modifiez la taille du mot de passe pour qu'il fasse 8 caractères ou mois, ou placez votre mot de passe dans un fichier d'options.
Vous pouvez ajouter des utilisateurs de deux fa¸ons différentes :
-
en utilisant la commande
GRANT -
manipulant la table des droits de MySQL directement
La méthode préférée consiste à utiliser la commande GRANT, car elle est plus concise et qu'il y a moins de risques d'erreur. Sa syntaxe est présentée dans la section Section 13.5.1.3, « Syntaxe de GRANT et REVOKE ».
Il y a aussi beaucoup de programmes utilitaires comme phpmyadmin qui peuvent être utilisés pour créer et administrer les utilisateurs.
Les exemples suivants montrent comment utiliser le client mysql pour créer de nouveaux utilisateurs. Ces exemples supposent que les privilèges sont attribués en accord avec les valeurs par défaut discutées dans la section Section 2.5.3, « Création des premiers droits MySQL ». Cela signifie que pour effectuer des changements, vous devez être sur la même machine où mysqld tourne, vous devez vous connecter en tant qu'utilisateur MySQL root, et l'utilisateur root doit avoir le droit INSERT sur la base mysql et le droit d'administration RELOAD. Si vous avez changé le mot de passe de l'utilisateur root, vous devez le spécifier dans les commandes mysql ci-dessous.
D'abord, utilisez le programme client mysql pour vous connecter au serveur MySQL en tant qu'utilisateur root :
shell> mysql --user=root mysql
Vous pouvez ajouter de nouveaux utilisateurs en utilisant des commandes GRANT :
mysql>GRANT ALL PRIVILEGES ON *.* TO 'monty'@'localhost'->IDENTIFIED BY 'un_mot_de_passe' WITH GRANT OPTION;mysql>GRANT ALL PRIVILEGES ON *.* TO 'monty'@'%'->IDENTIFIED BY 'un_mot_de_passe' WITH GRANT OPTION;mysql>GRANT RELOAD,PROCESS ON *.* TO 'admin'@'localhost';mysql>GRANT USAGE ON *.* TO 'dummy'@'localhost';
Ces commandes GRANT ajoutent trois nouveaux utilisateurs :
-
Deux comptes de super-utilisateur qui utilisent le mot de passe
'un_mot_de_passe'. Les deux comptes ont tous les droits sur le serveur. Un des comptes,'monty'@'localhost', peut être utilisé depuis la machine locale. L'autre depuis n'importe quel autre serveur :'monty'@'%'. Notez que nous devons exécuter une commandeGRANTpour'monty'@'localhost'et'monty'@'%'. Si nous n'ajoutons pas l'entrée aveclocalhost, l'entrée concernant l'utilisateur anonyme pourlocalhostqui est créée parmysql_install_dbprendra précédence lors de la connexion à partir de l'hôte local, car elle a une entrée plus spécifique pour la valeur du champHostet de plus, elle vient en premier dans l'ordre de tri de la tableuser. Les tris de la tableusersont présentés dans la section Section 5.5.5, « Contrôle d'accès, étape 1 : Vérification de la connexion ». -
Un utilisateur
adminqui peut se connecter depuislocalhostsans mot de passe et qui a les droits administratifsRELOADetPROCESS. Cela permet à cet utilisateur d'exécuter les commandesmysqladmin reload,mysqladmin refresh, etmysqladmin flush-*, ainsi quemysqladmin processlist. Aucun droit lié aux bases de données n'est donné. Ils peuvent l'être plus tard en utilisant d'autres instructionsGRANT. -
Un utilisateur
dummyqui peut se connecter sans mot de passe, mais seulement à partir de l'hôte local. Les droits globaux sont tous à'N': le type de droitUSAGEvous permet de créer un utilisateur démuni de privilège. Il est supposé que vous lui assignerez les droits spécifiques aux bases de données plus tard.
Vous pouvez ajouter les mêmes droits d'accès aux utilisateurs en utilisant directement des requêtes INSERT puis en demandant au serveur de recharger les tables de droits :
shell>mysql --user=root mysqlmysql>INSERT INTO user VALUES('localhost','monty',PASSWORD('un_mot_de_passe'),->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y');mysql>INSERT INTO user VALUES('%','monty',PASSWORD('un_mot_de_passe'),->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y');mysql>INSERT INTO user SET Host='localhost',User='admin',->Reload_priv='Y', Process_priv='Y';mysql>INSERT INTO user (Host,User,Password)->VALUES('localhost','dummy','');mysql>FLUSH PRIVILEGES;
Selon votre version de MySQL, vous pouvez avoir un nombre différent de valeurs 'Y' plus haut (les versions antérieures à la 3.22.11 possèdent moins de colonnes de privilèges). Pour l'utilisateur admin, la syntaxe d'INSERT étendue la plus lisible disponible depuis la version 3.22.11 est utilisée.
Notez que pour ajouter un super-utilisateur, vous avez juste besoin de créer une entrée dans la table user avec tous les champs de droits à 'Y'. Aucune entrée n'est requise dans les tables db et host.
Les colonnes de privilèges de la table user n'étaient pas renseignées explicitement dans la dernière requête INSERT (pour l'utilisateur dummy), ses colonnes prennent donc la valeur par défaut, 'N'. C'est la même chose que ce que fait GRANT USAGE.
L'exemple suivant ajoute un utilisateur custom qui peut se connecter à partir des hôtes localhost, server.domain, et whitehouse.gov. Il ne pourra accéder à la base de données bankaccount qu'à partir de localhost, à la base expenses qu'à partir de whitehouse.gov, et à la base customer à partir des trois hôtes. Il utilisera le mot de passe stupid pour les trois hôtes.
Pour configurer les privilèges de cet utilisateur en utilisant des commandes GRANT, exécutez ce qui suit :
shell>mysql --user=root mysqlmysql>GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP->ON bankaccount.*->TO custom@localhost->IDENTIFIED BY 'stupid';mysql>GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP->ON expenses.*->TO custom@whitehouse.gov->IDENTIFIED BY 'stupid';mysql>GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP->ON customer.*->TO custom@'%'->IDENTIFIED BY 'stupid';
Les trois comptes peuvent être utilisés comme suit :
-
Le premier compte a accès à la base
bankaccount, mais uniquement depuis l'hôte local. -
Le second compte peut accéder à la base
expenses, mais uniquement depuis l'hôtewhitehouse.gov. -
Le troisième compte peut accéder à la base
customer, mais uniquement depuis l'hôteserver.domain.
Pour régler les permissions d'accès en modifiant directement les tables de droits, exécutez ces commandes (notez l'appel à FLUSH PRIVILEGES à la fin) :
shell>mysql --user=root mysqlmysql>INSERT INTO user (Host,User,Password)->VALUES('localhost','custom',PASSWORD('stupid'));mysql>INSERT INTO user (Host,User,Password)->VALUES('server.domain','custom',PASSWORD('stupid'));mysql>INSERT INTO user (Host,User,Password)->VALUES('whitehouse.gov','custom',PASSWORD('stupid'));mysql>INSERT INTO db->(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,->Create_priv,Drop_priv)->VALUES->('localhost','bankaccount','custom','Y','Y','Y','Y','Y','Y');mysql>INSERT INTO db->(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,->Create_priv,Drop_priv)->VALUES->('whitehouse.gov','expenses','custom','Y','Y','Y','Y','Y','Y');mysql>INSERT INTO db->(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,->Create_priv,Drop_priv)->VALUES('%','customer','custom','Y','Y','Y','Y','Y','Y');mysql>FLUSH PRIVILEGES;
Les trois premières requêtes INSERT ajoute les entrées dans la table user qui permettent l'utilisateur custom à se connecter à partir de plusieurs hôtes avec le mot de passe donné, mais ne lui donnent aucun droit (tous les droits sont mis à la valeur par défaut qui est 'N'). Les trois requêtes INSERT suivantes ajoutent des entrées dans la table db qui autorisent custom à utiliser les bases de données bankaccount, expenses, et customer, mais seulement s'il y accède à partir de l'hôte spécifié. Comme d'habitude, lorsque les tables de droits sont modifiées directement, on doit demander au serveur des les recharger (avec FLUSH PRIVILEGES) pour que les changements soient pris en compte.
Si vous voulez donner un accès spécifique à un utilisateur à partir de n'importe quelle machine d'un domaine donné, vous pouvez utiliser la commande GRANT, en utilisant ‘%’ comme joker dans le nom de l'hôte :
mysql>GRANT ...->ON *.*->TO monutilisateur@"%.mondomaine.com"->IDENTIFIED BY 'monmotdepasse';
Pour faire la même chose en modifiant directement la table de droits, faites :
mysql>INSERT INTO user VALUES ('%.mondomaine.com', 'monutilisateur',->PASSWORD('monmotdepasse'),...);mysql>FLUSH PRIVILEGES;
Pour supprimer un compte, utilisez la commande DROP USER, qui a été ajoutée en MySQL 4.1.1. Pour les anciennes versions de MySQL, utilisez la commande DELETE. La suppression de compte est décrite dans la section Section 13.5.1.2, « Effacer des utilisateurs MySQL ».
Jusqu'à la version 4.0.2, la seule méthode possible pour limiter l'utilisation des ressources serveurs MySQL était de configurer la variable de démarrage max_user_connections avec une valeur non nulle. De même, le nombre de connexions simultanées pouvaient être limitées pour un compte, mais pas les opérations réalisables, une fois l'utilisateur connecté. Ces deux types de contrôles ont importants pour les administrateurs systèmes et les fournisseurs de services.
Depuis MySQL 4.0.2, il est possible de limiter certaines ressources accessibles à un utilisateur possible :
-
Nombre de requête par heure : Toutes les commandes qu'un utilisateur peut exécuter.
-
Nombre de modifications par heure : Toute commande qui implique la modification d'une table ou d'une base.
-
Nombre de connexions réalisées par heure : Le nombre de nouvelles connexions par heure.
Toute commande que le client émet compte pour la limiter de requêtes. Seules les commandes qui modifient les tables ou bases comptant pour la limite de modifications.
Pour utiliser cette fonctionnalité, la table user de la base mysql doit contenir les colonnes nécessaires pour stocker les limites. Les limites doivent être stockées dans les colonnes max_questions, max_updates et max_connections. Si votre table user ne dispose pas de ces colonnes, elle doit être mise à jour. Voyez Section 2.6.7, « Mise à jour des tables de droits ».
Par défaut, les utilisateurs ne sont pas limités dans l'utilisation des ressources ci-dessus, à moins que des limites ne leur soient imposées. Ces limites peuvent être configurées uniquement via la commande GRANT (*.*), avec cette syntaxe :
Pour spécifier des limites de ressources avec la commande GRANT, utilisez la clause WITH pour chaque ressource que vous voulez limiter. Par exemple, pour créer un nouveau compte avec un accès à la base customer, mais sans abuser, utilisez ceci :
mysql>GRANT ALL ON customer.* TO 'francis'@'localhost'->IDENTIFIED BY 'frank'->WITH MAX_QUERIES_PER_HOUR 20->MAX_UPDATES_PER_HOUR 10->MAX_CONNECTIONS_PER_HOUR 5;
Les types de limite n'ont pas besoin d'être tous appelés avec WITH, mais ils peuvent être appelés dans n'importe quel ordre. La valeur de chaque limite doit être un entier représentant le nombre autorisé par heure. Si la commande GRANT n'a pas de clause WITH, les limites valent alors 0, c'est à dire qu'il n'y a pas de limite.
Pour configurer et changer les limites d'un compte existant, utilisez la commande GRANT USAGE au niveau global, avec ON *.*. La commande suivante modifie la limite de requêtes du compte francis à 100 :
mysql>GRANT USAGE ON *.* TO 'francis'@'localhost'->WITH MAX_QUERIES_PER_HOUR 100;
Cette commande ne touche pas aux droits du compte : elle ne modifie que les valeurs des limites.
Pour supprimer une limite existante, donnez lui la valeur de 0. Par exemple, pour supprimer la limite de connexions de francis, utilisez cette commande :
mysql>GRANT USAGE ON *.* TO 'francis'@'localhost'->WITH MAX_CONNECTIONS_PER_HOUR 0;
Le compteur d'utilisation des ressources se met en marche dès que la limite n'est pas nulle.
Durant le fonctionnement du serveur, les ressources utilisées sont comptées. Si le compte atteint la limite de connexions dans un intervalle d'une heure, les connexions suivantes sont rejetées, jusqu'à la fin de l'heure. Similairement, si le compte atteint la limite de requête dans un intervalle d'une heure, les requêtes suivantes sont sont rejetées, jusqu'à la fin de l'heure. Dans tous les cas, un message approprié est affiché.
Le compte de ressource est fait par compte, et non pas client. Par exemple, si votre compte a une limite de requêtes de 50, vous ne pouvez pas augmenter votre limite à 100 en vous connectant deux fois. Les requêtes issues des deux connexions seront alors comptées ensemble.
Le compte courant d'utilisation peut être remis à zéro, globalement, ou individuellement :
-
Pour remettre à zéro les compteurs pour tous les comptes, faites un
FLUSH USER_RESOURCES. Les comptes sont remis à zéro au moment du re-chargement des tables de droits : par exemple, avec la commandeFLUSH PRIVILEGESou la commandemysqladmin reload. -
Les comptes individuels peuvent être remis à zéro en donnant de nouvelles limites ou changeant les droits. Pour cela, utilisez
GRANT USAGEtel que décrit précédemment, en donnant la même limite que celle qui est configurée.
Les mots de passe peuvent être assigné en ligne de commande avec l'utilitaire mysqladmin :
shell> mysqladmin -u user_name -h host_name password "newpwd"
Le compte qui est remis à zéro par cette commande est celui pour lequel une ligne de la table user qui correspond à la valeur user_name dans la colonne User et l'hôte client d'où vous vous connectez dans la colonne Host.
Un autre moyen pour assigner un mot de passe à un compte est d'utiliser la commande SET PASSWORD :
mysql> SET PASSWORD FOR 'jeffrey'@'%' = PASSWORD('biscuit');
Seuls les utilisateurs root ayant des accès en écriture à la base mysql peuvent changer les mots de passe des autres utilisateurs. Si vous n'êtes pas connectés en tant qu'utilisateur anonyme, vous pouvez modifier votre propre mot de passe en omettant la clause FOR :
mysql> SET PASSWORD = PASSWORD('biscuit');
Vous pouvez aussi utiliser la commande GRANT USAGE au niveau global (ON *.*) pour assigner un mot de passe sans affecter les droits du compte :
mysql> GRANT USAGE ON *.* TO 'jeffrey'@'%' IDENTIFIED BY 'biscuit';
Même s'il est généralement préférable d'assigner un mot de passe en utilisant une des méthodes précédentes, vous pouvez aussi modifier la table user directement :
-
Pour établir un mot de passe lors de la création d'un compte, fournissez une valeur à la colonne
Password:shell>
mysql -u root mysqlmysql>INSERT INTO user (Host,User,Password)->VALUES('%','jeffrey','biscuit');mysql>FLUSH PRIVILEGES; -
Pour changer le mot de passe d'un compte existant, utilisez la commande
UPDATEpour modifier la valeur de la colonnePassword:shell>
mysql -u root mysqlmysql>UPDATE user SET Password = PASSWORD('bagel')->WHERE Host = '%' AND User = 'francis';mysql>FLUSH PRIVILEGES;
Lorsque vous assignez un mot de passe à un compte avec SET PASSWORD, INSERT, ou UPDATE, vous devez utiliser la fonction PASSWORD() pour le chiffrer. La seule exception est que vous n'avez pas besoin d'utiliser PASSWORD() si le mot de passe est vide. PASSWORD() est nécessaire car la table user stocke les mots de passe sous forme chiffrée, et non en texte clair. Si vous oubliez cela, vous risquez d'avoir des mots de passe de la forme :
shell>mysql -u root mysqlmysql>INSERT INTO user (Host,User,Password)->VALUES('%','jeffrey','biscuit');mysql>FLUSH PRIVILEGES;
Le résultat est que la valeur 'biscuit' est stockée dans la colonne de mot de passe de la table user. Lorsque l'utilisateur jeffrey tente de se connecter au serveur avec ce mot de passe, le client mysql compare ce mot de passe chiffré avec sa version en clair stockée dans la table user. Cependant, la version stockée est la valeur littérale de 'biscuit', et la comparaison échoue, le serveur rejette la connexion :
shell> mysql -u jeffrey -pbiscuit test
Access denied
Si vous modifiez les mots de passe en utilisant la commande GRANT ... IDENTIFIED BY ou la commande mysqladmin password, la fonction PASSWORD() n'est pas nécessaire. Ces commandes assureront le chiffrement de votre mot de passe pour vous, ce qui vous permet de spécifier le mot de passe de 'biscuit' comme ceci :
Note : PASSWORD() n'effectue pas le chiffrement du mot de passe de la même fa¸on qu'Unix. See Section 5.6.1, « Nom d'utilisateurs MySQL et mots de passe ».
Il est recommandé de ne pas placer votre mot de passe là où il risque d'être découvert par d'autres personnes. Les méthode que vous utiliserez pour spécifier votre mot de passe lors de la connexion avec le client sont listées ici, avec les risques liés à chaque méthode :
-
Utilisez l'option
-pou--password(sans la valeur dumot de passe). Dans ce cas, le programme client va solliciter la saisie du mot de passe depuis le terminal :shell>
mysql -u user_name -pEnter password: ********Cette méthode est pratique mais peu sûre, car le mot de passe est visible par les programmes système tels que
psqui peuvent être appelé par les autres utilisateurs. Les clients MySQL remplacent généralement les arguments de la ligne de commande par des zéros durant leur initialisation, mais il y a un court instant où la valeur est visible. -
Utilisez les options
-pou--passwordsans valeur de mot de passe. Dans ce cas, le client va solliciter explicitement le mot de passe du terminal :shell>
mysql -u francisEnter password: ********Les caractères ‘
*’ représentent votre mot de passe. Le mot de passe n'est pas affiché en clair lors de votre saisie.Cette méthode est bien plus sûre pour saisir votre mot de passe qu'en le spécifiant directement en ligne de commande, car il n'est pas visible des autres utilisateurs. Cependant, cette méthode n'est possible qu'avec les programmes que vous utilisez en mode interactif. Si vous voulez invoquer le client depuis un script qui s'exécute de manière non interactive, il n'y aura pas d'opportunité pour saisir ce mot de passe dans le terminal. Sur certains systèmes, vous pourriez même voir la première ligne de votre script lue et interprétée comme votre mot de passe, incorrectement.
-
Stockez votre mot de passe dans le fichier de configuration. Par exemple, vous pouvez lister votre mot de passe dans la section
[client]du fichier.my.cnfdans votre dossier personnel :[client] password=mot_de_passe
Si vous stockez ce mot de passe dans le fichier
.my.cnf, le fichier ne doit pas être lisible par le groupe ou par les autres utilisateurs, ou encore accessible en écriture : seul le propriétaire de ce fichier doit avoir ces droits. Assurez-vous les droits d'accès au fichiers sont400ou600. Par exemple :shell>
chmod 600 .my.cnfSection 4.3.2, « Fichier d'options
my.cnf» présente les options pour plus de détail.s -
Vous pouvez stocker votre mot de passe dans la variable d'environnement
MYSQL_PWD, mais cette méthode doit être considérée comme extrêmement peu sûre, et doit être évitée autant que possible. Certaines versions de la commande en lignepsincluent une option pour afficher les variables d'environnement des processus : votre mot de passe sera alors facilement accessible, et en texte clair, si vous configurez la commandeMYSQL_PWD. Même sur les systèmes sans une telle version de la commandeps, il est peu recommandé de supposer que les variables d'environnement sont inaccessibles par une méthode quelconque. See Annexe E, Variables d'environnement.
En conclusion, la méthode la plus sûre est encore de laisser le client vous demander le mot de passe, ou de le spécifier dans le fichier de configuration.
Disponible depuis la version 4.0.0, MySQL supporte les connexions sécurisées. Pour comprendre comment MySQL utilise SSL, il est nécessaire de comprendre les concepts SSL et X509 de base. Ceux qui les connaissent, peuvent aisément sauter ce chapitre.
Par défaut, MySQL utilise une connexion en clair entre le client et le serveur. Cela signifie qu'une personne peut surveiller votre trafic, et lire les données échangées. Cette personne pourrait aussi modifier les données qui transitent entre le client et le serveur. Parfois, vous aurez besoin d'échanger des informations sur un réseau public, mais en sécurisant ces informations. Dans ce cas, utiliser une connexion sans protection est inacceptable.
SSL est un protocole qui utilise différents algorithmes de chiffrement pour s'assurer que les données qui transitent par un réseau public peuvent être considérées comme fiables. Ce protocole dispose de méthodes pour s'assurer que les données n'ont pas été modifiées, ce que soit par une altération, une perte ou une répétition des données. SSL inclut aussi des algorithmes pour reconnaître et fournit des outils de vérifications d'identité, pris en charge par le standard X509.
Le chiffrement est une méthode pour rendre des données illisibles. En fait, les pratiques actuelles requièrent d'autres éléments de sécurité issus des algorithmes de chiffrement. Ils doivent savoir résister à de nombreux types d'attaque, comme la modification de l'ordre des messages ou les répétitions inopinées.
X509 est un standard qui rend possible l'identification d'une personne sur l'internet. Il est particulièrement utilisé pour les applications e-commerce. En termes simples, il doit y avoir une entreprise (appelée l'``autorité de certification'') qui assigne un certificat électronique à toute personne qui en a besoin. Ces certificats utilisent un chiffrement assymétrique qui exploitent deux clés de chiffrement, une clé publique et une clé privée. Le propriétaire d'un certificat peut prouver son identité en montrant son certificat à l'autre partie. Un certificat est constitué de la clé publique du propriétaire. Toute donnée qui est chiffrée avec cette clé publique doit être déchiffrée avec la clé secrète correspondante, qui est détenue par le propriétaire du certificat.
MySQL n'utilise pas les connexions chiffrées par défaut, car cela ralentit considérablement le protocole de communication. Toute fonctionnalité supplémentaire requiert du travail supplémentaire de la part du serveur, et chiffrer des données est une tâche particulièrement coûteuse, qui peut ralentir considérablement les tâches principales de MySQL. Par défaut, MySQL est paramétré pour être aussi rapide que possible.
Si vous avez besoin de plus d'informations sur SSL, X509 ou le chiffrement, utilisez votre moteur de recherche préféré sur Internet, et utilisez ces mots clés pour avoir plus de détails.
Pour utiliser les connexions SSL entre le serveur MySQL et les clients, vous devez avoir le support de OpenSSL et votre version de MySQL doit être 4.0.0 ou plus récente.
Pour faire fonctionner les connexions sécurisées avec MySQL, vous devez disposer de ceci :
-
Installation de la bibliothèque d'OpenSSL. Nous avons testé MySQL avec OpenSSL 0.9.6. http://www.openssl.org/.
-
Lorsque vous configurez MySQL, utilisez le script
configureavec les options--with-vioet--with-openssl. -
Assurez vous que vous avez une version de la table
mysql.userà jour. Ceci est nécessaire si vos tables de droits proviennent d'un version de MySQL antérieure à la version 4.0.0. La procédure de mise à jour est décrite dans Section 2.6.7, « Mise à jour des tables de droits ». -
Vous pouvez vérifier que vous posséder un serveur
mysqldqui supporte OpenSSL en examinant le résultat de la commandeSHOW VARIABLES LIKE 'have_openssl':mysql>
SHOW VARIABLES LIKE 'have_openssl';+---------------+-------+ | Variable_name | Value | +---------------+-------+ | have_openssl | YES | +---------------+-------+elle doit retourner
YES.
Voici un exemple de configuration de certificats SSL pour MySQL :
DIR=`pwd`/openssl
PRIV=$DIR/private
mkdir $DIR $PRIV $DIR/newcerts
cp /usr/share/ssl/openssl.cnf $DIR
replace ./demoCA $DIR -- $DIR/openssl.cnf
# Créez les dossiers nécessaires : $database, $serial et $new_certs_dir
# optionnel
touch $DIR/index.txt
echo "01" > $DIR/serial
#
# Génération du cerificat d'autorité (CA)
#
openssl req -new -x509 -keyout $PRIV/cakey.pem -out $DIR/cacert.pem \
-config $DIR/openssl.cnf
# Exemple de résultat :
# Using configuration from /home/monty/openssl/openssl.cnf
# Generating a 1024 bit RSA private key
# ................++++++
# .........++++++
# writing new private key to '/home/monty/openssl/private/cakey.pem'
# Enter PEM pass phrase:
# Verifying password - Enter PEM pass phrase:
# -----
# You are about to be asked to enter information that will be incorporated
# into your certificate request.
# What you are about to enter is what is called a Distinguished Name or a DN.
# There are quite a few fields but you can leave some blank
# For some fields there will be a default value,
# If you enter '.', the field will be left blank.
# -----
# Country Name (2 letter code) [AU]:FI
# State or Province Name (full name) [Some-State]:.
# Locality Name (eg, city) []:
# Organization Name (eg, company) [Internet Widgits Pty Ltd]:MySQL AB
# Organizational Unit Name (eg, section) []:
# Common Name (eg, YOUR name) []:MySQL admin
# Email Address []:
#
# Création des clé et requêtes serveur
#
openssl req -new -keyout $DIR/server-key.pem -out \
$DIR/server-req.pem -days 3600 -config $DIR/openssl.cnf
# Exemple de résultat :
# Using configuration from /home/monty/openssl/openssl.cnf
# Generating a 1024 bit RSA private key
# ..++++++
# ..........++++++
# writing new private key to '/home/monty/openssl/server-key.pem'
# Enter PEM pass phrase:
# Verifying password - Enter PEM pass phrase:
# -----
# You are about to be asked to enter information that will be incorporated
# into your certificate request.
# What you are about to enter is what is called a Distinguished Name or a DN.
# There are quite a few fields but you can leave some blank
# For some fields there will be a default value,
# If you enter '.', the field will be left blank.
# -----
# Country Name (2 letter code) [AU]:FI
# State or Province Name (full name) [Some-State]:.
# Locality Name (eg, city) []:
# Organization Name (eg, company) [Internet Widgits Pty Ltd]:MySQL AB
# Organizational Unit Name (eg, section) []:
# Common Name (eg, YOUR name) []:MySQL server
# Email Address []:
#
# Please enter the following 'extra' attributes
# to be sent with your certificate request
# A challenge password []:
# An optional company name []:
#
# Supprimez la passe-phrase de la clé (optionnel)
#
openssl rsa -in $DIR/server-key.pem -out $DIR/server-key.pem
#
# Signez le certificat serveur
#
openssl ca -policy policy_anything -out $DIR/server-cert.pem \
-config $DIR/openssl.cnf -infiles $DIR/server-req.pem
# Exemple de résultat :
# Using configuration from /home/monty/openssl/openssl.cnf
# Enter PEM pass phrase:
# Check that the request matches the signature
# Signature ok
# The Subjects Distinguished Name is as follows
# countryName :PRINTABLE:'FI'
# organizationName :PRINTABLE:'MySQL AB'
# commonName :PRINTABLE:'MySQL admin'
# Certificate is to be certified until Sep 13 14:22:46 2003 GMT (365 days)
# Sign the certificate? [y/n]:y
#
#
# 1 out of 1 certificate requests certified, commit? [y/n]y
# Write out database with 1 new entries
# Data Base Updated
#
# Créez les clé et requêtes client
#
openssl req -new -keyout $DIR/client-key.pem -out \
$DIR/client-req.pem -days 3600 -config $DIR/openssl.cnf
# Exemple de résultat :
# Using configuration from /home/monty/openssl/openssl.cnf
# Generating a 1024 bit RSA private key
# .....................................++++++
# .............................................++++++
# writing new private key to '/home/monty/openssl/client-key.pem'
# Enter PEM pass phrase:
# Verifying password - Enter PEM pass phrase:
# -----
# You are about to be asked to enter information that will be incorporated
# into your certificate request.
# What you are about to enter is what is called a Distinguished Name or a DN.
# There are quite a few fields but you can leave some blank
# For some fields there will be a default value,
# If you enter '.', the field will be left blank.
# -----
# Country Name (2 letter code) [AU]:FI
# State or Province Name (full name) [Some-State]:.
# Locality Name (eg, city) []:
# Organization Name (eg, company) [Internet Widgits Pty Ltd]:MySQL AB
# Organizational Unit Name (eg, section) []:
# Common Name (eg, YOUR name) []:MySQL user
# Email Address []:
#
# Please enter the following 'extra' attributes
# to be sent with your certificate request
# A challenge password []:
# An optional company name []:
#
# Supprimez la passe-phrase de la clé (optionnel)
#
openssl rsa -in $DIR/client-key.pem -out $DIR/client-key.pem
#
# Signez le cerficat client
#
openssl ca -policy policy_anything -out $DIR/client-cert.pem \
-config $DIR/openssl.cnf -infiles $DIR/client-req.pem
# Exemple de résultat :
# Using configuration from /home/monty/openssl/openssl.cnf
# Enter PEM pass phrase:
# Check that the request matches the signature
# Signature ok
# The Subjects Distinguished Name is as follows
# countryName :PRINTABLE:'FI'
# organizationName :PRINTABLE:'MySQL AB'
# commonName :PRINTABLE:'MySQL user'
# Certificate is to be certified until Sep 13 16:45:17 2003 GMT (365 days)
# Sign the certificate? [y/n]:y
#
#
# 1 out of 1 certificate requests certified, commit? [y/n]y
# Write out database with 1 new entries
# Data Base Updated
#
# Créez le fichier my.cnf que vous pourrez utiliser pour tester les différents certificats
#
cnf=""
cnf="$cnf [client]"
cnf="$cnf ssl-ca=$DIR/cacert.pem"
cnf="$cnf ssl-cert=$DIR/client-cert.pem"
cnf="$cnf ssl-key=$DIR/client-key.pem"
cnf="$cnf [mysqld]"
cnf="$cnf ssl-ca=$DIR/cacert.pem"
cnf="$cnf ssl-cert=$DIR/server-cert.pem"
cnf="$cnf ssl-key=$DIR/server-key.pem"
echo $cnf | replace " " '
' > $DIR/my.cnf
#
# To test MySQL
mysqld --defaults-file=$DIR/my.cnf &
mysql --defaults-file=$DIR/my.cnf
Pour tester les connexions SSL, lancez le serveur comme ceci, où $DIR est le dossier où le fichier de configuration my.cnf est situé :
shell> mysqld --defaults-file=$DIR/my.cnf &
Puis, lancez le programme client en utilisant le même fichier d'options :
shell> mysql --defaults-file=$DIR/my.cnf
Si vous avez une distribution source MySQL, vous pouvez aussi tester votre configuration en modifiant le fichier my.cnf précédent, pour utiliser les certificats et fichiers de clé SSL de la distribution.
MySQL peut vérifier les certificats X509 en plus de la combinaisons habituelle de nom d'utilisateur et mot de passe. Toutes les options habituelles sont toujours nécessaires (nom d'utilisateur, masque d'adresse IP, nom de base de données, nom de table). See Section 13.5.1.3, « Syntaxe de GRANT et REVOKE ».
Voici différentes possibilités pour limiter les connexions :
-
Sans aucune option SSL ou X509, toutes les connexions chiffrées ou non chiffrées sont autorisées si le nom d'utilisateur et le mot de passe sont valides.
-
L'option
REQUIRE SSLrequiert que les connexions soient chiffrées avec SSL. Notez que cette option peut être omise si il n'y a pas de ligne ACL qui autorise une connexion sans SSL.mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret" REQUIRE SSL; -
REQUIRE X509impose au client d'avoir un certificat valide, mais le certificat lui même est de peu d'importance. La seule restriction est qu'il doit être possible de vérifier la signature avec une des autorités de certification.mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret" REQUIRE X509; -
REQUIRE ISSUER "issuer"restreint les tentatives de connexion : le client doit se présenter avec un certificat X509 valide, émis par l' autorité de certification"issuer". Utiliser un certificat X509 implique obligatoirement des chiffrements, donc l'optionSSLest sous entendue.mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret"->REQUIRE ISSUER "C=FI, ST=Some-State, L=Helsinki,">O=MySQL Finland AB, CN=Tonu Samuel/Email=tonu@mysql.com"; -
REQUIRE SUBJECT "subject"impose au client d'avoir un certificat X509 valide, avec le sujet"subject". Si le client présente un certificat valide, mais que le"subject"est différent, la connexion est refusée.mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret"->REQUIRE SUBJECT "C=EE, ST=Some-State, L=Tallinn,">O=MySQL demo client certificate,">CN=Tonu Samuel/Email=tonu@mysql.com"; -
REQUIRE CIPHER "cipher"est utilisé pour s'assurer que les chiffrements sont suffisamment robuste, et que la bonne longueur de clé est utilisée. SSL lui même peut être faible si des algorithmes sont utilisés avec des clés courtes. En utilisant cette option, il est possible d'imposer la méthode de chiffrement avec la connexion.mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret"->REQUIRE CIPHER "EDH-RSA-DES-CBC3-SHA";Les options
SUBJECT,ISSUERetCIPHERpeuvent être combinées avec la clauseREQUIREcomme ceci :mysql>
GRANT ALL PRIVILEGES ON test.* TO root@localhost->IDENTIFIED BY "goodsecret"->REQUIRE SUBJECT "C=EE, ST=Some-State, L=Tallinn,">O=MySQL demo client certificate,">CN=Tonu Samuel/Email=tonu@mysql.com"->AND ISSUER "C=FI, ST=Some-State, L=Helsinki,">O=MySQL Finland AB, CN=Tonu Samuel/Email=tonu@mysql.com"->AND CIPHER "EDH-RSA-DES-CBC3-SHA";Depuis MySQL 4.0.4, le mot clé
ANDest optionnel, entre les optionsREQUIRE.L'ordre de ces options n'a pas d'importance, mais aucune option ne peut être spécifiée deux fois.
La table suivante liste les différentes options que vous pouvez utiliser avec SSL, les fichiers de certificats et de clés. Ces options sont disponibles depuis MySQL 4.0. Elles peuvent être spécifiées en ligne de commande ou bien dans le fichier d'options.
-
--sslPour le serveur, indique que le serveur autorise les connexions SSL. Pour le client, permet au logiciel de se connecter au serveur en utilisant le protocole SSL. Cette option seule n'est pas suffisante pour que la connexion soit sécurisée par SSL. Vous devez aussi spécifier les options
--ssl-ca,--ssl-certet--ssl-key.Cette option est plus souvent utilisée que sa forme contraire, pour indiquer que SSL ne doit pas être utilisé. Pour cela, spécifiez l'option sous la forme
--skip-sslou--ssl=0.Notez que cette option ne requiert pas de connexion SSL. Par exemple, si le serveur ou le client sont compilés sans le support SSL, une connexion sans chiffrement sera utilisée.
Une méthode pour s'assurer que la connexion sera bien sécurisée par SSL est de créer un compte sur le serveur, avec l'option
REQUIRE SSLdans la commandeGRANT. Utilisez alors ce compte pour vous connecter au serveur, avec le serveur et le client qui disposent du support SSL.Vous pouvez utiliser cette option pour indiquer que la connexion ne doit pas être SSL. Pour faire cela, spécifiez l'option
--skip-sslou--ssl=0. -
--ssl-ca=file_nameLe chemin jusqu'au fichier avec une liste des autorités de certifications SSL connues.
-
--ssl-capath=directory_nameLe chemin jusqu'au dossier qui contient les certificats SSL au format
PEM. -
--ssl-cert=file_nameLe nom du fichier de certificat SSL à utiliser pour établir une connexion sécurisée.
-
--ssl-cipher=cipher_listUne liste de chiffrements autorisées, à utiliser avec SSL.
cipher_lista le même format que la commandeopenssl ciphers.Exemple :
--ssl-cipher=ALL:-AES:-EXP -
--ssl-key=file_nameLe nom du fichier de la clé SSL a utiliser pour établir une connexion sécurisée.
Voici une note pour connecter un serveur MySQL avec une connexion sécurisée grâce à SSH (de David Carlson <dcarlson@mplcomm.com>) :
-
Installez un client SSH pour votre machine Windows. En tant qu'utilisateur, le meilleur que je connaisse est celui de
SecureCRTde http://www.vandyke.com/. Une autre option estf-securede http://www.f-secure.com/. Vous pouvez aussi en trouver d'autres de gratuit avecGoogleà http://directory.google.com/Top/Computers/Security/Products_and_Tools/Cryptography/SSH/Clients/Windows/. -
Démarrez votre client SSH Windows. Spécifiez
Host_Name = yourmysqlserver_URL_or_IP. Spécifiezuserid=your_useridpour vous loger dans votre serveur (probablement avec un mot de passe et un nom d'utilisateur différent). -
Configurez le
forwardde port. Faites soit unforwarddistant (spécifiezlocal_port: 3306,remote_host: yourmysqlservername_or_ip,remote_port: 3306) soit un forward local (spécifiezport: 3306,host: localhost,remote port: 3306). -
Sauvez le tout, sinon vous devrez le refaire la prochaine fois.
-
Connectez vous à votre serveur avec la session SSH que vous venez de créer.
-
Sous votre machine Windows, démarrez une application ODBC (comme
Access). -
Créez un nouveau fichier dans Windows et reliez le avec MySQL en utilisant le pilote ODBC de la même fa¸on que vous le feriez habituellement, hormis le fait que vous devrez taper
localhostcomme hôte serveur au lieu deyourmysqlservername.
Vous avez maintenant une connexion ODBC avec un serveur MySQL distant, et sécurisée avec SSH.
Cette section présente comment créer une sauvegarde de base de données, et comment assurer la maintenance des tables. La syntaxe des commandes SQL est décrite dans la section Section 13.5, « Référence de langage d'administration de la base de données ».
Comme les tables MySQL sont stockées sous forme de fichiers, il est facile d'en faire une sauvegarde. Pour avoir une sauvegarde consistante, faites un LOCK TABLES sur les tables concernées suivi d'un FLUSH TABLES pour celles-ci. Voyez Section 13.4.5, « Syntaxe de LOCK TABLES/UNLOCK TABLES » et Section 13.5.4.2, « Syntaxe de FLUSH ». Vous n'avez besoin que d'un verrou en lecture; cela permet aux autre threads de continuer à effectuer des requêtes sur les tables dont vous faites la copie des fichiers dans le dossier des bases de données. FLUSH TABLE est requise pour s'assurer que toutes les pages d'index actifs soient écrits sur le disque avant de commencer la sauvegarde.
Si vous voulez faire une sauvegarde d'une table avec SQL, vous pouvez utiliser SELECT INTO OUTFILE ou BACKUP TABLE. Voyez Section 13.1.7, « Syntaxe de SELECT » et Section 13.5.2.2, « Syntaxe de BACKUP TABLE ».
Une autre fa¸on de sauvegarder une base de données est d'utiliser l'utilitaire mysqldump ou le script mysqlhotcopy. Voyez Section 8.8, « mysqldump, sauvegarde des structures de tables et les données » et Section 8.9, « mysqlhotcopy, copier les bases et tables MySQL ».
-
Effectuez une sauvegarde complète de votre base de données :
shell>
mysqldump --tab=/chemin/vers/un/dossier --opt --allou
shell>
mysqlhotcopy base /chemin/vers/un/dossierVous pouvez aussi copier tout simplement tous les fichiers de tables (les fichiers
*.frm,*.MYD, et*.MYI) du moment que le serveur ne met rien à jour. Le scriptmysqlhotcopyutilise cette méthode. -
Arrêtez
mysqldsi il est en marche, puis démarrez le avec l'option--log-update[=nom_fichier]. See Section 5.9.3, « Le log de modification ». Le ou les fichiers de log fournissent les informations dont vous avez besoin pour répliquer les modifications de la base de données qui sont subséquents au moment où vous avez exécutémysqldump.
Si votre serveur MySQL est un esclave, quelque soit la sauvegarde que vous utilisez, lorsque vous sauvez vos données sur votre esclave, vous devez aussi sauver les fichiers master.info et relay-log.info, qui sont nécessaires pour relancer la réplication après la restauration des données de l'esclave. Si votre esclave doit traiter des commandes LOAD DATA INFILE, vous devez aussi sauver les fichiers nommés SQL_LOAD-*, qui sont dans le dossier spécifié par --slave-load-tmpdir. Ce dossier vaut par défaut la valeur de la variable tmpdir, si elle n'est pas spécifiée. L'esclave aura besoin de ces fichiers pour relancer la réplication d'une opération LOAD DATA INFILE interrompue.
Si vous avez besoin de restaurer quelque chose, essayez d'abord de restaurer vos tables avec REPAIR TABLE ou myisamchk -r en premier. Cela devrait fonctionner dans 99.9% des cas. Si myisamchk ne réussi pas, essayez la procédure suivante (cela ne fonctionnera que si vous avez démarré MySQL avec --log-update, Section 5.9.4, « Le log binaire ») :
-
Restaurez la sauvegarde originale de
mysqldump. -
Exécutez la commande suivante pour remettre en marche les mises à jour dans le log binaire :
shell>
mysqlbinlog hostname-bin.[0-9]* | mysqlDans votre cas, vous voudrez peut-être n'exécuter que certains logs binaires, depuis certaines positions : par exemple, depuis la date de la sauvegarde que vous avez restauré, hormis quelques requêtes problématiques. Voyez Section 8.5, «
mysqlbinlog, Exécuter des requêtes dans le log binaire » pour plus d'informations sur l'utilitairemysqlbinlog, et comment l'utiliser.Si vous utilisez le journal des mises à jour (qui a été supprimé en MySQL 5.0.0) vous pouvez utiliser :
shell>
ls -1 -t -r hostname.[0-9]* | xargs cat | mysql
ls est utilisée pour avoir tous les fichiers de mise à jour dans le bon ordre.
Vous pouvez aussi faire des sauvegardes sélectives de fichiers individuels :
-
Exportez la table avec
SELECT * INTO OUTFILE 'nom_fichier' FROM nom_de_table -
Restaurez avec
LOAD DATA INFILE 'nom_fichier' REPLACE .... Pour éviter les lignes dupliquées, vous aurez besoin d'unePRIMARY KEYou une clefUNIQUEdans la table. Le mot clefREPLACEfait que les anciens enregistrements sont remplacés par les nouveaux lorsque l'un d'eux duplique un ancien sur une valeur de clef unique.
Si vous obtenez des problèmes de performances sur votre système, vous pouvez les contourner en mettant en place une réplication et faisant les copies sur l'esclave au lieu du maître. See Section 6.1, « Introduction à la réplication ».
Si vous utilisez un système de fichiers Veritas , vous pourrez faire :
-
A partir d'un client (ou de Perl), exécutez :
FLUSH TABLES WITH READ LOCK. -
A partir d'un autre Shell, exécutez :
mount vxfs snapshot. -
Depuis le premier client, exécutez :
UNLOCK TABLES. -
Copiez les fichiers à partir de la sauvegarde.
-
Démontez snapshot.
Cette section présente une procédure pour effectuer des sauvegardes qui vous permettent de retrouver vos données après différents types de problèmes :
-
Arrêt du système d'exploitation
-
Problème d'alimentation électrique
-
Problème du système de fichiers
-
Problème matériel : disque dur, carte mère, etc.
Les instructions suivantes requièrent l'utilisation de la version minimale de MySQL 4.1.8, car certaines options de mysqldump utilisées ici ne sont pas disponibles dans les précédentes versions.
Les commandes d'exemples n'inclut pas les options telles que --user et --password avec les utilitaires mysqldump et mysql. Il vous faudra les ajouter en fonction des besoins, pour que MySQL puisse se connecter au serveur.
Nous considèrerons les données stockées dans une table de moteur InnoDB, qui supporte les transaction et la restauration automatique. Nous supposerons que le serveur MySQL est en charge au moment de la panne. Si ce n'est pas le cas, aucune restauration ne sera nécessaire.
Dans les cas de panne du système d'exploitation ou de l'alimentation électrique, on peut supposer que les disques de données MySQL sont toujours disponibles après un redémarrage. Les fichiers de données InnoDB sont analysés, et à partir des logs, on peut retrouver la liste des transactions archivées et non-archivées, qui n'ont pas encore été écrites sur le disque. Le moteur de table va alors annuler automatiquement les transactions qui n'ont pas été terminées. Le détail des opérations du processus de restauration est fourni à l'administrateur dans le fichier de log d'erreur de MySQL. Voici un extrait :
InnoDB: Database was not shut down normally. InnoDB: Starting recovery from log files... InnoDB: Starting log scan based on checkpoint at InnoDB: log sequence number 0 13674004 InnoDB: Doing recovery: scanned up to log sequence number 0 13739520 InnoDB: Doing recovery: scanned up to log sequence number 0 13805056 InnoDB: Doing recovery: scanned up to log sequence number 0 13870592 InnoDB: Doing recovery: scanned up to log sequence number 0 13936128 ... InnoDB: Doing recovery: scanned up to log sequence number 0 20555264 InnoDB: Doing recovery: scanned up to log sequence number 0 20620800 InnoDB: Doing recovery: scanned up to log sequence number 0 20664692 InnoDB: 1 uncommitted transaction(s) which must be rolled back InnoDB: Starting rollback of uncommitted transactions InnoDB: Rolling back trx no 16745 InnoDB: Rolling back of trx no 16745 completed InnoDB: Rollback of uncommitted transactions completed InnoDB: Starting an apply batch of log records to the database... InnoDB: Apply batch completed InnoDB: Started mysqld: ready for connections
Dans le cas d'une panne du système de fichiers ou du matériel, nous pouvons supposer que les données MySQL ne sont plus disponibles après le redémarrage. Cela signifie que MySQL ne pourra pas démarrer corerctement, car certains blocs de données ne seront plus lisibles. Dans ce cas, il est nécessaire de formatter le disque, d'en installer un nouveau ou bien de corriger le problème sous-jacent. Puis, il faut restaurer les données à partir des sauvegardes : cela signifie que nous devons avoir déjà fait des sauvegardes. Pour s'assurer que c'est le cas, voyons comment se déroule un processus de sauvegarde.
Nous savons tous que les sauvegardes doivent être programmées périodiquement. Les sauvegardes complètes, celles qui prélèvent toutes les données des bases, peuvent être réalisées avec plusieurs outils MySQL. Par exemple, InnoDB Hot Backup fournit un utilitaire de sauvegarde en ligne et non bloquant pour les fichiers InnoDB, et mysqldump fournit un outil de sauvegarde logique. Cette section utilise mysqldump.
Supposons que nous souhaitons réaliser une sauvegarde le dimanche, à une heure du matin, lorsque la charge sur le serveur est au plus bas. La commande suivante va faire une sauvegarde de toutes nos tables InnoDB, dans toutes les bases :
shell> mysqldump --single-transaction --all-databases > backup_sunday_1_PM.sql
C'est un outil de sauvegarde en ligne, non-bloquant, qui ne perturbe pas les opérations sur les tables. Nous avons supposé plus haut que nos tables utilisent le moteur InnoDB : l'option --single-transaction utilise une lecture cohérente, et garantit la stabilité des données prélevées par mysqldump. Les modifications peuvent être faîtes par d'autres clients sur les tables InnoDB sans que la commande mysqldump ne le per¸oive. Si nous avons d'autres types de tables, nous devons aussi supposer qu'elles ne changeront pas durant la sauvegarde. Par exemple, pour une table MyISAM dans la base mysql, nous devons supposer qu'aucun administrateur ne fera de modification aux comptes MySQL durant la sauvegarde.
Le fichier .sql résultant, produit par mysqldump contient les commandes SQL INSERT qui peuvent être utilisées pour recharger les tables ultérieurement.
Les sauvegardes complètes sont nécessaires, mais elles ne sont pas toujours pratiques. Elles produisent de très grands fichiers de données, et prennent du temps à s'exécuter. Elles ne sont pas optimales, car chaque sauvegarde inclut toutes les données, même celles qui n'ont pas évolué entre deux sauvegardes. Une fois qu'une sauvegarde initiale a été faite, les sauvegardes incrémentales sont bien plus optimales : elles génèrent des fichiers plus petits, et sont plus rapides à réaliser. L'inconvénient est que cette sauvegarde ne vous permettra pas de restaurer toutes vos données à partir de la sauvegarde complète : il vous faudra utiliser les sauvegardes incrémentales pour restaurer totalement votre base.
Pour réaliser des sauvegardes incrémentales, vous devez sauver les modifications incrémentales. Le serveur MySQL doit être lancé avec l'option --log-bin pour qu'il puisse stocker ces modifications au fur et à mesure des modifications des données. Cette option active le log binaire, ce qui fait que chaque commande qui modifie les données est enregistré dans un fichier appelé le log binaire. Voyons le dossier de données de MySQL, une fois qu'il a été lancé avec l'option --log-bin. Nous y trouverons les fichiers suivants :
-rw-rw---- 1 guilhem guilhem 1277324 Nov 10 23:59 gbichot2-bin.000001 -rw-rw---- 1 guilhem guilhem 4 Nov 10 23:59 gbichot2-bin.000002 -rw-rw---- 1 guilhem guilhem 79 Nov 11 11:06 gbichot2-bin.000003 -rw-rw---- 1 guilhem guilhem 508 Nov 11 11:08 gbichot2-bin.000004 -rw-rw---- 1 guilhem guilhem 220047446 Nov 12 16:47 gbichot2-bin.000005 -rw-rw---- 1 guilhem guilhem 998412 Nov 14 10:08 gbichot2-bin.000006 -rw-rw---- 1 guilhem guilhem 361 Nov 14 10:07 gbichot2-bin.index
A chaque fois que le serveur redémarre, MySQL crée un nouveau fichier de log binaires, en utilisant le numéro de séquence suivant. Lorsque le serveur fonctionne, vous pouvez aussi lui dire de clore le fichier de log, et d'en ouvrir un nouveau avec la commande SQL FLUSH LOGS ou bien avec la commande en ligne mysqladmin flush-logs. La commande mysqldump dispose aussi d'une option pour clore les fichiers de logs. Le fichier .index contient la liste de tous les fichiers de logs binaire du dossier de données. Ce fichier est utilisé durant les opérations de réplication.
Les fichiers de log binaires MySQL sont importants lors de restauration, car ils représentent des sauvegardes incrémentales. Si vous vous assurez de bien refermer les fichiers de log binaire lorsque vous réalisez une sauvegarde complète, alors les fichiers de log binaires qui ont été créés après votre sauvegarde représente les modifications incrémentales de vos données. Maintenant, modifions la commande mysqldump pour qu'elle referme les logs binaires lors de sauvegarde complète, et que le fichier de sauvegarde contienne les noms des nouveaux fichiers de logs :
shell> mysqldump --single-transaction --flush-logs --master-data=2
--all-databases > backup_sunday_1_PM.sql
Après avoir exécuté cette commande, le dossier de données contient un nouveau fichier de log binaire, gbichot2-bin.000007. Le fichier .sql résultant contient les lignes suivantes :
-- Position to start replication or point-in-time recovery from -- CHANGE MASTER TO MASTER_LOG_FILE='gbichot2-bin.000007',MASTER_LOG_POS=4;
Comme la commande mysqldump a fait une sauvegarde complète, ces lignes signifie deux choses :
-
Le fichier
.sqlcontient toutes les modifications effectuées sur les données avant le fichier appelégbichot2-bin.000007, ou plus récent. -
Toutes les modifications des données effectées après la sauvegarde ne sont pas enregistrées dans le fichier
.sql, mais sont présentes dans le fichier de log binairegbichot2-bin.000007.
Le lundi, à une heure du matin, nous pouvons créer une sauvegarde incrémentale en refermant les fichiers de log binaire, et en créant un nouveau fichier de log. Par exemple, la commande mysqladmin flush-logs crée un fichier gbichot2-bin.000008. Toutes les modifications qui ont eu lieu entre dimanche, 1 heure et lundi, 1 heure sont stockées dans le fichier gbichot2-bin.000007. Cette sauvegarde incrémentale est importante, et il est recommandé de la stocker dans un endroit sûr. Par exemple, copiez la sur une cassette ou un DVD, ou même sur une autre machine. Le mardi, à 1 heure, vous pouvez exécuter à nouveau la commande mysqladmin flush-logs. Toutes les opérations effectuées entre lundi, 1 heure et mardi, 1 heure sont dans le fichier gbichot2-bin.000008, qui doit être mis en sécurité.
Les logs binaires MySQL occupent de l'espace disque sur le serveur. Pour récupérer cet espace, supprimez-le de temps en temps. Pour le faire en toute sécurité, supprimez simplement les fichiers qui ne servent plus à rien, c'est à dire ceux qui sont antérieurs à la dernière sauvegarde complète :
shell> mysqldump --single-transaction --flush-logs --master-data=2
--all-databases --delete-master-logs > backup_sunday_1_PM.sql
Note : effacer les logs binaires avec la commande mysqldump --delete-master-logs peut être dangereux, car si le serveur est un maître de réplication, les esclaves pourraient ne pas avoir traités en totalité le contenu des logs binaires.
La description de la commande PURGE MASTER LOGS explique ce qui doit être vérifié avant d'effacer un fichier de log binaire. See Section 13.6.1.1, « PURGE MASTER LOGS ».
Supposons maintenant qu'un crash catastrophique survienne le mercredi à 8 heures du matin, et qu'il faille utiliser les sauvegardes pour restaurer la base de données. Pour cela, il faut commencer par utiliser la première sauvegarde complète que nous avons : c'est celle de samedi, à 1 heure. Cette sauvegarde est un ensemble de commandes SQL : la restauration est très simple :
shell> mysql < backup_sunday_1_PM.sql
Après cela, les données sont celles que nous avions dimanche, à 1 heure. Pour appliquer les modifications qui ont eu lieu depuis cette date, nous devons utiliser les sauvegardes incrémentales, c'est à dire les fichiers de log binaire gbichot2-bin.000007 et gbichot2-bin.000008. Retrouvez-les dans vos documents de sauvegarde, puis, exécutez-les de cette manière :
shell> mysqlbinlog gbichot2-bin.000007 gbichot2-bin.000008 | mysql
Nous avons maintenant retrouvé les données dans leur état de mardi, à 1 heure, mais il manque encore les données entre cette date et le crash. Pour ne pas les avoir perdu, il faut que les logs aient été sauvés dans un volume sécurisé (disque RAID, SAN, ...), sur un serveur différent de celui qui a crashé : tout cela pour que le serveur n'ait pas détruit les logs durant le crash. Pour cela, nous pouvons lancer le serveur avec l'option --log-bin, et spécifier un chemin sur un volume physique séparé. De cette manière, les logs ne seront pas perdus, même si le dossier contenant les données est perdu. Si nous pouvons retrouver ces fichiers de log, nous aurons un fichier appelé gbichot2-bin.000009 et nous pouvons l'appliquer aux données pour obtenir l'état le plus proche du moment du crash.
Dans le cas d'un arrêt du système d'exploitation ou d'une panne de courant, InnoDB se charge lui-même du travail de restauration des données. Mais pour vous assurer un sommeil sans cauchemar, nous vous recommandons de suivre ces instructions :
-
Utilisez toujours MySQL avec l'option
--log-bin, ou même avec--log-bin=, où le fichier est placé sur un média sécuritaire, différent de celui sur lequel fonctionne le dossier de données. SI vous avez un tel lieu de stockage, c'est aussi bon pour l'équilibrage de la charge du disque, ce qui conduit a des améliorations de performances.log_name -
Faîtes des sauvegardes periodiques, en utilisant la commande mysqldump pour réaliser des sauvegardes non-bloquantes.
-
Faites des sauvegardes incrémentales périodiques, en vidant les logs sur le disque, avec la commande SQL
FLUSH LOGSou la commande en ligne mysqladmin flush-logs.
- 5.7.3.1. Syntaxe de l'utilitaire
myisamchk - 5.7.3.2. Options générales de
myisamchk - 5.7.3.3. Options de vérifications pour
myisamchk - 5.7.3.4. Options de réparation de
myisamchk - 5.7.3.5. Autres options de
myisamchk - 5.7.3.6. Utilisation de la mémoire par
myisamchk - 5.7.3.7. Utiliser
myisamchkpour restaurer une table - 5.7.3.8. Comment vérifier la cohérence d'une table
- 5.7.3.9. Comment réparer des tables
- 5.7.3.10. Optimisation de table
La section suivante discute de l'utilisation de myisamchk pour vérifier et réparer les tables MyISAM (les tables avec les fichiers .MYI et .MYD). Les mêmes concepts s'appliquent à isamchk pour vérifier et réparer les tables ISAM (les tables avec les fichiers .ISM et .ISD). See Chapitre 14, Moteurs de tables MySQL et types de table.
Vous pouvez utiliser myisamchk pour obtenir des informations sur les tables de votre base de données, pour analyser, réparer ou optimiser ces tables. Les sections suivantes décrivent comment appeler myisamchk (y compris les options), comment mettre en place une politique d'entretien, et comment utiliser myisamchk pour effectuer différentes opérations.
Même si la réparation d'une table avec myisamchk est sécuritaire, il est toujours préférable de faire une sauvegarde avant la réparation, ou toute autre opération de maintenance qui pourrait faire de nombreuses modifications dans la table.
Les opérations myisamchk qui affectent les index peuvent causer la recompilation des index FULLTEXT avec des paramètres qui ne sont pas les paramètres courants du serveur. Pour éviter cela, voyez la section Section 5.7.3.2, « Options générales de myisamchk ».
Dans de nombreux cas, vous pouvez trouver plus simple de faire l'entretien des tables avec des requêtes SQL qu'avec myisamchk :
-
Pour vérifier ou réparer les tables
MyISAM, utilisezCHECK TABLEouREPAIR TABLE. -
Pour optimiser les tables
MyISAM, utilisezOPTIMIZE TABLE. -
Pour analyser les tables
MyISAM, utilisezANALYZE TABLE.
Ces commandes ont été ajoutées dans différentes versions, mais sont toutes disponibles depuis MySQL 3.23.14. Voyez Section 13.5.2.1, « Syntaxe de ANALYZE TABLE », Section 13.5.2.3, « Syntaxe de CHECK TABLE », Section 13.5.2.5, « Syntaxe de OPTIMIZE TABLE », et Section 13.5.2.6, « Syntaxe de REPAIR TABLE ».
Les commandes peuvent être utilisées directement, ou via le client mysqlcheck, qui fournit une interface en ligne de commande.
Un avantage de ces commandes par rapport à myisamchk est que le serveur se charge de tout. Avec myisamchk, vous devez vous assurer que le serveur ne va pas utiliser les tables en même temps que vous. Sinon, il va y avoir des interférences entre myisamchk et le serveur.
myisamchk s'exécute avec une commande de la forme :
shell> myisamchk [options] tbl_name
Les options spécifient ce que vous voulez que myisamchk fasse. Elles sont décrites dans ce chapitre. Vous pouvez aussi obtenir une liste d'options en invoquant le programme avec myisamchk --help. Sans option, myisamchk va simplement vérifier les tables. Pour obtenir plus d'information ou pour demander à myisamchk de prendre des mesures correctives, il faut ajouter l'une des options listées ici.
tbl_name est la table que vous voulez réparer ou vérifier. Si vous exécutez myisamchk autre part que dans le dossier de données, vous devez spécifier le chemin jusqu'au fichier, car sinon, myisamchk n'aura aucune idée d'où chercher les données dans votre base. En fait, myisamchk ne se préoccupe pas du fait que le fichier que vous utilisez est dans le dossier de base ou pas : vous pouvez copier le fichier à réparer dans un autre dossier, et y faire les opérations d'entretien.
Vous pouvez spécifier plusieurs noms de tables à myisamchk si vous le voulez. Vous pouvez aussi spécifier un nom sous la forme d'un fichier d'index (avec l'option .MYI), qui vous permettra de spécifier toutes les tables dans un dossier en utilisant le schéma *.MYI. Par exemple, si vous êtes dans le dossier de données, vous pouvez spécifier toutes les tables dans le dossier comme ceci :
shell> myisamchk *.MYI
Si vous n'êtes pas dans le dossier de données, et que vous souhaitez vérifier toutes les tables, vous devez ajouter le chemin jusqu'au dossier :
shell> myisamchk /path/to/database_dir/*.MYI
Vous pouvez même vérifier toutes les tables de toutes les bases avec le chemin suivant :
shell> myisamchk /path/to/datadir/*/*.MYI
La méthode recommandée pour vérifier rapidement toutes les tables est :
myisamchk --silent --fast /path/to/datadir/*/*.MYI isamchk --silent /path/to/datadir/*/*.ISM
Si vous voulez vérifier toutes les tables et réparer celles qui sont corrompues, vous pouvez utiliser la ligne suivante :
myisamchk --silent --force --fast --update-state -O key_buffer=64M \
-O sort_buffer=64M -O read_buffer=1M -O write_buffer=1M \
/path/to/datadir/*/*.MYI
isamchk --silent --force -O key_buffer=64M -O sort_buffer=64M \
-O read_buffer=1M -O write_buffer=1M /path/to/datadir/*/*.ISM
Ces commandes ci-dessus supposent que vous avez plus de 64 Mo de libres. Pour plus d'informations sur l'allocation de mémoire avec myisamchk, voyez la section Section 5.7.3.6, « Utilisation de la mémoire par myisamchk ».
Notez que si vous obtenez une erreur comme celle-ci :
myisamchk: warning: 1 clients is using or hasn't closed the table properly
Cela signifie que vous essayez de vérifier une table qui a été modifiée par un autre programme (comme le serveur mysqld) qui n'a pas encore refermé le fichier de table, ou que le fichier n'a pas été correctement refermé.
Si mysqld fonctionne, vous devez forcer la fermeture correcte des fichiers de tables avec la commande FLUSH TABLES, et vous assurer que personne n'utilise les tables durant vos opérations avec myisamchk. En MySQL version 3.23, la meilleure méthode pour éviter ce problème est d'utiliser la commande CHECK TABLE au lieu de myisamchk pour vérifier les tables.
Les options décrites dans cette section peuvent être utilisées pour toutes les maintenances de tables effectuée myisamchk. Les sections suivant celles-ci décrivent les options spécifiques à certaines opérations, comme la vérification et la réparation.
myisamchk supporte les options suivantes :
-
--help, -?Affiche le message d'aide, et termine le programme.
-
--debug=debug_options, -# debug_optionsAffiche le log de débogage. La chaîne
debug_optionsvaut souvent :'d:t:o,filename'. -
--silent, -sMode silencieux. Affiche uniquement les erreurs. Vous pouvez utiliser deux fois
-s(-ss) pour quemyisamchksoit très silencieux. -
--verbose, -vMode détaillé. Affiche plus d'informations. Vous pouvez combiner ce mode avec les options
-det-e. Utilisez-vplusieurs fois, (-vv,-vvv) pour plus de détails encore. -
--version, -VAffiche la version et quitte.
-
--wait, -wAu lieu de s'arrêter avec une erreur si la table est verrouillé, le programme attend que la table soit libérée avant de continuer. Notez que si vous utilisez
mysqldavec l'option--skip-external-locking, la table peut ne peut être verrouillée que par une autre commandemyisamchk.
Vous pouvez aussi configurer les variables suivantes avec la syntaxe --var_name=value :
| Variable | Valeur par défaut |
decode_bits |
9 |
ft_max_word_len |
dépend de la version |
ft_min_word_len |
4 |
ft_stopword_file |
liste par défaut |
key_buffer_size |
523264 |
myisam_block_size |
1024 |
read_buffer_size |
262136 |
sort_buffer_size |
2097144 |
sort_key_blocks |
16 |
write_buffer_size |
262136 |
Il est aussi possible de configurer les variables avec les syntaxes --set-variable=var_name=value et -O var_name=value. Toutefois, cette syntaxe est obsolète depuis MySQL 4.0.
Les variables myisamchk possibles et leur valeur par défaut sont affichées par myisamchk --help :
sort_buffer_size sert lors de la réparation des index par tri des clés, qui est le mode utilisé par l'option --recover.
key_buffer_size sert lorsque vous vérifiez une table avec l'option --extend-check ou lorsque les clés sont réparées par insertion de lignes dans la table (comme lors des insertions normales). La réparation par buffer de clés est utilisée dans ces situations :
-
Vous utiliez l'option
--safe-recover. -
Les fichiers temporaires utilisés pour trier les clés seraient deux fois plus gros que lors de la création directe du fichier. C'est souvent le cas lorsque vous avez de grandes clés pour les colonnes
CHAR,VARCHARetTEXT, car l'opération de trie a besoin de stocker la clé complète. Si vous avez beaucoup d'espace temporaire, vous pouvez forcermyisamchkà réparer en triant, en utilisant l'option--sort-recover.
La répartion par buffer de clé prend beaucoup moins d'espace disque, mais est bien plus lente.
Si vous voulez une réparation plus rapide, donnez à key_buffer_size et sort_buffer_size des valeurs représentant 25% de votre mémoire. Vous pouvez leur donner de grandes valeurs, car une seule des deux variables est utilisée.
myisam_block_size est la taille des blocs d'index. Elle est disponible depuis MySQL 4.0.0.
Les variables ft_min_word_len et ft_max_word_len sont disponibles depuis MySQL 4.0.0. ft_stopword_file est disponible depuis MySQL 4.0.19.
ft_min_word_len et ft_max_word_len indique la taille minimum et maximum pour les index FULLTEXT. ft_stopword_file est le nom du fichier de mots ignorés. Ils doivent toujours être configurés.
Si vous utilisez myisamchk pour faire une opération qui modifie les index de tables (comme la répartion ou l'analyse), les index FULLTEXT sont reconstruit en utilisant les valeurs par défaut pour les tailles minimales et maximales, et pour le fichier de mots ignorés. Cela peut conduire à l'échec de requêtes.
Le problème survient lorsque ces paramètre ne sont connus que par le serveur. Elles ne sont pas stockées dans le fichier d'index MyISAM. Pour éviter ce problème si vous avez modifié la taille des mots ou le fichier de mots ignorés dans le serveur, pensez à spécifier les mêmes valeurs avec les options ft_min_word_len, ft_max_word_len et ft_stopword_file de myisamchk. Par exemple, si vous avez configuré une taille minimale de 3, vous pourrez réparer la table avec myisamchk comme ceci :
shell> myisamchk --recover --ft_min_word_len=3 tbl_name.MYI
Pour vous assurer que myisamchk et le serveur utilisent les mêmes valeurs pour les paramètres des index en texte plein, vous pouvez placez ces valeurs dans les groupes [mysqld] et [myisamchk] du fichier d'options :
[mysqld] ft_min_word_len=3 [myisamchk] ft_min_word_len=3
Une alternative à l'utilisation de myisamchk est les commandes REPAIR TABLE, ANALYZE TABLE, OPTIMIZE TABLE et ALTER TABLE. Ces commandes sont effectuées par le serveur, qui sait comment traiter les paramétrages des index.
-
-c, --checkVérifie les erreurs d'une table. Ceci est l'opération par défaut de
myisamchksi vous ne lui donnez aucune autre option. -
-e, --extend-checkVérifie la table minutieusement (ce qui est un peu lent si vous avez des index). Cette option ne doit être utilisée que pour les cas extrêmes. Normalement,
myisamchkoumyisamchk --medium-checkdevrait, dans la plupart des cas, être capable de trouver s'il y a des erreurs dans la table.Si vous utilisez
--extended-checket que vous avez beaucoup de mémoire, vous devez augmenter de beaucoup la valeur dekey_buffer_size! -
-F, --fastNe vérifie que les tables qui n'ont pas été fermées proprement.
-
-C, --check-only-changedNe vérifie que les tables qui ont changé depuis la dernière vérification.
-
-f, --forceRedémarrez
myisamchkavec-r(répare) sur la table, simyisamchktrouve une erreur dans la table. -
-i, --informationAffiche des statistiques à propos de la table vérifiée.
-
-m, --medium-checkPlus rapide que
--extended-check, mais ne trouve que 99.99% des erreurs. Devrait, cependant, être bon pour la plupart des cas. -
-U, --update-stateEnregistre le fichier
.MYIlorsque la table à été vérifiée ou a été corrompue. Cela devrait être utilisé pour tirer tous les avantages de l'option--check-only-changed, mais vous ne devez pas utiliser cette option si le serveurmysqldutilise cette table et que vous utilisezmysqldavec--skip-external-locking. -
-T, --read-onlyNe marque pas la table comme vérifiée. C'est pratique si vous utilisez
myisamchkpour vérifier une table issue d'une autre application qui n'utilise pas les verrous. (commemysqld --skip-external-locking).
Les options suivantes sont utilisées avec myisamchk et l'option de réparation -r ou -o:
-
--backup, -BFait une sauvegarde du fichier
.MYD, sous le nomfilename-time.BAK -
--character-sets-dir=pathDossier qui contient les jeux de caractères. See Section 5.8.1, « Le jeu de caractères utilisé pour les données et le stockage ».
-
--correct-checksumSomme de contrôle correcte pour la table.
-
--data-file-length=#, -D #Taille maximale du fichier de données (lors de la recréation du fichier de données, et qu'il est complet).
-
--extend-check, -eEssaie de retrouver toutes les lignes possibles du fichier de données. Normalement, cette option va aussi découvrir beaucoup de lignes erronées. N'utilisez pas cette option si vous n'êtes pas totalement désespérés.
-
--force, -fEcrase les anciens fichiers temporaires (
table_name.TMD) au lieu d'annuler. -
--keys-used=#, -k #Si vous utilisez les tables
ISAM, indique au gestionnaire de tableISAMqu'il doit uniquement modifier les#premiers index. Si vous utilisez le gestionnaire de tableMyISAM, cette option indique quelles clés utiliser, et chaque bit binaire représente une clé (la première clé est le bit 0). Cela permet de réaliser des insertions plus rapides. Les index désactivés pourront être réactivés avec l'optionmyisamchk -r. -
--no-symlinks, -lNe pas suivre les lignes symboliques. Normalement,
myisamchkrépare les tables qu'un lien symbolique représente. Cette option n'existe pas en MySQL 4.0, car MySQL 4.0 ne va pas supprimer les liens symboliques durant la réparation. -
--parallel-recover, -pUtilise la même technique que
-ret-n, mais crée les clés avec des threads différents, en parallèle. Cette option a été ajoutée en MySQL 4.0.2. Ceci est du code alpha. Utilisez le à vos risques et périls! -
--quick, -qRéparation rapide, sans modifier le fichier de données. Il est possible d'ajouter l'option
-qpour forcermyisamchkà modifier le fichier original en cas de clés doublons. -
--recover, -rPeut réparer presque tout, sauf les clés uniques qui ne le sont plus (ce qui est extrêmement rare avec les tables
ISAM/MyISAM). Si vous voulez restaurer un table, c'est l'option à utiliser en premier. Simyisamchkindique que la table ne peut pas être corrigée avec l'option-r, vous pouvez alors passer à l'option-o. Notez que dans le cas rarissime où-r, le fichier de données est toujours intact. Si vous avez beaucoup de mémoire, vous pouvez augmenter la taille du buffersort_buffer_size! -
--safe-recover, -oUtilise une ancienne méthode de restauration (lit toutes les lignes dans l'ordre, et modifie l'arbre d'index conformément pour les lignes trouvées). C'est une méthode qui est beaucoup plus lente que l'option
-r, mais elle est capable de traiter certaines situations exceptionnelles que-rne pourrait pas traiter. Cette méthode utilise aussi moins d'espace disque que-r. Normalement, vous devriez commencer à réparer avec l'option-r, et uniquement sur l'échec de cette option, passer à-o.Si vous avez beaucoup de mémoire, vous devriez augmenter la taille du buffer de clé !
key_buffer_size! -
--set-character-set=nameChange le jeu de caractères utilisé par l'index.
-
--sort-recover, -nForce
myisamchkà utiliser le tri pour résoudre les clés, même si le fichier temporaire doit être énorme. -
--tmpdir=path, -t pathChemin pour stocker les fichiers temporaires. Si cette option n'est pas fournie,
myisamchkva utiliser la variable d'environnementTMPDIRpour cela. Depuis MySQL 4.1,tmpdirpeut prendre une liste de chemins différents, qui seront utilisés successivement, pour les fichiers temporaires. Le caractère de séparation des différents chemins est le deux-points sous Unix (‘:’) et le point-virgule (‘;’) sous Windows, NetWare et OS/2. -
--unpack, -uDécompresse des données compressées avec
myisampack.
Les autres actions que myisamchk peut réaliser, en dehors de vérifier et réparer une table sont :
-
-a, --analyzeAnalyser la distribution des clés. Cela améliore les performances des jointures en permettant à l'optimiseur de jointure de mieux choisir l'ordre d'utilisation des clés.
myisamchk --describe --verbose table_name'ouSHOW KEYSdans MySQL. -
-d, --descriptionAffiche des informations sur la table.
-
-A, --set-auto-increment[=value]Force
AUTO_INCREMENTà commencer avec une valeur supérieure. Si aucune valeur n'est fournie, la prochaine valeur de la colonneAUTO_INCREMENTsera la plus grande valeur de la colonne +1. -
-S, --sort-indexTrie les blocs de l'arbre d'index dans l'ordre haut / bas. Cela va optimiser les recherches, et les scans de tables par clés.
-
-R, --sort-records=#Trie les lignes en fonction de l'index. Cela rassemble vos données, et peut accélérer les lectures de lignes par intervalle avec
SELECTetORDER BYsur cet index (ce tri peut être très lent la première fois). Pour connaître les numéros d'index de tables, utilisez la commandeSHOW INDEX, qui affiche les index dans le même ordre quemyisamchkne les voit. Les index sont numérotés à partir de 1.
L'espace mémoire est très important quand vous utilisez myisamchk. myisamchk n'utilise pas plus de mémoire que ce que vous spécifiez avec les options -O. Si vous pensez utiliser myisamchk sur des fichiers très grands, vous devez d'abord décider la quantité de mémoire que vous souhaitez utiliser. Avec des valeurs plus grandes, vous pouvez accélérer myisamchk. Par exemple, si vous avez plus de 32 Mo de RAM, vous pourriez utiliser les options suivantes (en plus des autres options que vous pourriez spécifier) :
shell> myisamchk -O sort=16M -O key=16M -O read=1M -O write=1M ...
Utiliser -O sort=16M sera probablement suffisant pour la plupart des cas.
Soyez conscient que myisamchk utilise des fichiers temporaires dans le dossier TMPDIR. Si TMPDIR est un fichier en mémoire, vous pourriez facilement rencontrer des erreurs de mémoire. Si cela arrive, choisissez une autre valeur pour TMPDIR, avec plus d'espace disque, et redémarrez myisamchk.
Lors de la réparation, myisamchk va aussi avoir besoin d'espace disque :
-
Doublez la taille du fichier de données (l'original plus une copie). Cet espace n'est pas nécessaire si vous faites des réparations de type
--quick, car dans ce cas, seul le fichier d'index sera recréé. Cet espace est nécessaire sur le même disque que l'original ! -
De l'espace pour le nouveau fichier d'index qui remplacera l'ancien. L'ancien fichier d'index est réduit dès le démarrage, ce qui vous permet généralement d'ignorer cet espace. Cet espace est nécessaire sur le même disque que l'original !
-
Lorsque vous utilisez les options
--recoverou--sort-recover(mais pas lorsque vous utilisez--safe-recover), vous aurez besoin d'espace pour le buffer de tri :(plus_grande_cle + taille_du_pointeur_de_ligne)*nombre_de_lignes * 2
Vous pouvez vérifier la taille des clés et la taille du pointeur de ligne avec la commande
myisamchk -dv table. Cet espace est alloué sur le disque temporaire (spécifié parTMPDIRpar--tmpdir=#).
Si vous avez des problèmes avec l'espace disque durant la réparation, vous pouvez utiliser l'option --safe-recover au lieu de --recover.
Si vous utilisez mysqld avec l'option --skip-external-locking (qui est la configuration par défaut pour certains systèmes, comme Linux), vous ne pouvez pas utiliser myisamchk pour vérifier une table, lorsque mysqld utilise aussi la table. Si vous pouvez être sûr que personne n'utilise cette table via mysqld lorsque vous utilisez myisamchk, vous n'aurez qu'à utiliser la commande mysqladmin flush-tables avant de commencer à vérifier les tables. Si vous ne pouvez pas garantir cette condition, vous devez alors éteindre le serveur mysqld pour vérifier les tables. Si vous exécutez myisamchk alors que mysqld modifie la table, vous pourriez obtenir un diagnostic de corruption de la table, alors que ce n'est pas le cas.
Si vous n'utilisez pas l'option --skip-external-locking, vous pouvez vous servir de myisamchk pour vérifier les tables à tout moment. Pendant que vous le faites, les autres clients qui tentent de modifier la table devront attendre que myisamchk ait fini.
Si vous utilisez myisamchk pour réparer ou optimiser les tables, vous devez toujours vous assurer que mysqld n'utilise pas cette table (ce qui s'applique aussi si vous utilisez --skip-external-locking). Si vous n'éteignez pas le serveur mysqld, vous devez au moins utiliser mysqladmin flush-tables avant de lancer myisamchk. Vos tables peuvent être corrompues si le serveur et myisamchk travaillent dans une même table simultanément.
Ce chapitre décrit comment vérifier et gérer les corruptions de données dans les bases MySQL. Si vos tables sont fréquemment corrompues, vous devriez commencer par en rechercher la raison ! See Section A.4.2, « Que faire si MySQL plante constamment ? ».
La section sur les tables MyISAM contient différentes raisons pour lesquelles une table peut être corrompue. See Section 14.1.4, « Problèmes avec les tables MyISAM ».
Lorsque vous effectuez une restauration de table, il est important que chaque table tbl_name dans une base corresponde aux trois fichiers dans le dossier de base, du dossier de données :
| Fichier | Utilisation |
tbl_name.frm |
Définition de la table |
tbl_name.MYD |
Fichier de données |
tbl_name.MYI |
Fichier d'index |
Chacun de ces trois fichiers est sujet à des corruptions diverses, mais les problèmes surviennent généralement dans les fichiers de données ou d'index.
myisamchk fonctionne en créant une copie du fichier .MYD (les données), ligne par ligne. Il termine sa réparation en supprimant l'ancien fichier .MYD et en renommant le nouveau à la place de l'ancien. Si vous utilisez l'option --quick, myisamchk ne crée pas de fichier temporaire .MYD mais suppose plutôt que le fichier .MYD est correct et il génère simplement un nouveau fichier d'index sans toucher au fichier .MYD. C'est une méthode sécuritaire, car myisamchk va automatiquement détecter si le fichier .MYD est corrompu, et annulera alors la réparation si c'est le cas. Vous pouvez aussi ajouter deux options --quick à myisamchk. Dans ce cas, myisamchk ne s'interrompt pas sur certaines erreurs (comme des clés doublons), et essaie de résoudre ce problème en modifiant le fichier .MYD. Normalement, l'utilisation de deux options --quick n'est utile que si vous n'avez pas trop d'espace disque pour réaliser la réparation. Dans ce cas, vous devez au moins faire une copie de sauvegarde avant d'utiliser myisamchk.
Pour vérifier les tables de type MyISAM, utilisez les commandes suivantes :
-
myisamchk nom_de_tableCette commande trouvera 99.99% de toutes les erreurs. Ce qu'elle ne peut pas découvrir comme erreurs, sont celles qui impliquent uniquement le fichier de données (ce qui est très inhabituel). Si vous voulez vérifier une table, vous devriez utiliser l'utilitaire
myisamchksans les options ou avec les options-sou--silent. -
myisamchk -m nom_de_tableCette commande trouvera 99.999% de toutes les erreurs. Elle vérifie toutes les entrées dans le fichier d'index, puis lit toutes les lignes. Elle calcule une somme de contrôle pour toutes les clés et les lignes, et vérifie que les deux se correspondent dans l'arbre d'index.
-
myisamchk -e nom_de_tableCette commande fait une vérification complète et exhaustive de toutes les données (
-esignifie ``extended check''). Elle fait une lecture de contrôle de chaque ligne, pour vérifier qu'elle correspond bien aux index. Cette commande va prendre un long moment sur les grosses tables.myisamchkva normalement s'arrêter dès qu'il trouve une erreur. Si vous voulez obtenir plus d'information sur cette erreur, vous pouvez utiliser l'option--verbose(ou-v). Cela fera quemyisamchkva continuer à travailler et accumuler jusqu'à 20 erreurs. En utilisation normale, l'utilisation de cet utilitaire sans options est suffisante. -
myisamchk -e -i nom_de_tableComme les commandes précédentes, mais l'option
-iindique àmyisamchkqu'il doit afficher des informations statistiques.
Dans la section présente, nous allons uniquement parler de l'utilitaire myisamchk sur les tables MyISAM (extensions .MYI et .MYD). Si vous utilisez les tables ISAM (extensions .ISM et .ISD), vous devriez vous servir de isamchk à la place.
Depuis MySQL version 3.23.14, vous pouvez réparer les tables MyISAM avec la commande SQL REPAIR TABLE. See Section 13.5.2.6, « Syntaxe de REPAIR TABLE ».
Les symptômes de corruption de tables sont des requêtes qui s'interrompent inopinément :
-
tbl_name.frm locked against change:tbl_name.frmest verrouillée en écriture -
Can't find file tbl_name.MYI (Errcode: ###): Impossible de trouver le fichiertbl_name.MYI(Errcode: ###) -
Unexpected end of file: Fin de fichier inattendue -
Record file is crashed: Fichier de données crashé -
Got error ### from table handler: Reception de l'erreur ### de la part du gestionnaire de tablePour obtenir plus d'informations sur l'erreur, vous pouvez exécuter la commande
perror ###. Voici les erreurs les plus courantes :shell>
perror 126 127 132 134 135 136 141 144 145126 = Index file is crashed / Wrong file format : le fichier d'index est corrompu / le format du fichier est incorrect. 127 = Record-file is crashed : le fichier de données est corrompu. 132 = Old database file / ce fichier provient d'une vieille base de données. 134 = Record was already deleted (or record file crashed) / La ligne était déjà effacée. 135 = No more room in record file / Plus de place dans le fichier de données. 136 = No more room in index file / Plus de place dans le fichier d'index. 141 = Duplicate unique key or constraint on write or update / Doublon pour une clé unique trouvé durant la lecture ou l'écriture. 144 = Table is crashed and last repair failed / la table est corrompue et la dernière réparation a échoué. 145 = Table was marked as crashed and should be repaired / La table a été marquée comme corrompue et doit être réparée.Notez que l'erreur 135, "no more room in record file", n'est pas une erreur qui sera facile à corriger. Dans ce cas, vous devez utiliser la commande suivante :
ALTER TABLE table MAX_ROWS=xxx AVG_ROW_LENGTH=yyy;
Dans d'autres cas, vous devrez réparer vos tables. myisamchk peut généralement détecter et corriger la plupart des erreurs.
Le processus de réparation se déroule en 4 étapes décrites ici. Avant de vous lancer, vous devriez vous placer dans le dossier de données et vérifier les permissions des fichiers de données. Assurez-vous qu'ils sont bien lisibles par l'utilisateur Unix que MySQL utilise (et à vous aussi, car vous aurez besoin d'accéder à ces fichiers durant la vérification. Si vous devez corriger ces fichiers, vous aurez aussi besoin des droits d'écriture.
Si vous utilisez MySQL version 3.23.16 et plus récent, vous pouvez (et vous devriez) utiliser les commandes CHECK et REPAIR pour réparer vos tables MyISAM. Voyez Section 13.5.2.3, « Syntaxe de CHECK TABLE » et Section 13.5.2.6, « Syntaxe de REPAIR TABLE ».
La section du manuel sur l'entretien des tables inclut la présentation des options des utilitaires isamchk/myisamchk : Section 5.7.3, « Utilisation de myisamchk pour la maintenance des tables et leur recouvrement ».
La section suivante est destinée aux cas où les commandes ci-dessus ont échoué ou que vous voulez exploiter les fonctionnalités avancées que isamchk/myisamchk proposent.
Si vous allez réparer une table en ligne de commande, il est recommandé d'arrêter le serveur mysqld. Notez que lorsque vous exécutez une commande mysqladmin shutdown sur un serveur distant, le serveur mysqld sera encore opérationnel pendant un instant après que mysqladmin ait terminé, jusqu'à ce que toutes les requêtes et toutes les clés aient été écrites sur le disque.
Etape 1 : Vérifier vos tables
Exécutez la commande myisamchk *.MYI ou myisamchk -e *.MYI si vous avez plus de temps. Utilisez -s (silencieux) pour supprimer les informations peu pertinentes.
Si le serveur mysqld a terminé, vous devriez utiliser l'option --update pour indiquer à myisamchk d'enregistrer la vérification des tables ('checked').
Vous n'aurez à réparer que les tables pour lesquelles myisamchk vous annonce une erreur. Pour de telles tables, passez à l'étape 2.
Si vous obtenez des erreurs étranges lors de la vérification, (comme, l'erreur out of memory), ou si myisamchk crashe, passez à l'étape 3.
Etape 2 : réparation simple et facile
Note : Si vous voulez réparer très rapidement, vous devriez ajouter -O sort_buffer=# -O key_buffer=# (où # vaut environ le quart de la mémoire du serveur), à toutes les commandes isamchk/myisamchk.
Premièrement, essayez myisamchk -r -q tbl_name (-r -q signifie ``mode de réparation rapide''). Cette commande va tenter de réparer le fichier d'index sans toucher au fichier de données. Si le fichier de données contient toutess les données qu'il est sensé contenir, et que les points d'ancrage pour les effacements sont corrects, cette commande doit réussir, et la table sera alors réparée. Passez alors à la table suivante. Sinon, suivez la procédure suivante :
-
Faites une copie de sauvegarde de votre fichier de données.
-
Utilisez la commande
myisamchk -r tbl_name(-rsignifie ``mode de réparation''). Cette commande va supprimer les lignes invalides et effacer ces lignes du fichier de données, puis reconstruire le fichier d'index. -
Si l'instruction précédente a échoué, utilisez
myisamchk --safe-recover tbl_name. Le mode restauration sécuritaire utilise une vieille méthode de réparation qui peut gérer certains cas rares, mais elle est bien plus lente.
Si vous obtenez des erreurs étranges lors de la répaaration (comme des erreurs de type out of memory), ou si myisamchk crashe, passez à l'étape 3.
Etape 3 : Réparations difficiles
Nous ne devriez atteindre cette étape que si les 16 premiers ko du fichier d'index sont détruits, ou qu'il contient des données erronées, ou si le fichier d'index manque. Dans ce cas, il est nécessaire de créer un nouveau fichier d'index. Faites ceci :
-
Déplacez le fichier de données dans une archive sûre.
-
Utilisez le fichier description de la table pour créer de nouveaux fichiers de données et d'index vides.
shell>
mysql db_namemysql>SET AUTOCOMMIT=1;mysql>TRUNCATE TABLE table_name;mysql>quitSi votre version SQL ne dispose pas de
TRUNCATE TABLE, utilisez la commandeDELETE FROM table_name. -
Copiez l'ancien fichier de données à la place du nouveau fichier de données (ne faites pas un simple déplacement de fichier. Utilisez une copie, au cas où un problème surviendrait).
Retournez à l'étape 2. myisamchk -r -q doit alors fonctionner (et ceci ne doit pas être une boucle infinie).
Depuis MySQL 4.0.2, vous pouvez aussi utiliser REPAIR ... USE_FRM qui effectue toute cette opération automatiquement.
Etape 4 : Réparation très difficiles
Vous ne devriez atteindre cette étape que si votre fichier de description .frm a aussi crashé. Cela ne devrait jamais arriver, car le fichier de description n'est jamais modifié une fois que la table est créée.
-
Restaurez le fichier de description avec une sauvegarde, et retournez à l'étape 3. Vous pouvez aussi restaurer le fichier d'index et retourner à l'étape 2. Dans ce dernier cas, vous pouvez démarrer avec l'option
myisamchk -r. -
Si vous n'avez pas de sauvegarde, mais que vous savez exactement comment la table a été créée, vous pouvez créer une telle table dans une autre base. Supprimez alors le nouveau fichier de données, puis déplacez les fichiers de description
.frmet d'index.MYIdans votre base de données crashée. Cela vous donnera un nouveau fichier d'index et de description, mais laisse intact le fichier de données.MYD. Retournez à l'étape 2 et essayez de reconstruire le fichier d'index.
Pour réorganiser les lignes fragmentées et éliminer l'espace perdu par les effacements et les modifications de lignes, vous pouvez exécuter l'utilitaire myisamchk en mode de restauration :
shell> myisamchk -r tbl_name
Vous pouvez optimiser une table de la même fa¸on que vous le faîtes avec la commande SQL OPTIMIZE TABLE. OPTIMIZE TABLE effectue une réparation de la table, et une analyse des index, puis trie l'arbre d'index pour accélérer les recherches de clés. L'utilisation de la commande réduit aussi les interférences entre le serveur et l'utilitaire car c'est le serveur lui-même qui fait le travail. See Section 13.5.2.5, « Syntaxe de OPTIMIZE TABLE ».
myisamchk dispose aussi d'un grand nombre d'options que vous pouvez utiliser pour améliorer les performances de la table :
-
-S,--sort-index -
-R index_num,--sort-records=index_num -
-a,--analyze
Pour une description complète de ces options, voyez Section 5.7.3.1, « Syntaxe de l'utilitaire myisamchk ».
C'est une bonne idée que d'effectuer des vérifications des tables régulièrement, plutôt que d'attendre qu'un problème survienne. Pour faire ces vérifications, vous pouvez utiliser la commande myisamchk -s. L'option -s (raccourci pour --silent) fait que myisamchk s'exécute en mode silencieux, et n'affiche que les messages d'erreurs. Voyez les sections Section 13.5.2.3, « Syntaxe de CHECK TABLE » et Section 13.5.2.6, « Syntaxe de REPAIR TABLE ».
C'est aussi une bonne idée que de vérifier les tables lorsque le serveur démarre. Par exemple, à chaque fois qu'une machine redémarre au milieu d'une modification de table, vous devrez faire une vérification de toutes les tables qui pourraient être affectées : c'est une ``table supposément corrompue''. Vous pouvez ajouter un test à safe_mysqld pour qu'il exécute myisamchk, afin de vérifier toutes les tables qui ont été modifiées dans les 24 dernières heures, si il reste un vieux fichier .pid (identifiant de processus) après un redémarrage : le fichier .pid est créé par le serveur mysqld lorsqu'il démarre, et il est supprimé lorsque le serveur s'arrête dans des conditions normales. La présence d'un fichier .pid au démarrage indique que le serveur s'est arrêté anormalement.
Un test encore meilleur serait de vérifier toutes les tables dont la date de modification est plus récente que celle du fichier .pid.
Vous devriez aussi vérifiez vos tables régulièrement durant les opérations normales. Chez MySQL AB, nous utilisons une tâche en cron pour vérifier toutes nos tables importantes au moins une fois par semaine, avec une ligne comme celle-ci dans le fichier crontab :
35 0 * * 0 /path/to/myisamchk --fast --silent /path/to/datadir/*/*.MYI
Cela nous affiche les informations sur les tables qui ont été corrompues, de fa¸on à ce que nous puissions les examiner et les réparer.
Comme nous n'avons jamais eu de table qui se soit corrompue inopinément (des tables qui se corrompent pour d'autres raisons que des problèmes matériels) depuis quelques années (ce qui est véridique), une fois par semaine est un bon rythme pour nous.
Nous recommandons que vous commenciez par exécuter la commande myisamchk -s chaque nuit, sur toutes les tables qui ont été modifiées dans les 24 dernières heures, jusqu'à ce que vous preniez confiance en MySQL.
Normalement, vous n'avez pas à maintenir autant les tables MySQL. Si vous changez les tables avec un format de ligne dynamique (les tables avec des colonnes VARCHAR, BLOB ou TEXT) ou que vous avez des tables avec de nombreuses lignes effacées, vous pouvez envisager de faire des défragmentations du fichier, pour récupérer cet espace. Une fois par mois est un bon rythme.
Vous pouvez faire cela avec la commande SQL OPTIMIZE TABLE sur les tables en question, ou bien, si vous avez éteint le serveur mysqld, faites :
shell> myisamchk -r -s --sort-index -O sort_buffer_size=16M */*.MYI
Pour les tables ISAM, la commande est similaire à :
shell> isamchk -r -s --sort-index -O sort_buffer_size=16M */*.MYI
Pour obtenir la description d'une table ou des statistiques à son sujet, utiliser les commandes affichées ici. Nous allons expliquer certains de leurs détails ultérieurement.
-
myisamchk -d nom_de_table Exécute
myisamchken ``mode description'' pour produire une description de votre table. Si vous démarrez le serveur MySQL en utilisant l'option--skip-external-locking,myisamchkva rapporter une erreur si la table est modifiée durant l'exécution de la commande. Cependant, commemyisamchkne modifie pas les tables, durant le mode description, il n'y a pas de risque de perte de données. -
myisamchk -d -v nom_de_table Pour produire plus d'informations durant l'exécution de
myisamchk, ajoutez l'option-vpour indiquer qu'elle doit fonctionner en mode détaillé. -
myisamchk -eis nom_de_table Affiche les informations les plus importantes pour une table. C'est une commande lente, car elle doit lire toute la table.
-
myisamchk -eiv nom_de_table C'est l'équivalent de
-eis, mais qui vous indique ce qui se passe.
Exemple d'affichage résultant de myisamchk -d :
MyISAM file: company.MYI
Record format: Fixed length
Data records: 1403698 Deleted blocks: 0
Recordlength: 226
table description:
Key Start Len Index Type
1 2 8 unique double
2 15 10 multip. text packed stripped
3 219 8 multip. double
4 63 10 multip. text packed stripped
5 167 2 multip. unsigned short
6 177 4 multip. unsigned long
7 155 4 multip. text
8 138 4 multip. unsigned long
9 177 4 multip. unsigned long
193 1 text
Exemple d'affichage résultant de myisamchk -d -v:
MyISAM file: company
Record format: Fixed length
File-version: 1
Creation time: 1999-10-30 12:12:51
Recover time: 1999-10-31 19:13:01
Status: checked
Data records: 1403698 Deleted blocks: 0
Datafile parts: 1403698 Deleted data: 0
Datafilepointer (bytes): 3 Keyfile pointer (bytes): 3
Max datafile length: 3791650815 Max keyfile length: 4294967294
Recordlength: 226
table description:
Key Start Len Index Type Rec/key Root Blocksize
1 2 8 unique double 1 15845376 1024
2 15 10 multip. text packed stripped 2 25062400 1024
3 219 8 multip. double 73 40907776 1024
4 63 10 multip. text packed stripped 5 48097280 1024
5 167 2 multip. unsigned short 4840 55200768 1024
6 177 4 multip. unsigned long 1346 65145856 1024
7 155 4 multip. text 4995 75090944 1024
8 138 4 multip. unsigned long 87 85036032 1024
9 177 4 multip. unsigned long 178 96481280 1024
193 1 text
Exemple d'affichage résultant de myisamchk -eis:
Checking MyISAM file: company Key: 1: Keyblocks used: 97% Packed: 0% Max levels: 4 Key: 2: Keyblocks used: 98% Packed: 50% Max levels: 4 Key: 3: Keyblocks used: 97% Packed: 0% Max levels: 4 Key: 4: Keyblocks used: 99% Packed: 60% Max levels: 3 Key: 5: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 6: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 7: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 8: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 9: Keyblocks used: 98% Packed: 0% Max levels: 4 Total: Keyblocks used: 98% Packed: 17% Records: 1403698 M.recordlength: 226 Packed: 0% Recordspace used: 100% Empty space: 0% Blocks/Record: 1.00 Record blocks: 1403698 Delete blocks: 0 Recorddata: 317235748 Deleted data: 0 Lost space: 0 Linkdata: 0 User time 1626.51, System time 232.36 Maximum resident set size 0, Integral resident set size 0 Non physical pagefaults 0, Physical pagefaults 627, Swaps 0 Blocks in 0 out 0, Messages in 0 out 0, Signals 0 Voluntary context switches 639, Involuntary context switches 28966
Exemple d'affichage résultant de myisamchk -eiv:
Checking MyISAM file: company Data records: 1403698 Deleted blocks: 0 - check file-size - check delete-chain block_size 1024: index 1: index 2: index 3: index 4: index 5: index 6: index 7: index 8: index 9: No recordlinks - check index reference - check data record references index: 1 Key: 1: Keyblocks used: 97% Packed: 0% Max levels: 4 - check data record references index: 2 Key: 2: Keyblocks used: 98% Packed: 50% Max levels: 4 - check data record references index: 3 Key: 3: Keyblocks used: 97% Packed: 0% Max levels: 4 - check data record references index: 4 Key: 4: Keyblocks used: 99% Packed: 60% Max levels: 3 - check data record references index: 5 Key: 5: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 6 Key: 6: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 7 Key: 7: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 8 Key: 8: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 9 Key: 9: Keyblocks used: 98% Packed: 0% Max levels: 4 Total: Keyblocks used: 9% Packed: 17% - check records and index references [LOTS OF ROW NUMBERS DELETED] Records: 1403698 M.recordlength: 226 Packed: 0% Recordspace used: 100% Empty space: 0% Blocks/Record: 1.00 Record blocks: 1403698 Delete blocks: 0 Recorddata: 317235748 Deleted data: 0 Lost space: 0 Linkdata: 0 User time 1639.63, System time 251.61 Maximum resident set size 0, Integral resident set size 0 Non physical pagefaults 0, Physical pagefaults 10580, Swaps 0 Blocks in 4 out 0, Messages in 0 out 0, Signals 0 Voluntary context switches 10604, Involuntary context switches 122798
Voici les tailles des fichiers de données et d'index utilisés dans les tables précédentes :
-rw-rw-r-- 1 monty tcx 317235748 Jan 12 17:30 company.MYD -rw-rw-r-- 1 davida tcx 96482304 Jan 12 18:35 company.MYM
Des détails sur les types d'informations retournés par myisamchk sont listés ici. Le ``keyfile'' est le fichier d'index. ``Record'' et ``row'' sont synonymes de ligne :
-
ISAM fileNom du fichier d'index ISAM. -
Isam-versionVersion du format ISAM. Actuellement, c'est toujours 2. -
Creation timeDate de création du fichier de données. -
Recover timeDate de dernière reconstruction du fichier de données ou d'index. -
Data recordsCombien de lignes sont stockées dans la table. -
Deleted blocksCombien de blocs effacés occupent toujours de l'espace. Vous pouvez optimiser la table pour récupérer cet espace. See Section 5.7.3.10, « Optimisation de table ». -
Data file: PartsPour les tables au format de ligne dynamique, ceci indique combien de blocs de données sont présents. Pour une table optimisée sans lignes fragmentées, la valeur doit être égale àData records. -
Deleted dataCombien d'octets de données effacées et non réutilisées sont présents dans la table. Vous pouvez optimiser la table pour récupérer cet espace. See Section 5.7.3.10, « Optimisation de table ». -
Data file pointerLa taille du pointeur de fichier de données, en octets. C'est généralement 2, 3, 4, ou 5 octets. La plupart des tables peuvent se gérer avec 2 octets, mais ceci ne peut être contrôlé par MySQL actuellement. Pour les tables à format de ligne fixe, c'est une adresse de ligne. Pour les tables dynamiques, c'est une adresse d'octet. -
Keyfile pointerLa taille du pointeur de fichier d'index, en octets. C'est généralement 1, 2 ou 3 octets. La plupart des tables supportent 2 octets, mais cela est calculé automatiquement par MySQL. C'est toujours une adresse de bloc. -
Max datafile lengthTaille maximale du fichier de données, en octets. -
Max keyfile lengthTaille maximale du fichier d'index, en octets. -
RecordlengthTaille occupée par chaque ligne, en octets. -
Record formatLe format utilisé pour stocker les lignes de la table. Les exemples ci-dessus utilisaientFixed length. Les autres valeurs possibles sontCompressedetPacked. -
table descriptionUne liste de toutes les clés de la table. Pour chaque clé, des informations de bas niveau sont présentées :-
KeyLe numéro d'index. -
StartOù, dans la ligne, l'index débute. -
LenTaille de cette partie d'index. Pour les nombres compactés, c'est toujours la taille maximale de la colonne. Pour les chaînes, c'est plus petit que la taille maximale de la colonne index, car vous pouvez indexer un préfixe de la chaîne. -
Indexuniqueetmultip.(multiple). Indique si une valeur peut exister plusieurs fois dans cet index. -
TypeDe quel type de données cet index est. C'est un type de données ISAM avec les optionspacked,strippedouempty. -
RootAdresse du premier bloc d'index. -
BlocksizeLa taille de chaque bloc d'index. Par défaut, c'est 1024, mais cette valeur peut être modifiée lors de la compilation. -
Rec/keyC'est une valeur statistique, utilisée par l'optimiseur. Il indique combien de lignes sont disponibles par valeur de cette clé. Une clé unique aura toujours une valeur de 1. Cela peut être modifié une fois que la table est chargée (ou modifiée de fa¸on majeure), avec la commandemyisamchk -a. Si ce n'est pas mis à jour, une valeur par défaut de 30 est utilisée.
Dans le premier exemple ci-dessus, la neuvième clé est une clé multi-partie, avec deux parties.
-
-
Keyblocks usedQuel pourcentage des blocs de clé est utilisé. Comme les tables utilisées dans les exemples ont tout juste été réorganisées avecmyisamchk, ces valeurs sont très grandes (très proches du maximum théorique). -
PackedMySQL essaie de compacter les clés ayant un préfixe commun. Cela ne peut être utilisé que pour les colonnes de typeCHAR/VARCHAR/DECIMAL. Pour les longues chaînes comme des noms, cette technique va significativement réduire l'espace utilisé. Dans le troisième exemple ci-dessus, la quatrième clé fait 10 caractères de long et a une réduction de 60 % dans l'espace utilisé effectivement. -
Max levelsLa profondeur duB-tree. Les grandes tables avec de longues clés peuvent obtenir de grandes valeurs. -
RecordsCombien de lignes sont enregistrées dans la table. -
M.recordlengthLa taille moyenne d'une ligne. Pour les tables avec un format de ligne statique, c'est la taille de chaque ligne. -
PackedMySQL efface les espaces à la fin des chaînes.Packedindique le pourcentage d'économie d'espace réalisé. -
Recordspace usedQuel est le pourcentage d'utilisation du fichier de données. -
Empty spaceQuel est le pourcentage d'utilisation du fichier d'index. -
Blocks/RecordLe nombre moyen de blocs par enregistrements (c'est à dire, de combien de liens une ligne fragmentées est constituée). C'est toujours 1.0 pour les tables à format de ligne statique. Cette valeur doit être aussi proche que possible de 1.0. Si elle grossit trop, vous pouvez réorganiser la table avecmyisamchk. See Section 5.7.3.10, « Optimisation de table ». -
RecordblocksCombien de blocs sont utilisés. Pour les tables à format de ligne fixe, c'est le même nombre que le nombre de lignes. -
DeleteblocksCombien de blocs (liens) sont effacés. -
RecorddataCombien d'octets sont utilisés dans le fichier. -
Deleted dataCombien d'octets dans le fichier de données sont effacés (inutilisés). -
Lost spaceSi une ligne est modifiée, et réduite en taille, de l'espace est perdu. Ce chiffre est la somme de ces espaces perdus, en octets. -
LinkdataLorsque le format de ligne dynamique est utilisé, les fragments de lignes sont liés avec des pointeurs de (4 à 7 octets chacun).Linkdataest la somme du stockage utilisé par ces pointeurs.
Si une table a été compressée avec myisampack, myisamchk -d affiche des informations supplémentaires à propos de chaque colonne. Voir Section 8.2, « myisampack, le générateur de tables MySQL compressées en lecture seule », pour un exemple de ces informations, et une description de leur signification.
- 5.8.1. Le jeu de caractères utilisé pour les données et le stockage
- 5.8.2. Langue des messages d'erreurs
- 5.8.3. Ajouter un nouveau jeu de caractères
- 5.8.4. Le tableau de définition des caractères
- 5.8.5. Support d'assemblage des chaînes
- 5.8.6. Support des caractères multi-octets
- 5.8.7. Problèmes avec les jeux de caractères
- 5.8.8. Support des fuseaux horaires avec MySQL
Par défaut, MySQL utilise le jeu de caractères ISO-8859-1 (Latin1) avec tri en accord au Suédois/Finnois. C'est le jeu de caractère le mieux adapté pour les USA et l'Europe de l'ouest.
Tous les binaires standards MySQL sont compilés avec --with-extra-charsets=complex. Cela ajoutera du code à tous les programmes standards pour qu'ils puissent gérer latin1 et tous les jeux de caractères multi-octets compris dans le binaire. Les autres jeux de caractères seront chargés à partir d'un fichier de définition de jeu si besoin.
Le jeu de caractères détermine quels caractères sont autorisés dans les noms et comment s'effectuent les tris dans les clauses ORDER BY et GROUP BY de la commande SELECT.
Vous pouvez changer le jeu de caractères avec l'option de démarrage du serveur --default-character-set. Les jeux de caractères disponibles dépendent des options --with-charset=charset et --with-extra-charsets= list-of-charset | complex | all de configure, et des fichiers de configuration de jeux de caractères situés dans SHAREDIR/charsets/Index. See Section 2.4.2, « Options habituelles de configure ».
Depuis MySQL 4.1.1, vous pouvez aussi changer la collation du jeu de caractères avec l'option --default-collation lorsque le serveur démarre. La collation doit être valide pour le jeu de caractères par défaut. Utilisez la commande SHOW COLLATION pour déterminer quelles collations sont disponibles pour chaque jeu de caractères. See Section 2.4.2, « Options habituelles de configure ».
Si vous changez le jeu de caractères lors de l'utilisation de MySQL (ce qui pourra aussi changer l'ordre de tri), vous devez exécuter myisamchk -r -q --set-character-set=charset sur toutes les tables. Sinon, vos index pourront ne pas être ordonnés correctement.
Lorsqu'un client se connecte à un serveur MySQL, le serveur envoie le jeu de caractères utilisé par défaut au client. Le client changera de jeu de caractères pour cette connexion.
Vous devez utiliser mysql_real_escape_string() pour protéger les chaînes pour une requête SQL. mysql_real_escape_string() est identique à l'ancienne fonction mysql_escape_string(), excepté qu'elle prend le gestionnaire de connexion MYSQL en tant que premier paramètre.
Si le client est compilé avec d'autres chemins que ceux où le serveur est installé et que la personne qui a configuré MySQL n'a pas inclut tous les jeux de caractères dans le binaire MySQL, vous devez indiquer au client où il peut trouver les jeux de caractères additionnels dont il aura besoin si le serveur utilise un autre jeu de caractères que le client.
On peut le spécifier en pla¸ant dans un fichier d'options MySQL :
[client] character-sets-dir=/usr/local/mysql/share/mysql/charsets
où le chemin pointe vers le répertoire où les jeux de caractères dynamiques de MySQL sont stockés.
On peut forcer le client à utiliser un jeu de caractères spécifique en précisant :
[client] default-character-set=character-set-name
mais on n'en a normalement jamais besoin.
Pour obtenir l'ordre de tri Allemand, vous devez démarrer mysqld avec --default-character-set=latin1_de. Cela vous donnera les caractéristiques différentes.
-
Lors du tri et de la comparaison des chaînes, les remplacements suivants sont faits dans la chaîne avant d'effectuer la comparaison :
ä -> ae ö -> oe ü -> ue ß -> ss
-
Tous les caractères accentués sont convertis en leur majuscule non-accentuée. Toutes les lettres sont transformées en majuscules.
-
Lors de la comparaison des chaînes de caractères avec
LIKE, la conversion un vers deux caractères n'est pas effectuée. Toutes les lettres sont transformées en majuscules. Les accents sont supprimés de toutes les lettres, à l'exception de :Ü,ü,Ö,ö,Äetä.
mysqld peut émettre des messages d'erreurs dans les langues suivantes : Tchèque, Danois, Néerlandais, Anglais (par défaut), Estonien, Fran¸ais, Allemand, Grec, Hongrois, Italien, Japonais, Coréen, Norvégien, Norwegian-ny, Polonais, Portugais, Roumain, Russe, Slovaque, Espagnol et Suédois.
Pour démarrer mysqld avec une langue particulière, utilisez soit l'option --language=lang, soit -L lang. Par exemple :
shell> mysqld --language=french
ou :
shell> mysqld --language=/usr/local/share/french
Notez que tout les noms de langue sont spécifiés en minuscule.
Les fichiers de langue sont situés (par défaut) dans share/.LANGUAGE/
Pour modifier le fichier de messages d'erreurs, vous devez éditer le fichier errmsg.txt et exécuter la commande suivante pour générer le fichier errmsg.sys :
shell> comp_err errmsg.txt errmsg.sys
Si vous changez de version de MySQL, pensez à modifier le nouveau fichier errmsg.txt.
Cette section présente la procédure à suivre pour ajouter un autre jeu de caractères à MySQL. Vous devez avoir une distribution source pour suivre ces instructions.
Pour choisir la procédure adaptée, il faut savoir si le jeu de caractères est simple ou complexe :
-
Si le jeu de caractères n'a pas besoin d'utiliser des routines de collations de chaînes spéciales pour le tri et n'a pas besoin du support des jeux de caractères multi-octets, il est simple.
-
S'il a besoin de l'une de ces deux fonctionnalités, il est complexe.
Par exemple, latin1 et danish sont des jeux de caractères simples tandis que big5 et czech sont complexes.
Dans la section suivante, nous supposons que vous nommez votre jeu de caractères MONJEU.
Pour un jeu de caractères simple, effectuez ce qui suit :
-
Ajoutez
MONJEUà la fin du fichiersql/share/charsets/IndexAssignez-lui un nombre unique. -
Créez le fichier
sql/share/charsets/MONJEU.conf. (Vous pouvez vous inspirer desql/share/charsets/latin1.conf.)La syntaxe pour le fichier est très simple :
-
Les commentaires commencent avec le caractère ‘
#’ et se terminent à la fin de la ligne. -
Les mots sont séparés par un nombre changeant d'espaces blancs.
-
Lors de la définition d'un jeu de caractères, chaque mot doit être un nombre au format hexadécimal.
-
Le tableau
ctypeprends les 257 premiers mots. Les tableauxto_lower[],to_upper[]etsort_order[]prennent chacun 256 mots après cela.
See Section 5.8.4, « Le tableau de définition des caractères ».
-
-
Ajoutez le nom du jeu de caractères aux listes
CHARSETS_AVAILABLEetCOMPILED_CHARSETSdansconfigure.in. -
Reconfigurez, recompilez et testez.
Pour un jeu de caractères complexe faites ce qui suit :
-
Créez le fichier
strings/ctype-MONJEU.cdans la distribution des sources MySQL. -
Ajoutez
MONJEUà la fin du fichiersql/share/charsets/Index. Assignez-lui un nombre unique. -
Regardez un des fichiers
ctype-*.cexistant pour voir ce qui doit être défini, par exemple,strings/ctype-big5.c. Notez que les tableaux dans votre fichier doivent avoir des noms tels quectype_MONJEU,to_lower_MONJEU, etc. Cela correspond aux tableaux dans les jeux de caractères simples. See Section 5.8.4, « Le tableau de définition des caractères ». Pour un jeu de caractère complexe -
Au début du fichier, placez un commentaire spécial comme celui-ci :
/* * This comment is parsed by configure to create ctype.c, * so don't change it unless you know what you are doing. * * .configure. number_MONJEU=MYNUMBER * .configure. strxfrm_multiply_MONJEU=N * .configure. mbmaxlen_MONJEU=N */
Le programme
configureutilise ce commentaire pour inclure automatiquement le jeu de caractères dans la bibliothèque MySQL.Les lignes
strxfrm_multiplyetmbmaxlenseront expliquées dans les sections suivantes. Ne les incluez que si vous avez besoin des fonctions d'assemblage des chaînes ou des fonctions de jeu de caractères multi-octets, respectivement. -
Vous devez alors créer les fonctions suivantes :
-
my_strncoll_MONJEU() -
my_strcoll_MONJEU() -
my_strxfrm_MONJEU() -
my_like_range_MONJEU()
-
-
Ajoutez le nom du jeu de caractères aux listes
CHARSETS_AVAILABLEetCOMPILED_CHARSETSdansconfigure.in. -
Reconfigurez, recompilez et testez.
Le fichier sql/share/charsets/README fournit plus d'instructions.
Si vous voulez qu'un jeu de caractères soit ajouté dans la distribution MySQL, envoyez un patch aux listes internes. See Section 1.4.1.1, « Les listes de diffusion de MySQL ».
to_lower[] et to_upper[] sont de simples tableaux qui contiennent les caractères minuscules et majuscules correspondant à chaque membre du jeu de caractère. Par exemple :
to_lower['A'] doit contenir 'a' to_upper['a'] doit contenir 'A'
sort_order[] est une carte indiquant comment les caractères doivent être ordonnés pour les comparaisons et les tris. Pour beaucoup de jeux de caractères, c'est la même chose que to_upper[] (ce qui signifie que le tri sera insensible à la casse). MySQL triera les caractères en se basant sur la valeur de sort_order[caractère]. Pour des règles de tri plus compliquées, voyez la discussion suivante sur l'assemblage des chaînes. See Section 5.8.5, « Support d'assemblage des chaînes ».
ctype[] est un tableau de valeurs de bit, avec un élément par caractère. (Notez que to_lower[], to_upper[], et sort_order[] sont indexés par la valeur du caractère, mais que ctype[] est indexé par la valeur du caractère + 1. C'est une vielle habitude pour pouvoir gérer EOF.)
Vous pouvez trouver les définitions de bitmask suivantes dans m_ctype.h :
#define _U 01 /* Majuscule */ #define _L 02 /* Minuscule */ #define _N 04 /* Numérique (nombre) */ #define _S 010 /* Caractère d'espacement */ #define _P 020 /* Ponctuation */ #define _C 040 /* Caractère de contrôle */ #define _B 0100 /* Blanc */ #define _X 0200 /* nombre hexadecimal */
L'entrée ctype[] de chaque caractère doit être l'union des valeurs de masque de bits qui décrivent le caractère. Par exemple, 'A' est un caractère majuscule (_U) autant qu'une valeur hexadécimale (_X), et donc ctype['A'+1] doit contenir la valeur :
_U + _X = 01 + 0200 = 0201
Si les règles de tri de votre langue sont trop complexes pour être gérées par le simple tableau sort_order[], vous devez utiliser les fonctions d'assemblage de chaînes.
Jusqu'à présent, la meilleure documentation traitant de ce sujet est présente dans les jeux de caractères implémentés eux-mêmes. Regardez les jeux de caractères big5, czech, gbk, sjis, et tis160 pour des exemples.
Vous devez spécifier la valeur de strxfrm_multiply_MYSET=N dans le commentaire spécial au début du fichier. N doit être le rationnel maximal vers lequel la chaîne pourra croître durant my_strxfrm_MYSET (cela doit être un entier positif).
Si vous voulez ajouter le support de jeu de caractères incluant des caractères multi-octets, vous devez utiliser les fonctions de caractères multi-octets.
Jusqu'à présent, la meilleure documentation traitant de ce sujet est présente dans les jeux de caractères implémentés eux-mêmes. Regardez les jeux de caractères euc_kr, gb2312, gbk, sjis, et ujis pour des exemples. Ils sont implémentés dans les fichiers ctype-'charset'.c dans le dossier strings.
Vous devez spécifier la valeur de mbmaxlen_MYSET=N dans le commentaire spécial en haut du fichier source. N doit être la taille en octet du caractère le plus large dans le jeu.
Si vous essayez d'utiliser un jeu de caractères qui n'est pas compilé dans votre exécutable, vous pouvez rencontrer différents problèmes :
-
Votre programme a un chemin faux en ce qui concerne l'endroit où sont stockés les jeux de caractères. (Par défaut
/usr/local/mysql/share/mysql/charsets). Cela peut être réparé en utilisant l'option--character-sets-dirdu programme en question. -
Le jeu de caractères est un jeu de caractères multi-octets qui ne peut être chargé dynamiquement. Dans ce cas, vous devez recompiler le programme en incluant le support du jeu de caractère.
-
Le jeu de caractères est un jeu de caractères dynamique, mais vous n'avez pas de fichier de configuration lui étant associé. Dans ce cas, vous devez installer le fichier de configuration du jeu de caractères à partir d'une nouvelle distribution MySQL.
-
Votre fichier
Indexne contient pas le nom du jeu de caractères.ERROR 1105: File '/usr/local/share/mysql/charsets/?.conf' not found (Errcode: 2)
Dans ce cas, vous devez soit obtenir un nouveau fichier
Indexou ajouter à la main le nom du jeu de caractères manquant.
Pour les tables MyISAM, vous pouvez vérifier le nom du jeu de caractères et son nombre associé d'une table avec myisamchk -dvv nom_de_table.
Avant MySQL version 4.1.3, vous pouviez modifier le fuseau horaire du serveur avec l'option --timezone=timezone_name de mysqld_safe. Vous pouvez aussi le modifier avec la variable d'environnement TZ avant de lancer mysqld.
Les valeurs autorisées pour --timezone et TZ dépendent du système d'exploitation. Consultez la documentation de votre système d'exploitation pour connaître ces valeurs.
Depuis MySQL 4.1.3, le serveur entretien différentes configurations de fuseau horaire :
-
Le fuseau horaire du système. Lorsque le serveur se lance, il tente de déterminer le fuseau horaire de la machine serveur, et l'utilise dans la variable système
system_time_zone. -
Le fuseau horaire courant. La variable système globale
time_zoneindique le fuseau horaire courant du serveur. La valeur initiale est'SYSTEM', qui indique que le serveur est dans le même fuseau horaire que le serveur. La valeur initiale peut être spécifiée explicitement avec l'option--default-time-zone=. Si vous avez les droits detimezoneSUPER, vous pouvez modifier la valeur de cette variable durant l'exécution du serveur, avec cette commande :mysql>
SET GLOBAL time_zone =timezone; -
Fuseau horaire de connexion. Chaque client qui se connecte peut disposer de sa propre configuration de fuseau horaire, grâce à la variable de session
time_zone. Initialement, elle prend la valeur detime_zonemais peut être redéfinie avec la commande suivante :mysql>
SET time_zone =timezone;
La valeur courante du fuseau horaire global et de session est accessible avec cette commande :
mysql> SELECT @@global.time_zone, @@session.time_zone;
Les valeurs de timezone peuvent être fournies sous forme de chaînes de caractères, indiquant un décalage par rapport au temps UTC, comme '+10:00' ou '-6:00'. Si la table de fuseau horaire de la base mysql a été créée et remplie, vous pouvez aussi utiliser les noms de fuseaux, comme 'Europe/Paris' ou 'Canada/Eastern', ou 'MET'. La valeur 'SYSTEM' indique le fuseau horaire du système. Les noms de fuseau horaire sont insensibles à la casse.
La procédure d'installation de MySQL crée la table des fuseaux horaires, mais ne la remplit pas. Vous devez le faire manuellement. Si vous passez en MySQL version 4.1.3 ou plus récent depuis une version plus récente, il est important de créer ces tables en mettant à jour la base mysql. Utilsiez les instructions de Section 2.6.7, « Mise à jour des tables de droits ».)
Note : actuellement, la table des fuseaux horaires peut être remplie uniquement sous Unix. Le problème sera bientôt réglé pour Windows.
Le programme mysql_tzinfo_to_sql sert à charger la table des fuseaux horaires. Vous devez connaître le nom du dossier dans lequel votre système d'exploitation enregistre les fuseaux horaires. Typiquement, c'est /usr/share/zoneinfo. Indiquez cette valeur au programme en ligne de commande mysql_tzinfo_to_sql, et passez le résultat du programme au client mysql. Par exemple :
shell> mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root mysql
mysql_tzinfo_to_sql lit les fichiers de fuseau horaire de votre système et génère des requêtes SQL. Le client mysql traite ces commandes et les charge dans la base de données.
mysql_tzinfo_to_sql peut aussi charger un fichier de fuseau horaire, et générer les secondes additionnelles.
Pour charger un fichier de fuseaux horaires tz_file qui correspond au fuseau appelé tz_name, appelez le programme mysql_tzinfo_to_sql comme ceci :
shell> mysql_tzinfo_to_sql tz_file tz_name | mysql -u root mysql
SI votre système doit prendre en compre les secondes additionnelles, initialisez les informations de secondes additionnelles comme ceci, où tz_file est le nom de votre fichier de fuseau :
shell> mysql_tzinfo_to_sql --leap tz_file | mysql -u root mysql
MySQL a plusieurs fichiers de log qui peuvent vous aider à savoir ce qui se passe à l'intérieur de mysqld:
| Fichier | Description |
| Le log d'erreurs | Problèmes rencontrés lors du démarrage, de l'exécution ou de l'arrêt de mysqld. |
Le log ISAM |
Garde une trace des changements liés au tables ISAM. Utilisé uniquement pour déboguer le code ISAM. |
| Le log de requêtes | Connexions établies et requêtes exécutées. |
| Le log de mises à jour | Désapprouvé : Enregistre toutes les commandes qui changent les données. |
| Le log binaire | Enregistre toutes les commandes qui changent quelque chose. Utilisé pour la réplication. |
| Le log des requêtes lentes | Enregistre toutes les requêtes qui ont pris plus de long_query_time à s'exécuter ou celles qui n'ont pas utilisé d'index. |
Par défaut, tous les fichiers de log peuvent être trouvés dans le dossier de données de mysqld. Vous pouvez forcer mysqld à rouvrir les fichiers de log (ou dans quelques cas à passer à un nouveau log) en exécutant FLUSH LOGS. See Section 13.5.4.2, « Syntaxe de FLUSH ».
Si vous utilisez les fonctionnalités de réplications de MySQL, les serveurs esclaves entretiennent un fichier de log supplémentaire, appelé log de relais. Chapitre 6, Réplication de MySQL.
Le fichier d'erreurs contient les informations indiquant quand mysqld a été lancé et arrêté, ainsi que les erreurs critiques qui sont survenues lorsque le serveur fonctionnait.
Si mysqld s'arrête inopinément, et que mysqld_safe doit le relancer, mysqld_safe va écrire un message restarted mysqld dans le log d'erreurs. Si mysqld remarque qu'une table a besoin d'être réparée ou analysée, il écrit aussi un message dans le log d'erreurs.
Sur certains systèmes d'exploitation, le log d'erreur contient automatiquement une pile de trace si mysqld. La trace peut être utilisée pour déterminer quand mysqld. See Section D.1.4, « Utilisation d'un tra¸age de pile mémoire ».
Depuis MySQL 4.0.10, vous pouvez spécifier où mysqld stocke le fichier d'erreurs avec l'option --log-error[=file_name]. Si aucune valeur file_name n'est donnée, mysqld utilise le nom host_name.err et écrit le fichier dans le dossier de données. (Avant MySQL 4.0.10, le nom de fichier d'erreurs Windows était mysql.err.) Si vous exécutez FLUSH LOGS, le log d'erreur est renommé avec le suffixe -old et mysqld crée un nouveau fichier de log vide.
Dans les anciennes versions de MySQL sous Unix, le log d'erreur était géré par mysqld_safe qui redirigeait les erreurs vers host_name.err. Vous pouvez modifier le nom du fichier en spécifiant l'option --err-log=filename de mysqld_safe.
Si vous ne spécifiez pas --log-error, ou, sous Windows, si vous utilisez l'option --console, les erreurs sont écrites dans la sortie standard stderr. C'est généralement le terminal qui a lancé MySQL.
Sous Windows, les erreurs sont toujours écrites dans le fichier .err si --console n'est pas donné.
Si vous voulez savoir ce qui se passe à l'intérieur de mysqld, vous devez le démarrer avec --log[=fichier]. Cela aura pour effet d'écrire toutes les connexions et les requêtes dans le fichier de log (pas défaut nommé 'hostname'.log). Ce log peut être très utile quand vous suspectez une erreur dans un client et voulez savoir exactement ce que mysqld pense que le client lui a envoyé.
Les anciennes versions du script mysql.server (de MySQL 3.23.4 à 3.23.8) passent à safe_mysqld une option --log (active le log général de requêtes). Si vous avez besoin de meilleurs performances lorsque vous démarrez MySQL dans un environnement de production, vous pouvez supprimer l'option --log de mysql.server ou la changer en --log-bin. See Section 5.9.4, « Le log binaire ».
mysqld écrit le scommandes dans le log de requêtes, dans l'ordre où il les rec¸oit. Cela peut être différent de l'ordre dans lequel elles sont exécutées. Cela est différent du log de modifications et du log binaire, qui sont toujours écrits après exécution, mais avant la libération des verrous.
Les redémarrage de serveur et les écritures de logs ne génèrent pas un nouveau fichier de log de requêtes (même si l'écriture des logs ferme puis ouvre à nouveau le fichier). Sous Unix, vous pouvez renommer le fichier et en créer un nouveau avec les commandes suivantes :
shell>mv hostname.log hostname-old.logshell>mysqladmin flush-logsshell>cp hostname-old.log to-backup-directoryshell>rm hostname-old.log
Sous Windows, vous ne pouvez pas renommer le fichier de logs, alors que le serveur l'a ouvert. Vous devez arrêter le serveur, puis renommer le log. Puis, redémarrez le le serveur pour créer un nouveau log.
Note : le log de modifications a été remplacé par le log binaire. See Section 5.9.4, « Le log binaire ». Avec ce nouveau log, vous pouvez faire tout ce que vous faisiez avec le log de modifications. Le log de modifications n'est plus disponible depuis MySQL 5.0.0.
Lors l'option --log-update[=file_name] est utilisée au démarrage, mysqld écrit un fichier de log contenant toutes les commandes SQL qui modifie les données. Si aucun fichier n'est spécifié, il prendra la valeur par défaut du nom de l'hôte. Si un fichier est spécifié mais qu'aucun chemin n'est indiqué, le fichier sera écrit dans le dossier de données. Si le fichier file_name n'a pas d'extension, mysqld va créer un fichier de log avec ce nom : file_name.###, où ### est un nombre qui s'incrémente à chaque vois que vous exécutez la commande mysqladmin refresh, mysqladmin flush-logs, FLUSH LOGS ou que vous redémarrez le serveur.
Note : pour que la technique ci-dessus fonctionne, vous ne devez pas créer de fichiers avec le nom du fichier de log + une extension, qui pourrait être considérée comme un nombre, dans le dossier qui contient les log de modifications.
L'enregistrement dans le log de modification est fait juste après l'achèvement de la requête, mais avant la levée des verrous, et les validations. Cela garantit que la requête sera enregistrée.
Si vous voulez modifier une base grâce aux fichier de log de modification, vous pouvez utiliser la commande suivante (en supposant que vos fichiers de log de modification porte le nom de file_name.###) :
shell> ls -1 -t -r file_name.[0-9]* | xargs cat | mysql
ls est utilisé pour obtenir toute la liste des fichiers de logs du dossier.
Ceci peut être utile si vous devez repartir d'un fichier de sauvegarde après un crash, et que vous souhaitez re-exécuter les modifications qui ont eu lieu depuis la sauvegarde.
Le log binaire a remplacé l'ancien log de modifications, qui ne sera plus disponible à partir de MySQL version 5.0. Le log binaire contient toutes les informations du log de modifications, dans un format plus efficace, et compatible avec les transactions.
Le log binaire, comme le log de modifications, contient toutes les requêtes qui modifient les données. Ainsi, une commande UPDATE ou DELETE avec une clause WHERE qui ne trouve aucune ligne ne sera pas écrite dans le log. Les commandes UPDATE qui donnent à une colonne sa valeur courante sont même évitées.
Le log binaire contient aussi des informations sur le temps d'exécution de la requête dans la base. Il ne contient que des commandes qui modifient des données. Si vous voulez avoir toutes les commandes (par exemple, si vous identifiez un problème de requête, vous devez utiliser le log de requête général. See Section 5.9.2, « Le log général de requêtes ».
Le but principal de ce log est de pouvoir reprendre les modifications de la base durant les opérations de restaurations, car le log binaire contiendra les requêtes qui ont eu lieu après une sauvegarde.
Le log binaire est aussi utilisé lorsque de la réplication d'un maître par un esclave. See Chapitre 6, Réplication de MySQL.
L'utilisation du log binaire ralentit le serveur d'environ 1%. Cependant, les avantages du log binaire durant les opérations de restauration et pour la réplication sont généralement plus intéressants.
Lorsque l'option de démarrage --log-bin[=file_name] est utilisée, mysqld écrit un fichier de log contenant toutes les commandes SQL qui modifient les données. Si aucun nom de fichier n'est donné, le nom de la machine hôte est utilisé, suivi de -bin. Si un nom est donné, mais qu'il ne contient pas de chemin, le fichier sera écrit dans le dossier de données.
Si vous fournissez une extension à --log-bin=filename.extension, l'extension sera automatiquement supprimée.
mysqld va ajouter une extension au nom du fichier de log binaire qui est un nombre automatiquement incrémenté chaque fois que vous exécutez mysqladmin refresh, mysqladmin flush-logs, FLUSH LOGS ou redémarrez le serveur. Un nouveau fichier de log sera automatiquement créé lorsque le fichier en cours atteint la taille de max_binlog_size. Un fichier de log binaire peut être plus grand que max_binlog_size si vous utilisez de grandes transactions : une transaction est écrite dans le log binaire d'un seul coup, et n'est jamais répartie entre plusieurs fichiers.
Pour être capable de faire la différence entre les fichiers de logs binaire utilisés, mysqld crée aussi un fichier d'index de logs, qui porte le même nom que le fichier de log, mais avec l'extension '.index'. Vous pouvez changer le nom du fichier de log avec l'option --log-bin-index=[file_name]. N'éditez pas manuellement ce fichier durant l'exécution de mysqld ; cela va induire mysqld en erreur.
Vous pouvez effacer tous les fichiers de log avec la commande RESET MASTER, ou seulement certains d'entre eux avec PURGE MASTER LOGS. Voyez Section 13.5.4.5, « Syntaxe de la commande RESET » et Section 13.6.1, « Requêtes SQL pour contrôler les maîtres de réplication ».
Vous pouvez utiliser les options suivantes avec mysqld pour modifier ce qui est enregistré dans le fichier de log :
-
binlog-do-db=database_nameIndique au maître qu'il doit enregistrer les modifications si la base courante (c'est à dire, celle qui est sélectionnée par
USE) estdb_name. Toutes les autres bases de données qui ne sont pas explicitement mentionnées sont ignorées. Si vous utilisez cette option, assurez vous que vous ne faites des modifications que dans la base courante.Un exemple qui ne fonctionnera pas comme on pourrait l'attendre : Si le serveur est lancé avec l'option
binlog-do-db=sales, et que vous utilisezUSE prices; UPDATE sales.january SET amount=amount+1000;, cette commande ne sera pas écrite dans le fichier de log binaire. -
binlog-ignore-db=database_nameIndique au maître qu'il doit ne doit pas enregistrer les modifications si la base courante (c'est à dire, celle qui est sélectionnée par
USE) estdb_name. Si vous utilisez cette option, assurez vous que vous ne faites des modifications que dans la base courante.Un exemple qui ne fonctionnera pas comme on pourrait l'attendre : Si le serveur est lancé avec l'option
binlog-ignore-db=sales, et que vous utilisezUSE prices; UPDATE sales.january SET amount=amount+1000;, cette commande sera écrite dans le fichier de log binaire.
Pour ignorer ou forcer plusieurs bases, spécifiez l'option plusieurs fois, une fois par base.
Les règles suivante sont utilisées dans l'ordre suivant, pour décider si la requête doit aller dans le log binaire ou pas :
-
Y a-t-il des règles
binlog-do-dboubinlog-ignore-db?-
Non : écrit la requête dans le log binaire, et quitte.
-
Oui : aller à l'étape suivante.
-
-
Il y a des règles (
binlog-do-dboubinlog-ignore-dbou les deux). Y a t il une base de données courante (une base sélectionnée avec la commandeUSE)?-
Non : N'écrit pas la requête, et quitte.
-
Oui : aller à l'étape suivante.
-
-
Il y a une base de données courante. Y a-t-il des règles
binlog-do-db?-
Oui : Est-ce que la base de données courante vérifie une des règles
binlog-do-db?-
Oui : écrit la requête dans le log binaire, et quitte.
-
Non : N'écrit pas la requête, et quitte.
-
-
Non : aller à l'étape suivante.
-
-
Il y a des règles
binlog-ignore-db. Est-ce que la base de données courante vérifie une des règlesbinlog-ignore-db?-
Oui : N'écrit pas la requête, et quitte.
-
Non : écrit la requête dans le log binaire, et quitte.
-
Par exemple, un esclave qui fonctionne avec l'option binlog-do-db=sales ne va pas écrire dans le log binaire les commandes qui concernent d'autres bases que sales (en d'autres termes, l'option binlog-do-db peut être considéré comme ``ignore les autres bases'').
Si vous utilisez la réplication, vous ne devez pas effacer les anciens log binaires jusqu'à ce que vous soyez sûrs que les esclaves n'en auront plus besoin. Une fa¸on de faire cela est d'utiliser la commande mysqladmin flush-logs une fois par jour, et d'effacer les fichiers de log qui ont plus de trois jours. Vous pouvez les supprimer manuellement, ou utilisez de préférence la commande PURGE MASTER LOGS TO (see Section 13.6, « Commandes de réplication ») qui va aussi modifier le fichier de log binaires pour vous depuis MySQL 4.1.
Un client avec le droit de SUPER peut désactiver le log binaire pour ses commandes avec SET SQL_LOG_BIN=0. See Section 13.5.2.8, « Syntaxe de SET ».
Vous pouvez examiner le fichier de log binaire avec la commande mysqlbinlog. Par exemple, vous pouvez mettre à jour le serveur MySQL depuis la ligne de commande comme ceci :
shell> mysqlbinlog log-file | mysql -h server_name
Vous pouvez aussi utiliser le programme Section 8.5, « mysqlbinlog, Exécuter des requêtes dans le log binaire » pour lire le fichier de log binaire directement dans le serveur MySQL.
Si vous utilisez les transactions, vous devez utiliser le fichier de log binaire pour les sauvegardes, plutôt que le vieux fichier de log de modifications.
L'enregistrement dans le fichier de log binaire est fait immédiatement après l'achèvement de la requête, mais avant la libération des verrous ou la validation de la requête. Cela garantit que les requêtes seront enregistrées dans l'ordre d'exécution.
Les modifications dans les tables non transactionnelles sont enregistrées dans le fichier de log binaire immédiatement après exécution. Pour les tables transactionnelles comme BDB ou InnoDB, toutes les modifications (UPDATE, DELETE ou INSERT) qui modifient les tables sont mises en cache jusqu'à ce qu'une commande COMMIT ne les envoie au serveur. A ce moment, mysqld écrit la totalité de la transaction dans le log binaire, avant d'appliquer la commande COMMIT. Tous les threads vont, au démarrage, allouer un buffer de la taille de binlog_cache_size octets pour enregistrer les requêtes. Si la requête est plus grande que ce buffer, le thread va ouvrir un fichier temporaire pour écrire la transaction. Le fichier temporaire sera supprimé dès que le thread se termine.
L'option max_binlog_cache_size (par défaut 4Go) peut être utilisé pour limiter la taille utilisée pour mettre en cache une transaction multi-requête. Si la transaction est plus grande que que cette taille, elle sera annulée.
Si vous utilisez les log de modification ou binaire, les insertions concurrentes seront converties en insertions normales lors de l'utilisation de CREATE ... SELECT ou INSERT ... SELECT. Cela garantit que vous pourrez recréer une copie exacte de la table en appliquant les même commandes sauvegardées.
Le format de log binaire est différent entre les versions 3.23, 4.0 et 5.0.0. Ces changements de formats sont nécessaires pour améliorer la réplication. MySQL 4.1 a le même format de log binaire que 4.0. See Section 6.5, « Compatibilité de la réplication entre les versions de MySQL ».
Lorsqu'il est démarré avec l'option --log-slow-queries[=file_name], mysqld va écrire dans un fichier les requêtes SQL qui vont mettre plus de long_query_time secondes à s'exécuter. Le temps d'acquisition d'un verrou n'est pas compté.
Les requêtes lentes sont enregistrées après l'achèvement de l'exécution de la requête, et libération du verrou. Cela peut être différent de l'ordre dans lequel les commandes sont exécutées.
Si aucun nom de fichier n'est donné, le fichier de log prendra par défaut le nom de la machine, suffixé avec -slow.log. Si un nom de fichier est donné, mais qu'il manque le chemin, le fichier sera écrit dans le dossier de données.
Le log de requêtes lentes peut être utilisé pour repérer les requêtes qui prennent longtemps à s'exécuter, et donc, qui sont candidates à l'optimisation. Avec un grand fichier de log, cela peut devenir difficile. Vous pouvez alors passer le fichier de log à mysqldumpslow pour obtenir un sommaire des requêtes dans ce fichier.
Si vous utilisez l'option --log-long-format alors les requêtes qui n'utilisent pas d'index sont aussi enregistrées. See Section 4.3.1, « Options de ligne de commande de mysqld ».
Le serveur MySQL peut créer un grand nombre de fichiers de logs différents, qui permettent de suivre ce qui se passe. See Section 5.9, « Les fichiers de log de MySQL ». Vous devez toutefois nettoyer régulièrement ces fichiers, pour être sûr que les logs ne prennent pas tout le disque de la machine.
Lorsque vous utilisez MySQL avec des fichiers de log, vous voudrez, de temps en temps, supprimer ou sauvegarder les fichiers, et demander à MySQL d'utiliser de nouveaux fichiers. See Section 5.7.1, « Sauvegardes de base de données ».
Sous une installation Linux (Redhat), vous pouvez utiliser le script mysql-log-rotate pour cela. Si vous avez installé MySQL depuis une distribution RPM, le script doit avoir été installé automatiquement. Notez que vous devez être prudent avec cette commande si vous utilisez les logs pour la réplication.
Sur d'autres systèmes, vous devez installer un court script par vous même, qui sera exécuté via le démon cron.
Vous pouvez forcer MySQL à utiliser de nouveaux fichiers de log en utilisant la commande mysqladmin flush-logs ou avec la commande SQL FLUSH LOGS. Si vous utilisez MySQL version 3.21, vous devez utiliser mysqladmin refresh.
Les commandes ci-dessus effectue les tâche suivantes :
-
Si le log standard (
--log) ou le log de requêtes lentes (--log-slow-queries) est utilisé, la commande ferme et rouvre le fichier de log (mysql.loget`hostname`-slow.logpar défaut). -
Si le log de modifications est utilisé (
--log-update), la commande ferme le log de modification et ouvre un nouveau fichier, avec un nouveau numéro de séquence plus grand.
Si vous utilisez uniquement le log de modification, vous pour simplement vider les logs sur le disque, et sauver l'ancien fichier de modification dans une sauvegarde. Si vous utilisez le log normal, vous pouvez faire ceci :
shell>cd mysql-data-directoryshell>mv mysql.log mysql.oldshell>mysqladmin flush-logs
puis faire une sauvegarde du fichier, et le supprimer (mysql.old).
Il y a des situations où vous souhaiterez avoir plusieurs serveurs MySQL sur la même machine. Par exemple, si vous voulez tester une nouvelle version du serveur avec votre configuration de production sans perturber votre installation de production. Ou bien, vous êtes un fournisseur de services Internet, et vous voulez fournir des installations distinctes pour des clients différents.
Si vous voulez exécuter plusieurs serveurs MySQL, le plus simple et de compiler les serveurs avec différents ports TCP/IP et fichiers de sockets pour qu'ils ne soient pas tous à l'écoute du même port ou de la même socket. Voir Section 4.3.1, « Options de ligne de commande de mysqld » et Section 4.3.2, « Fichier d'options my.cnf ».
Au minimum, les options suivantes doivent être différentes sur chaque serveur :
-
--port=port_num--portcontrôle le numéro de port des connexions TCP/IP. -
--socket=path--socketcontrôle le chemin de la socket sous Unix, et le nom du pipe nommé sous Windows. Sous Windows, il est nécessaire de spécifier un pipe distinct pour les serveurs qui supportent les connexions par pipes nommés. -
--shared-memory-base-name=nameCette option ne sert actuellement que sous Windows. Elle désigne la portion de mémoire partagée, utilisée par Windows pour mettre aux clients de se connecter via la mémoire partagée. Cette option est nouvelle en MySQL 4.1.
-
--pid-file=pathCette option ne sert que sous Unix. Elle indique le nom du fichier dans lequel le serveur écrit l'identifiant de processus.
--port contrôle le numéro de port des connexions TCP/IP. --socket contrôle le chemin du fichier de socket sous Unix et le nom du pipe sous Windows. Il est nécessaire d'indiquer des noms de pipe différents sous Windows, uniquement si le serveur supporte les pipes nommés. --shared-memory-base-name désigne le nom du segment de mémoire partagée utilisé par un serveur Windows pour permettre à ses clients de se connecter via la mémoire partagée. --pid-file indique le nom du fichier sur lequel le serveur Unix écrit le numéro de processus.
Si vous utilisez les options suivantes, elles doivent être différentes sur chaque serveur :
-
--log=path -
--log-bin=path -
--log-update=path -
--log-error=path -
--log-isam=path -
--bdb-logdir=path
Si vous voulez plus de performances, vous pouvez aussi spécifier les options suivantes différemment pour chaque serveur, pour répartir la charge entre plusieurs disques physiques :
-
--tmpdir=path -
--bdb-tmpdir=path
Avoir plusieurs dossiers temporaires comme ci-dessus est aussi recommandé car il est plus facile pour vous de savoir quel serveur MySQL aura créé quel fichier temporaire.
Généralement, chaque serveur doit aussi utiliser des options différentes pour les dossiers de données, qui est spécifié avec l'option --datadir=path.
Attention : normalement, vous ne devez pas avoir deux serveurs qui modifient en même temps les données dans les mêmes bases. Si votre OS ne supporte pas le verrouillage sans échec, cela peut vous mener à de déplaisantes surprises !
Cette mise en garde contre le partage de données entre deux serveur s'applique aussi aux environnements NFS. Permettre à plusieurs serveurs MYSQL d'accéder aux même données via NFS est une mauvaise idée!
-
Le problème principale est que NFS devient rapidement une limitation en termes de vitesse. Il n'a pas été con¸u pour cela.
-
Un autre risque avec NFS est que vous devez vous assurer que deux serveurs n'interfèrent pas les uns avec les autres. Généralement, le verrouillage de fichier NFS est fait avec
lockd, mais pour le moment, aucune plate-forme ne sera 100% fiable avec cette technique.
Simplifie vous la vie : évitez de partager le même dossier de données entre plusieurs serveurs, via NFS. Une solution plus intelligente est d'avoir un serveur avec plusieurs processeurs, et un système d'exploitation bien optimisé pour les threads.
Si vous avez plusieurs installations de serveurs MySQL a plusieurs endroits, vous pouvez spécifier le dossier de données pour chaque serveur avec l'option --basedir=path, pour que chaque serveur utilise des données différentes, des fichiers de log différents et un PID différent. Les valeurs par défaut de ces options sont relatives au dossier d'installation. Dans ce cas, la seule chose qui reste à adapter est la socket --socket et le --port. Par exemple, supposons que vous installez différentes versions de MySQL en utilisant la distribution binaire .tar. Elles vont être installées en différents dossiers, et vous pouvez lancer le serveur à chaque fois, avec le script ./bin/mysqld_safe de chaque dossier respectif. mysqld_safe va déterminer la bonne option --basedir à passer à mysqld, et vous devrez spécifier --socket et --port à mysqld_safe.
Comme présenté dans les prochaines sections, il est possible de démarrer d'autres serveurs en modifiant des variables d'environnement ou en spécifiant les bonnes options de ligne de commande. Cependant, si vous devez lancer des serveurs de manière récurrente, il sera plus pratique de stocker ces valeurs dans le fichier de configuration.
Vous pouvez utiliser plusieurs serveur MySQL sur Windows, en lan¸ant manuellement chacun d'entre eux en ligne de commande, avec ses paramètres de fonctionnement appropriés. Sur les systèmes Windows NT, vous pouvez aussi installer plusieurs serveurs comme services Windows, et les faire fonctionner de cette fa¸on. Des instructions générales pour exécuter MySQL depuis la ligne de commande ou comme services sont données dans la section Section 2.2.1, « Installer MySQL sous Windows ». Cette section décrit comme lancer chaque serveur, avec différentes valeurs de démarrage, qui doivent être uniques pour chaque serveur, à commencer par le dossier de données. Ces options sont décrites dans la section Section 5.10, « Faire fonctionner plusieurs serveurs MySQL sur la même machine ».
Pour lancer plusieurs serveurs manuellement depuis la ligne de commande, vous pouvez spécifier les options appropriés en ligne de commande, ou dans un fichier d'options. Il est plus pratique de le faire dans un fichier d'option, mais il est nécessaire que chaque serveur utilise bien un fichier d'options différent. Pour cela, créez un fichier pour chaque serveur, et donner le nom du fichier au serveur avec l'option --defaults-file.
Supposez que vous voulez utiliser mysqld sur le port 3307 avec un dossier de données situé dans C:\mydata1, et mysqld-max sur le port 3308 avec un dossier de données situé dans C:\mydata2. Pour cela, créez deux fichiers d'options. Par exemple créez un fichier appelé C:\my-opts1.cnf qui ressemble à celui-ci :
[mysqld] datadir = C:/mydata1 port = 3307
Créez un fichier appelé C:\my-opts2.cnf qui ressemble à celui-ci :
[mysqld] datadir = C:/mydata2 port = 3308
Puis, lancez chaque serveur avec ses propres options :
shell>mysqld --defaults-file=C:\my-opts1.cnfshell>mysqld-max --defaults-file=C:\my-opts2.cnf
(Sur NT, les serveurs vont se lancer en tâche de fond, et vous devrez ouvrir deux consoles pour lancer les deux commandes séparées).
Pour éteindre ces deux serveurs, vous devez vos connecter au bon numéro de port :
shell>mysqladmin --port=3307 shutdownshell>mysqladmin --port=3308 shutdown
Les serveurs configurés comme décrit ci-dessus permettent aux clients de se connecter via un réseau TCP/IP. Si vous voulez aussi utiliser les pipes nommés, utilisez les serveurs mysqld-nt ou mysqld-max-nt et spécifiez les options qui permettent d'activer les pipes nommés et leur nom. Chaque serveur qui supporte les pipes nommés doit avoir un nom de pipe unique. Par exemple, le fichier C:\my-opts1.cnf peut être écrit comme ceci :
[mysqld] datadir = C:/mydata1 port = 3307 enable-named-pipe socket = mypipe1
Puis, lancez le serveur comme ceci :
shell> mysqld-nt --defaults-file=C:\my-opts1.cnf
C:\my-opts2.cnf doit être modifié similairement pour l'utiliser avec le second serveur.
Sur les systèmes NT, MySQL peut fonctionner comme un service Windows. Les procédures pour installer, contrôler et supprimer un service MySQL sont décrites dans la section Section 2.2.9.1, « Lancer MySQL comme un service Windows ».
Depuis MySQL 4.0.2, vous pouvez installer plusieurs serveurs sous forme de plusieurs services. Dans ce cas, vous devez vous assurer que chaque serveur utilise un nom de service différente, en plus de tous les autres paramètres qui doivent être uniques pour chaque instance.
Pour les instructions suivantes, supposez que vous vouez utiliser le serveur mysqld-nt avec différentes versions de MySQL, qui sont installées dans les dossiers C:\mysql-4.0.8 et C:\mysql-4.0.17, respectivement. Cela peut être le cas si vous utilisez la version 4.0.8 comme serveur de production, mais que vous voulez tester la version 4.0.17 avant de l'utiliser.
Les règles suivantes sont applicables lors de l'installation d'un service MYSQL avec l'option --install :
-
Si vous ne spécifiez aucun nom de service, le serveur utilise le nom de service par défaut de MySQL et le serveur lit les options dans le groupe
[mysqld], du groupe de fichiers d'options standard. -
Si vous spécifiez un nom de service après l'option
--install, le serveur va ignorer le group d'options[mysqld]et lire les options dans le groupe qui a le même nom que le service. Les options seront lues dans le fichier d'options standard. -
Si vous spécifiez
--defaults-fileaprès un nom de service, le serveur va ignorer le fichier d'options standard, et lire les options dans le groupe[mysqld]du fichier ainsi nommé.
Note : avant MySQL 4.0.17, seul le serveur utilisant le nom de service par défaut (MySQL) ou un service installé explicitement avec le nom de mysqld lira le groupe d'options [mysqld] dans le fichier d'options. Depuis 4.0.17, tous les serveurs lisent le groupe [mysqld] s'ils lisent dans le fichier d'options standard, même si ils ont été installé avec un autre nom de service. Cela permet d'utiliser le groupe [mysqld] pour des options qui doivent être utilisées par tous les services MySQL, et un groupe d'options pour chaque service sera utilisé individuellement par chaque service.
En se basant sur les informations précédentes, vous avez plusieurs moyens pour installer des services Windows multiples. Les instructions suivantes décrivent certaines situations. Avant de tous les essayer, assurez vous de bien éteindre et supprimer tous les services MySQL existant.
-
Approche 1 : Spécifiez les options de tous les services dans un fichier d'options. Pour cela, utilisez différent noms de services pour chaque serveur. Supposons que vous vouliez utiliser
mysqld-nt4.0.8 sous le nom demysqld1et lemysqld-nt4.0.17 sous le nom demysqld2. Dans ce cas, vous pouvez utiliser le groupe[mysqld1]pour le serveur version 4.0.8 et le groupe[mysqld2]pour le serveur version 4.0.17. Par exemple, vous pourriez configurer votre fichier d'optionsC:\my.cnfainsi :# options for mysqld1 service [mysqld1] basedir = C:/mysql-4.0.8 port = 3307 enable-named-pipe socket = mypipe1 # options for mysqld2 service [mysqld2] basedir = C:/mysql-4.0.17 port = 3308 enable-named-pipe socket = mypipe2
Installez les services comme ceci, en utilisant les noms de chemin complet pour vous assurer que Windows trouve les bons programmes pour chaque service :
shell>
C:\mysql-4.0.8\bin\mysqld-nt --install mysqld1shell>C:\mysql-4.0.17\bin\mysqld-nt --install mysqld2Pour lancer les services, utilisez le gestionnaire de services, ou bien utilisez la commande
NET STARTavec les bons noms de services :shell>
NET START mysqld1shell>NET START mysqld2Pour lancer les services, utilisez le gestionnaire de services, ou bien utilisez la commande
NET STOPavec les bons noms de services :shell>
NET STOP mysqld1shell>NET STOP mysqld2 -
Approche 2 : Spécifiez les options de chaque serveur dans un fichier séparé, et utilisez l'option
--defaults-filelorsque vous installez le service pour dire au serveur quel fichier utiliser. Dans ce cas, chaque fichier doit contenir les options du groupe[mysqld].Avec cette approche, pour spécifier les options du serveur
mysqld-nt4.0.8, il faut créer un fichierC:\my-opts1.cnfqui ressemble à ceci :[mysqld] basedir = C:/mysql-4.0.8 port = 3307 enable-named-pipe socket = mypipe1
Pour la version 4.0.17 de
mysqld-nt, créez un fichierC:\my-opts2.cnfqui ressemble à ceci :[mysqld] basedir = C:/mysql-4.0.17 port = 3308 enable-named-pipe socket = mypipe2
Installez les services comme suit (entrez chaque commande comme une seule ligne) :
shell>
C:\mysql-4.0.8\bin\mysqld-nt --install mysqld1--defaults-file=C:\my-opts1.cnf shell>C:\mysql-4.0.17\bin\mysqld-nt --install mysqld2--defaults-file=C:\my-opts2.cnfPour utiliser l'option
--defaults-filelors de l'installation du serveur MySQL comme service, vous devez la faire précéder du nom de service.Après avoir installé les services, lancez et arrêtez les services de la même fa¸on que dans l'exemple précédent.
Pour supprimer plusieurs services, utilisez la commande mysqld --remove pour chacun d'entre eux, en spécifiant le nom du service, suivi de l'option --remove si le service a un nom qui n'est pas le nom par défaut.
Le plus simple pour utiliser plusieurs serveurs sous Unix, est de le compiler avec différents ports TCP/IP et sockets pour que chacun puisse utiliser une interface réseau différente. De plus, en compilant le serveur dans différents dossier de base, cela conduit automatiquement à la configuration de différents dossiers de données, fichiers de logs, et PID pour chaque serveur.
Supposons que le serveur existant est configuré avec le numéro de port (3306) et le fichier de socket par défaut (/tmp/mysql.sock). Pour configurer un nouveau serveur en ayant des paramètres opératoires différents, vous pouvez utiliser le script de configuration configure avec les options suivantes :
shell>./configure --with-tcp-port=port_number \--with-unix-socket-path=file_name \--prefix=/usr/local/mysql-4.0.17
Ici, port_number et file_name doivent être différents des valeurs par défaut de numéro de port et de chemin. La valeur --prefix doit spécifier un dossier d'installation différent de celui dans lequel le serveur existant est installé.
Si vous avez un serveur MySQL qui écoute sur un port donné, vous pouvez utiliser la commande suivante pour connaître ses caractéristiques, y compris son dossier de base et son fichier de socket :
shell> mysqladmin --host=host_name --port=port_number variables
Avec les informations affichées par la commande, vous pouvez savoir quelles valeurs ne doivent pas être utilisées lors de la configuration du nouveau serveur.
Notez que si vous spécifiez ``localhost'' comme nom d'hôte, mysqladmin va utiliser par défaut une socket Unix plutôt que TCP/IP. En MySQL 4.1, vous pouvez explicitement spécifier le protocole de connexion avec l'option --protocol={TCP | SOCKET | PIPE | MEMORY}.
Vous n'avez pas à compiler un nouveau serveur MySQL pour le lancer avec un numéro de port et une socket différente. Il est aussi possible de spécifier ces valeurs au moment du démarrage. Une méthode pour faire cela est d'utiliser les options de ligne de commande :
shell> /path/to/mysqld_safe --socket=file_name --port=port_number
Pour utiliser un dossier de données différent, utilisez l'option --datadir=path à mysqld_safe.
Un autre moyen pour arriver au même résultat est d'utiliser les variables d'environnement pour spécifier le nom de la socket et le numéro de port.
shell>MYSQL_UNIX_PORT=/tmp/mysqld-new.sockshell>MYSQL_TCP_PORT=3307shell>export MYSQL_UNIX_PORT MYSQL_TCP_PORTshell>scripts/mysql_install_dbshell>bin/mysqld_safe &
C'est une méthode rapide pour lancer un second serveur pour le tester. Le plus agréable de cette méthode est que les variables d'environnement vont être adoptées par les logiciels clients que vous invoquerez avec le même Shell. Par conséquent, les connexions seront automatiquement dirigées vers le nouveau serveur.
Annexe E, Variables d'environnement inclut une liste des variables d'environnement que vous pouvez utiliser pour affecter mysqld.
Pour les scripts de lancement automatique, votre script de démarrage qui est exécuté au démarrage doit utiliser la commande suivante avec les options appropriées pour chaque serveur :
mysqld_safe --defaults-file=path-to-option-file
Chaque fichier d'options doit contenir les valeurs spécifique du serveur.
Sous Unix, le script mysqld_multi est une autre méthode pour lancer plusieurs serveurs. See Section 5.1.5, « mysqld_multi, un programme pour gérer plusieurs serveurs MySQL ».
Lorsque vous voulez connecter un client à un serveur MySQL qui écoute sur différentes interfaces réseau que celles que vous utilisez sur votre client, vous devez utiliser les méthodes suivantes :
-
Lancez le client avec les options
--host=host_name --port=port_numberpour vous connecter via TCP/IP sur un hôte distant, ou avec--host=localhost --socket=file_namepour vous connecter localement, via les sockets Unix, ou un pipe nommé Windows. -
Depuis MySQL 4.1, lancez le programme avec l'option
--protocol=tcppour vous connecter via TCP/IP,--protocol=socketpour vous connecter via les socket Unix,--protocol=pipepour vous connecter via un pipe nommé, ou--protocol=memorypour vous connecter via la mémoire partagée. Pour TCP/IP, vous aurez peut être besoin d'indiquer les options d'hôte--hostet de port--port. Pour les autres types de connexion, vous aurez peut être besoin de spécifier l'option--socketpour indiquer la socket ou le pipe nommé, ou encore--shared-memory-base-namepour spécifier la mémoire partagée. -
Sous Unix, configurez les variables d'environnement
MYSQL_UNIX_PORTetMYSQL_TCP_PORTpour qu'elles pointent sur la socket Unix et le port TCP/IP que vous voulez, avant de lancer le client. Si vous utilisez normalement une socket ou un port spécifique, vous pouvez placer des commandes pour configurer ces variables dans votre script.login, afin que vous les ayez à chaque connexion. See Annexe E, Variables d'environnement. -
Spécifiez la socket par défaut et le port TCP/IP dans le groupe d'options
[client]du fichier d'options. Par exemple, vous pouvez utiliserC:\my.cnfsur Windows, ou.my.cnfdans votre dossier racine sous Unix. See Section 4.3.2, « Fichier d'optionsmy.cnf». -
Dans un programme C, vous pouvez spécifier le port ou la socket dans l'appel à
mysql_real_connect(). Vous pouvez aussi faire que le programme lise des fichiers d'options en utilisant la fonctionmysql_options(). See Section 24.2.3, « Description des fonctions de l'API C ». -
Si vous utilisez le module
DBD::mysql, vous pourrez lire les options dans les fichiers d'options MySQL. Par exemple :$dsn = "DBI:mysql:test;mysql_read_default_group=client;" . "mysql_read_default_file=/usr/local/mysql/data/my.cnf"; $dbh = DBI->connect($dsn, $user, $password);
Depuis la version 4.0.1, le MySQL server bénéficie d'un cache de requêtes. En fait, le cache sauvegrade le texte d'une requête SELECT avec le résultat qui a été envoyé au client. Si une requête identique est appelée par la suite, le serveur retournera le résultat à partir du cache plutôt que d'analyser puis exécuter la requête à nouveau.
Le cache de requêtes est extrêmement utile dans un environnement où les tables ne changent pas souvent, et que vous avez de nombreuses requêtes identiques. C'est la situation classique des serveurs Web, qui génèrent beaucoup de pages dynamiques à partir du même contenu.
Note: The query cache does not return stale data. When tables are modified, any relevant entries in the query cache are flushed.
Note : Le cache de requêtes ne retourne pas de données périmées. A chaques fois que les données sont modifiées, les entrées correspondantes dans le cache sont effacées.
Voici quelques performances du cache de requêtes. (Ces résultats on été générés en utilisant la suite benchmark MySQL sur un Linux Alpha 2 x 500 MHz avec 2GB RAM et un cache de requêtes de 64MB) :
-
Si toutes les requêtes que vous effectuez sont simples (comme séléctionner un champ d'une table n'en contenant qu'un) mais diffèrent d'une manière que toutes les requêtes ne peuvent être cachées, le gain lors de l'utilisation du cache est de 13%. Cela peut être considéré comme le pire des cas. En réalité, les requêtes sont plus compliquées que notre exemple le gain est donc plus petit.
-
Les recherches sur une colonne dans une table n'en contenant qu'une sont 238% plus rapides. Cela peut être considéré comme le gain minimal à attendre pour une requête cachée.
Si vous ne voulez pas utiliser le cache de requêtes paramétrez query_cache_size à zéro. En désactivant le cache de requête, il n'y a aucune surcharge apparente. (le cache de requêtes peut être désactivé à l'aide de l'option de configuration --without-query-cache)
Cette section décrit le fonctionnement du cache de requêtes lorsque ce dernier est opérationnel. La section Section 5.11.3, « Configuration du cache de requêtes » décrit comment contrôler ce cache, qu'il soit opérationnel ou pas.
Les requêtes sont comparées avant analyse, alors les deux requêtes suivantes seront considérées comme différentes pour le cache de requête :
SELECT * FROM tbl_name Select * from tbl_name
Les requêtes doivent être les mêmes (caractère à caractère) pour être considérées comme identiques. Les requêtes qui utilisent différentes bases de données, différents protocoles ou différents jeux de caractères sont alors considérées comme différentes, et mises en cache différemment.
Si un résultat de requête a été retourné depuis le cache de requête, alors la variable Com_select ne sera pas incrémenté, mais Qcache_hits le sera. See Section 5.11.4, « Statut du cache de requêtes et maintenance ».
Si une table change (INSERT, UPDATE, DELETE, TRUNCATE, ALTER ou DROP TABLE|DATABASE), alors toutes les requêtes mises en cache qui utilisaient cette table deviennent obsolètes et en sont retirées.
Les tables transactionnelles InnoDB qui ont été modifiées seront rendues obsolètes lorsqu'un COMMIT sera exécuté.
En MySQL 4.0, le cache de requêtes est désactivé dans les transactions : elles ne retourne pas le résultats. Depuis MySQL 4.1.1, le cache de requête fonctionne aussi dans les transactions avec les tables InnoDB : le serveur utilise le numéro de version de table pour détecter si le contenu est à jour ou non.
Avant MySQL 5.0, une requête qui commence avec un commentaire peut être mise en cache, mais ne sera jamais lue depuis le cache. Ce problème est résolu en MySQL 5.0.
Le cache de requête fonctionne pour les requêtes SELECT SQL_CALC_FOUND_ROWS ... et SELECT FOUND_ROWS(). Les requêtes FOUND_ROWS() retournent la valeur correcte même si la requête précédent a aussi été lue dans le cache, car le nombre de lignes lues est conservé dans le cache.
Une requête ne peut être mise en cache si elle contient l'une des fonctions suivantes :
BENCHMARK() |
CONNECTION_ID() |
CURDATE() |
CURRENT_DATE() |
CURRENT_TIME() |
CURRENT_TIMESTAMP() |
CURTIME() |
DATABASE() |
ENCRYPT() avec un paramètre |
FOUND_ROWS() |
GET_LOCK() |
LAST_INSERT_ID() |
LOAD_FILE() |
MASTER_POS_WAIT() |
NOW() |
RAND() |
RELEASE_LOCK() |
SYSDATE() |
UNIX_TIMESTAMP() sans paramètre |
USER() |
Une requête ne sera pas mise en cache dans ces conditions :
-
Elle contient des fonctions définies par l'utilisateur :
UDF. -
Elle contient des variables utilisateur.
-
Elle fait référence à des tables de la base
mysql. -
Elle est de l'une des formes suivantes :
SELECT ... IN SHARE MODE SELECT ... INTO OUTFILE ... SELECT ... INTO DUMPFILE ... SELECT * FROM ... WHERE autoincrement_col IS NULL
La dernière forme n'est pas mise en cache, car elle est utilisée comme palliatfi pour ODBC, afin d'obtenir la dernière valeur insérée. See Section 25.1.14.1, « Comment obtenir la valeur d'une colonne
AUTO_INCREMENTavec ODBC ». -
Elle utilise une table
TEMPORARY. -
Elle n'utilise pas de tables.
-
L'utilisateur a un droit de niveau colonne pour l'une des tables impliquée.
-
Avant la lecture de la requête dans le cache de requête, MySQL vérifie que l'utilisateur a les droits
SELECTpour toutes les bases de données impliquées. Si ce n'est pas le cas, le résultat n'est pas utilisé.
Il y a deux options relatives au cache de requêtes qui peuvent être utilisées dans une requête SELECT :
-
SQL_CACHELe résultat de la requête est en cache si la valeur de la variable système
query_cache_typeest àONouDEMAND. -
SQL_NO_CACHELe résultat de la requête n'est pas mis en cache.
Exemples:
SELECT SQL_CACHE id, name FROM customer; SELECT SQL_NO_CACHE id, name FROM customer;
La variable système serveur have_query_cache indique si le cache est actif :
mysql> SHOW VARIABLES LIKE 'have_query_cache';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| have_query_cache | YES |
+------------------+-------+
Le cache de requête ajoute plusieurs variables système MySQL liées à mysqld qui peuvent être spécifiées dans un fichier de configuration, en ligne de commande lors du démarrage de mysqld. Les variables systèmes liées au cache sont toutes préfixées avec query_cache_. Elles sont décrites brièvement dans la section Section 5.2.3, « Variables serveur système », avec des informations complémentaires.
Pour configurer la taille du cache de requêtes, modifiez la variable système query_cache_size. En lui donnant la valeur de 0, vous le désactivez. La taille par défaut du cache est de 0 : le cache est désactivé par défaut.
Si le cache de requête est actif, la variable query_cache_type modifie son comportement. Cette variable peut prendre les valeurs suivantes :
-
La valeur de
0ouOFFempêche la mise en cache ou la lecture de résultats en cache. -
La valeur de
1ouONpermet le cache, sauf pour les commandes qui commencent parSELECT SQL_NO_CACHE. -
La valeur de
2ouDEMANDimpose la mise en cache de toutes les requêtes, même celles qui commencent parSELECT SQL_CACHE.
Modifier la valeur GLOBAL de query_cache_type détermine le comportement du cache pour tous les clients qui se connecteront après la modification. Les clients individuels peuvent modifier le comportement du cache pour leur connexion avec l'option SESSION de query_cache_type. Par exemple, un client peut désactiver le cache de requête pour ses propres requêtes avec :
mysql> SET SESSION query_cache_type = OFF;
Pour contrôler la taille maximale des résultats de requêtes qui peuvent être mis en cache, il faut modifier la valeur de la variable query_cache_limit. La valeur par défaut de 1Mo.
Le résultat d'une requête (les données envoyées au client) sont stockées dans le cache durant la lecture. Par conséquent, les données ne sont pas manipulées en un seul gros morceau. Le cache de requête alloue des blocs à la demande, pour stocker les données, et dès qu'un bloc est rempli, un autre est alloué. Comme l'allocation de mémoire est une opération coûteuse (en temps), le cache de requêtes crée des blocs avec une taille minimale de query_cache_min_res_unit, jusqu'à la taille des données à mettre en cache. Suivant le type de requêtes exécutées, vous pourrez adapter la valeur de la variable query_cache_min_res_unit :
-
La valeur par défaut de
query_cache_min_res_unitest 4Ko. Cela doit être adapté la plupart des situations. -
Si vous avez beaucoup de requêtes avec de petits résultats, la taille par défaut sera un peu grande, et conduit à une fragmentation inutile de la mémoire, indiquée par un grand nombre de blocs libres. La fragmentation va forcer le cache à effacer d'anciennes requêtes pour libérer de la place. Dans ce cas, réduisez la valeur de
query_cache_min_res_unit. Le nombre de blocs libres et de requêtes supprimées pour libérer de la place sont stockées dans les variablesQcache_free_blocksetQcache_lowmem_prunes. -
Si la plupart de vos requêtes ont de grands résultats (vérifiez les variables
Qcache_total_blocksetQcache_queries_in_cache), vous pouvez augmenter la valeur dequery_cache_min_res_unit. Cependant, soyez prudent de ne pas aggrandir trop la valeur (voir point précédent).
query_cache_min_res_unit a été ajoutée en MySQL 4.1.
Vous pouvez vérifier que vous avez le cache de requête sur MySQL avec la commande suivante :
mysql> SHOW VARIABLES LIKE 'have_query_cache';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| have_query_cache | YES |
+------------------+-------+
1 row in set (0.00 sec)
Avec la commande FLUSH QUERY CACHE, vous pouvez défragmenter le cache de requêtes pour mieux en utiliser la mémoire. Cette commande n'effacera aucune requête du cache.
La commande RESET QUERY CACHE efface tous les résultats de requêtes du cache. FLUSH TABLES aussi.
Vous pouvez visualiser les performances du cache de requêtes avec SHOW STATUS:
mysql> SHOW STATUS LIKE 'Qcache%';
+-------------------------+--------+
| Variable_name | Value |
+-------------------------+--------+
| Qcache_free_blocks | 36 |
| Qcache_free_memory | 138488 |
| Qcache_hits | 79570 |
| Qcache_inserts | 27087 |
| Qcache_lowmem_prunes | 3114 |
| Qcache_not_cached | 22989 |
| Qcache_queries_in_cache | 415 |
| Qcache_total_blocks | 912 |
+-------------------------+--------+
La description de chaque variable est présentée dans la section Section 5.2.4, « Variables de statut du serveur ». Certaines utilisations sont présentées ici.
Le nombre total de commandes SELECT vaut :
Com_select + Qcache_hits + requêtes avec une erreur
La valeur de Com_select est :
Qcache_inserts + Qcache_not_cached + erreurs de droits d'accès ou de colonnes
Le cache de requêtes utilise des blocs de longueur variable, ce qui fait que Qcache_total_blocks et Qcache_free_blocks peuvent indiquer une fragmentation de la mémoire du cache. Après un appel à FLUSH QUERY CACHE un seul (grand) bloc libre subsiste.
Note : Chaque requête a besoin au minimum de deux blocs (un pour le texte de la requête et un autre, ou plus, pour le résultat). De même, chaque table utilisée par une requête a besoin d'un bloc, mais si deux ou plusieurs requêtes utilisent la même table, seul un bloc a besoin d'être alloué.
Vous pouvez aussi utiliser la variable Qcache_lowmem_prunes pour ajuster la taille du cache de requêtes. Elle compte le nombre de requêtes qui ont été supprimées du cache pour libérer de la place pour les nouvelles requêtes. Le cache de requêtes utilise une stratégie du type la plus anciennement utilisée (least recently used ou LRU) pour décider de quelle requête doit être retirée. Des informations de paramétrage sont données dans la section Section 5.11.3, « Configuration du cache de requêtes ».
This is a translation of the MySQL Reference Manual that can be found at dev.mysql.com. The original Reference Manual is in English, and this translation is not necessarily as up to date as the English version.
Remonter 
