Heim >Datenbank >MySQL-Tutorial >Warum behandelt MySQL „localhost' und „127.0.0.1' bei der Gewährung von Berechtigungen unterschiedlich?
Localhost vs. 127.0.0.1: Der seltsame Fall von MySQL-Berechtigungen
Bei der Arbeit mit MySQL stößt man häufig auf scheinbar verwirrende Unterschiede zwischen den Begriffen „localhost“ und „127.0.0.1“. Dieser Unterschied zeigt sich im Zusammenhang mit der Gewährung von Berechtigungen an Benutzer innerhalb des Datenbanksystems.
Betrachten Sie zur Veranschaulichung das folgende Beispiel:
$ mysql -u root -h 127.0.0.1 -e 'show tables' created_from_host; +-----------------------------+ | Tables_in_created_from_host | +-----------------------------+ | test | +-----------------------------+ $ mysql -u root -h localhost -e 'show tables' created_from_host; ERROR 1049 (42000): Unknown database 'created_from_host'
Diese Diskrepanz entsteht, weil MySQL zwischen Verbindungen unterscheidet, die über a hergestellt werden Hostname (z. B. „localhost“) und über einen Socket hergestellte Verbindungen (z. B. „127.0.0.1“). Die Socket-Methode, die verwendet wird, wenn kein Hostname angegeben ist oder wenn eine Verbindung mit „localhost“ hergestellt wird, verwendet einen lokalen Socket für die Kommunikation mit dem Datenbankserver.
Diese Unterscheidung wird im Bereich der Benutzerrechte von Bedeutung. Hier ist eine einfache Anleitung zum Gewähren ALLER Berechtigungen für ALLE Datenbanken von ALLEN Hosts für „root“:
Stellen Sie mit dem Root-Konto eine Verbindung zu MySQL her:
$ mysql -u root -p
Führen Sie den folgenden Befehl aus, um die zu gewähren Berechtigungen:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
Löschen Sie die Berechtigungen, um sicherzustellen, dass die Änderungen wirksam werden:
FLUSH PRIVILEGES;
Durch Befolgen dieser Schritte können Sie sicherstellen dass „root“ von jedem Host aus uneingeschränkten Zugriff auf Ihr Datenbanksystem hat, unabhängig davon, ob dieser über „localhost“ oder verbunden ist '127.0.0.1'.
Das obige ist der detaillierte Inhalt vonWarum behandelt MySQL „localhost' und „127.0.0.1' bei der Gewährung von Berechtigungen unterschiedlich?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!