![Используйте unix_socket в mysql с хостом, отличным от localhost](https://rvso.com/image/1609693/%D0%98%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D1%83%D0%B9%D1%82%D0%B5%20unix_socket%20%D0%B2%20mysql%20%D1%81%20%D1%85%D0%BE%D1%81%D1%82%D0%BE%D0%BC%2C%20%D0%BE%D1%82%D0%BB%D0%B8%D1%87%D0%BD%D1%8B%D0%BC%20%D0%BE%D1%82%20localhost.png)
Чтобы воспроизвести поведение некоторого скрипта на тестовом компьютере, мне нужно авторизовать MySQL с правами root через сокет Unix.
С sudo mysql все работает нормально, но когда я выполняю sudo mysql -h testhost, я получаю:
ERROR 1698 (28000): Access denied for user 'root'@'localhost'
Я добавил testhost в свой файл hosts
127.0.0.1 localhost testhost
Я также обновил гранты MySQL.
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED VIA unix_socket USING '*59D9CEFB549F231CFA8634AC47153FD4F3CCC29F' WITH GRANT OPTION |
| GRANT PROXY ON ''@'%' TO 'root'@'localhost' WITH GRANT OPTION
И
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED VIA unix_socket USING '*59D9CEFB549F231CFA8634AC47153FD4F3CCC29F'
решение1
«Unix-сокеты» — это не TCP/IP-сокеты. Онивсегдаограничено только текущей системой — невозможно подключиться к сокету другой системы по сети.
Из-за этого имя хоста localhost
является специальным в MySQL, и клиент фактически не пытается найти его IP-адрес.совсем. И когда вы подключаетесь к нему, вы не подключаетесь ни к 127.0.0.1, ни к ::1 — вы на самом деле подключаетесь к /var/run/mysqld/mysqld.sock
или к какому-то похожему пути.
Если вы хотите имитировать сетевое соединение, запустите mysql -h 127.0.0.1
или mysql -h ::1
.
Сетевые (TCP/IP) соединенияне могуиспользовать IDENTIFIED VIA unix_socket
, поскольку они не передают UID клиента (тем более не каким-либо уязвимым для безопасности способом). Они должны использовать пароли, сертификаты X.509 или GSSAPI.