Comment réinitialiser le mot de passe racine dans MySQL?
Arrêtez le service MySQL à l'aide de SystemCTL, Service ou STOP NET en fonction de votre système d'exploitation. 2. Démarrez MySQL en mode sans échec avec - Skip-Grant-Tables et --Skip-Networking pour contourner l'authentification. 3. Connectez-vous à MySQL en tant que racine sans mot de passe à l'aide de la racine MySQL -U. 4. Réinitialisez le mot de passe racine à l'aide de l'alter utilisateur pour MySQL 5.7 ou mettez à jour MySQL.User pour les anciennes versions, garantissant que toutes les entrées hôte root @ sont mises à jour. 5. Tuez le processus de mode sûr et redémarrez MySQL normalement via SystemCTL, Service ou Net Start. 6. Testez le nouveau mot de passe en vous connectant avec MySQL -U ROOT -P. Après réinitialisation, utilisez toujours un mot de passe fort, évitez de quitter MySQL en mode dangereux et envisagez d'utiliser des comptes d'administration dédiés pour les tâches régulières.
Si vous avez perdu l'accès à votre serveur MySQL parce que vous avez oublié le mot de passe racine, ne vous inquiétez pas - vous pouvez le réinitialiser en démarrant MySQL dans un mode spécial qui contourne le système d'autorisation. Voici comment le faire en toute sécurité et efficacement.

1. Arrêtez le service MySQL
Avant de réinitialiser le mot de passe, vous devez arrêter le serveur MySQL exécuté afin que vous puissiez le redémarrer en mode sans échec.
Sur Linux (en utilisant Systemd):

sudo systemctl stop mysql
ou
service sudo mysql stop
Sur macOS (s'il est installé via Homebrew):

Les services de brassage arrêtent mysql
Sur Windows (via l'invite de commande en tant qu'administrateur):
net stop mysql
2. Démarrez MySQL en mode sans échec (Skip Grant Tables)
Cette étape démarre MySQL sans charger les tables de subventions, ce qui vous permet de vous connecter sans mot de passe.
Sur Linux / macOS:
Courir:
sudo mysqld_safe --skip-grant-tables --skip-networking &
Remarque:
--skip-networking
empêche les connexions externes pour la sécurité pendant que vous réinitialisez le mot de passe.
Alternativement, si mysqld_safe
n'est pas disponible, utilisez:
Sudo MySQLD - Skip-Grant-Tables - Skip-Networking &
Sur Windows:
Accédez à votre répertoire MySQL Bin (par exemple, C:\Program Files\MySQL\MySQL Server XX\bin
) et exécuter:
MySQLD - Skip-Grant-Tables - Skip-Networking
Cela commencera MySQL en arrière-plan. Laissez cette fenêtre ouverte.
3. Connectez-vous à MySQL sans mot de passe
Ouvrez un nouveau terminal ou une invite de commande et connectez-vous directement:
racine mysql -u
Vous devriez maintenant être connecté sans être invité à un mot de passe.
4. Réinitialisez le mot de passe racine
Une fois à l'intérieur du shell MySQL, suivez ces étapes en fonction de votre version MySQL.
Pour MySQL 5.7 et plus tard:
Mettez à jour le mot de passe à l'aide ALTER USER
:
Modifier l'utilisateur 'root' @ 'localhost' identifié par 'your_new_secure_password'; Privilèges de rinçage;
Assurez-vous d'utiliser
'root'@'localhost'
- c'est sensible à la casse et spécifique à l'utilisateur / hôte.
Pour MySQL 5.6 et plus tôt:
Utilisez la méthode plus ancienne avec la table mysql.user
:
Mettre à jour mysql.user set authentication_string = mot de passe ('your_new_secure_password') où user = 'root'; Privilèges de rinçage;
Remarque: La fonction
PASSWORD()
est obsolète dans les versions plus récentes, alors évitez-la si vous êtes sur 5.7.
Si vous n'êtes pas sûr de l'hôte, vérifiez avec:
Sélectionnez l'utilisateur, hôte dans mysql.user;
Vous devrez peut-être également mettre à jour d'autres entrées racine comme 'root'@'127.0.0.1'
ou 'root'@'::1'
.
5. Redémarrez MySQL normalement
Après avoir réinitialisé le mot de passe, fermez l'instance MySQL en cours de sécurité.
Trouvez l'ID de processus:
PS aux Aux | grep mysqld
Puis tuez-le:
sudo kill <Process_id>
Redémarrez maintenant le service MySQL normalement:
sudo systemctl start mysql
ou
service sudo mysql start
Sur Windows:
net start mysql
6. Testez le nouveau mot de passe
Connectez-vous à nouveau à l'aide du nouveau mot de passe:
mysql -u root -p
Entrez votre nouveau mot de passe lorsque vous y êtes invité. Si vous entrez, la réinitialisation a réussi.
Conseils de sécurité après réinitialisation
- Ne partez pas
--skip-grant-tables
en cours d'exécution - il désactive tous les contrôles d'accès. - Utilisez un mot de passe fort.
- Envisagez de créer un utilisateur d'administration dédié au lieu d'utiliser régulièrement Root.
- Assurez-vous que votre version MySQL est à jour.
La réinitialisation du mot de passe racine nécessite des temps d'arrêt temporaires et une manipulation minutieuse, mais il s'agit d'une procédure de récupération standard. Assurez-vous simplement de redémarrer MySQL normalement par la suite afin que la sécurité soit restaurée.
Fondamentalement, arrêtez MySQL → Commencez par --skip-grant-tables
→ Connectez-vous → Modifier le mot de passe → Redémarrer normalement. Pas complexe, mais facile à gâcher si vous sautez des étapes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Lorsque vous traitez avec de grandes tables, les performances MySQL et la maintenabilité sont confrontées à des défis, et il est nécessaire de commencer à partir de la conception structurelle, de l'optimisation des index, de la stratégie de sous-table de tableau, etc. 1. Concevoir raisonnablement les clés et les index primaires: il est recommandé d'utiliser des entiers auto-incrémentés comme clés principales pour réduire les scintillement de pages; Utiliser les index de superposition pour améliorer l'efficacité de la requête; Analyser régulièrement les journaux de requête lents et supprimer les index non valides. 2. Utilisation rationnelle des tables de partition: partition en fonction de la plage de temps et d'autres stratégies pour améliorer l'efficacité de la requête et de la maintenance, mais l'attention devrait être accordée aux problèmes de partitionnement et de coupe. 3. Envisagez de lire et d'écrire la séparation et la séparation des bibliothèques: la séparation de lecture et d'écriture atténue la pression sur la bibliothèque principale. La séparation de la bibliothèque et la séparation des tableaux conviennent aux scénarios avec une grande quantité de données. Il est recommandé d'utiliser des middleware et d'évaluer les problèmes de requête des transactions et des magasins croisés. La planification précoce et l'optimisation continue sont la clé.

MySQL prend en charge les contraintes de contrôle pour forcer l'intégrité du domaine, efficace à partir de la version 8.0.16; 1. Ajoutez des contraintes lors de la création d'un tableau: utilisez crééTable pour définir les conditions de contrôle, telles que l'âge ≥ 18, salaire> 0, valeurs limites du département; 2. Modifiez le tableau pour ajouter des contraintes: utilisez alterTableAddConstraint pour limiter les valeurs de champ, telles que le nom non vide; 3. Utiliser des conditions complexes: Prise en charge la logique et les expressions multi-colonnes, telles que la date de fin ≥ Date et l'état d'achèvement doivent avoir une date de fin; 4. Supprimer les contraintes: utilisez alterTabledRopConstraint pour spécifier le nom à supprimer; 5. Remarques: MySQL8.0.16, Innodb ou Myisam doit être cité

Useamany-to-gyrelateeshipswithajunctiontabletolinkitemsandtagsviathreetables: éléments, tags, anditem_tags.2.whenaddingtags, checkforexistingtagsinthetagstable, insertifnecessary, thencreatemappingsinitem_tagsusingtransactionsforcencence..

Vérifiez si le service MySQL est en cours d'exécution, utilisez SudosystemctlStatusMysQL pour confirmer et démarrer; 2. Assurez-vous que Bind-Address est défini sur 0,0.0.0 pour permettre les connexions distantes et redémarrer le service; 3. Vérifiez si le port 3306 est ouvert, vérifiez et configurez les règles de pare-feu pour permettre le port; 4. Pour l'erreur "AccessEnedy", vous devez vérifier le nom d'utilisateur, le mot de passe et le nom d'hôte, puis vous connecter à MySQL et interroger la table MySQL.User pour confirmer les autorisations. Si nécessaire, créez ou mettez à jour l'utilisateur et autorisez-le, comme l'utilisation de «votre_user» @ «%»; 5. Si l'authentification est perdue à cause de Caching_Sha2_Password

Pour afficher toutes les bases de données dans MySQL, vous devez utiliser la commande showDatabases; 1. Après être connecté au serveur MySQL, vous pouvez exécuter les showDatabases; Commande pour répertorier toutes les bases de données auxquelles l'utilisateur actuel a la permission d'accéder; 2. 3. Vous pouvez également interroger et filtrer la base de données via selectSchema_namefrominformation_schema.schemata; Par exemple, l'exclusion de la base de données système pour afficher uniquement la base de données créée par les utilisateurs; Assurez-vous d'utiliser

DeleterMovesspecificorAllRows, KeepSableStructure, permet de faire des effectifs et de surgurer de manière

CheckCompatibilitéwithos, Applications et Features; 2.BackupallData, Configs, andlogs; 3.ChooseupgradeMethod (PackageManager, MySQLinstaller, Ormanual); 4.Runpost-upgradeCkEckSandtests; 5.ResolvessueslikEuthenticationpluginsordepreatedOptions.

Pour ajouter une clé primaire à une table existante, utilisez l'instruction altertable avec la clause AddPrimaryKey. 1. Assurez-vous que la colonne cible n'a pas de valeur nulle, pas de duplication et est définie comme notnull; 2. La syntaxe de clé primaire à colonne unique est le nom de table altertable addPrimaryKey (nom de colonne); 3. La syntaxe de la clé primaire de combinaison multi-colonnes est le nom de table altertable addPrimaryKey (colonne 1, colonne 2); 4. Si la colonne permet Null, vous devez d'abord exécuter Modify pour définir Notnull; 5. Chaque tableau ne peut avoir qu'une seule clé primaire et l'ancienne clé primaire doit être supprimée avant d'ajouter; 6. Si vous avez besoin de l'augmenter vous-même, vous pouvez utiliser Modify pour définir Auto_Increment. Assurer les données avant le fonctionnement
