Comment gérer l'exception mysql innodb
1. Revenez en arrière et réinstallez mysql
Pour éviter d'avoir à importer ces données depuis d'autres endroits, faites d'abord une sauvegarde du fichier de base de données de la bibliothèque actuelle (/var/lib/mysql/location) . Ensuite, j'ai désinstallé le package du serveur Percona 5.7, réinstallé le package 5.1.71 d'origine et démarré le service mysql. Il a demandé Type de table inconnu/non pris en charge : innodb et n'a pas pu démarrer normalement.
110509 12:04:27 InnoDB: Initializing buffer pool, size = 384.0M 110509 12:04:27 InnoDB: Completed initialization of buffer pool InnoDB: Error: log file ./ib_logfile0 is of different size 0 5242880 bytes InnoDB: than specified in the .cnf file 0 157286400 bytes! 110509 12:04:27 [ERROR] Plugin 'InnoDB' init function returned error. 110509 12:04:27 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed. 110509 12:04:27 [ERROR] Unknown/unsupported table type: innodb 110509 12:04:27 [ERROR] Aborting 110509 12:04:27 [Note] /usr/sbin/mysqld: Shutdown complete
Supprimez le répertoire /var/lib/mysql/, redémarrez le service de base de données et initialisez-le. Cela s'avère normal. Les moteurs d'exposition peuvent trouver le moteur innodb. Arrêtez ensuite la base de données, écrasez le contenu du répertoire /var/lib/mysql/ précédemment sauvegardé par le contenu de l'emplacement actuel et redémarrez. J'ai également constaté qu'il ne pouvait pas être démarré et que le contenu de l'erreur était le même qu'avant. La structure du contenu du répertoire
/var/lib/mysql est la suivante :
-rw-rw---- 1 mysql mysql 10485760 2月 26 18:10 ibdata1 -rw-rw---- 1 mysql mysql 5242880 2月 26 18:10 ib_logfile0 -rw-rw---- 1 mysql mysql 5242880 2月 26 17:20 ib_logfile1 drwx------ 2 mysql mysql 4096 2月 26 17:20 mysql drwx------ 2 mysql mysql 4096 2月 26 17:24 wiki
Le répertoire wiki est la bibliothèque des données de test, le fichier ibdata1 est le fichier de données, les deux fichiers commençant par ib sont des fichiers journaux , et le répertoire mysql contient des éléments liés à la bibliothèque système. Utilisez à nouveau les données initialisées et écrasez le répertoire wiki et le fichier ibdata1 dans le répertoire /var/lib/mysql. Vous pouvez démarrer normalement et vous connecter normalement.
2. Réinstallez le module innodb
Cependant, lors de la sauvegarde via mysqldump, le moteur de table inconnu "Innodb" s'affiche. Après vous être connecté, vérifiez tous les types de moteurs actuels et constatez que le type innodb n'existe pas parmi eux :

Utilisez la commande alter pour modifier le type de l'une des tables en MyISAM, et constatez que l'erreur est toujours signalé.

Utilisez find pour découvrir qu'il existe un fichier ha_innodb_plugin.so dans le répertoire /usr/lib64/mysql/plugin/. J'ai l'impression que les versions ultérieures de mysql5 prennent en charge l'installation de plug-ins en ligne. Vérifiez les éléments suivants pour confirmer qu'il est bien pris en charge :

Lors du chargement à l'aide de la commande suivante, il a été constaté qu'il a échoué :
install plugin innodb soname 'ha_innodb.so';
3. Sauvegarde
Ajoutez la configuration suivante à /etc/my.cnf :
plugin-load=innodb=ha_innodb_plugin.so plugin_dir=/usr/lib64/mysql/plugin/ default-storage-engine=InnoDB
Il a été constaté que le démarrage échouait toujours. Vérifiez mysql-error.log et recherchez le contenu suivant :
InnoDB: Database page corruption on disk or a failed InnoDB: file read of page 7. InnoDB: You may have to recover from a backup. InnoDB: It is also possible that your operating InnoDB: system has corrupted its own file cache InnoDB: and rebooting your computer removes the InnoDB: error. InnoDB: If the corrupt page is an index page InnoDB: you can also try to fix the corruption InnoDB: by dumping, dropping, and reimporting InnoDB: the corrupt table. You can use CHECK InnoDB: TABLE to scan your table for corruption. InnoDB: See also http://dev.mysql.com/doc/refman/5.1/en/forcing-innodb-recovery.html
Ouvrez la page officielle forcing-innodb-recovery et constatez que vous pouvez forcer le démarrage et la récupération en spécifiant le paramètre innodb_force_recovery. Ajoutez le contenu suivant à /etc/my.cnf :
innodb_force_recovery=6
Le redémarrage a réussi. Il n'y a aucun problème avec la sauvegarde via mysqldump. L'importation des données de sauvegarde sur d'autres hôtes peut également s'avérer normale et peut être testée.
Maintenant, c'est facile. Supprimez complètement MySQL et réinstallez le serveur Percona 5.7. Après l'installation, créez la base de données, restaurez les données, reconnectez le programme et tout va bien.
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)

ToseCuremysQleffectively, useobject-levelprivilestolimitreaccessbasedheirSpecificneeds.binbyranding comptabilisation de l'objectif-levelprivilegesapplytodatabases, des tables, des orcolumns

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é.

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

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é

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

Les méthodes de base pour réaliser le suivi des liens sanguins de données MySQL incluent: 1. Utilisez le binlog pour enregistrer la source de changement de données, activer et analyser le binlog et tracer des actions commerciales spécifiques en combinaison avec le contexte de la couche d'application; 2. Injecter les liens de sang dans le processus ETL et enregistrer la relation de mappage entre la source et la cible lors de la synchronisation de l'outil; 3. Ajouter des commentaires et des balises de métadonnées aux données, expliquez la source de champ lors de la construction du tableau et connectez-vous au système de gestion des métadonnées pour former une carte visuelle; 4. Faites attention à la cohérence de la clé primaire, évitez une dépendance excessive à l'égard de l'analyse SQL, des changements de modèle de données de contrôle de version et vérifiez régulièrement les données de liens sanguins pour assurer le suivi précis et fiable des liens de sang.

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

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