ChatGPT解决这个技术问题 Extra ChatGPT

MySQL:如何允许远程连接到 mysql

我在本地机器上安装了 MySQL Community Edition 5.5,我想允许远程连接,以便我可以从外部源连接。

我怎样才能做到这一点?

Enable remote MySQL connection 的可能重复项
如果您碰巧使用 DigitalOcean,您可以尝试使用 sudo mysql_secure_installation。供参考。
不要对不是代码的文本使用代码格式。无关。
@EJP 为什么?出于好奇的诚实问题

I
Iftekhar Ahmed

默认情况下,MySQL 允许这样做。

默认情况下禁用的是远程 root 访问。如果要启用它,请在本地运行此 SQL 命令:

 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
 FLUSH PRIVILEGES;

然后在您的 my.cnf 文件中找到以下行并将其注释掉,该文件通常位于 Unix/OSX 系统上的 /etc/mysql/my.cnf 上。在某些情况下,该文件的位置是 /etc/mysql/mysql.conf.d/mysqld.cnf)。

如果是 Windows 系统,你可以在 MySQL 安装目录中找到它,通常是 C:\Program Files\MySQL\MySQL Server 5.5\,文件名是 my.ini

换线

 bind-address = 127.0.0.1

 #bind-address = 127.0.0.1

并重新启动 MySQL 服务器(Unix/OSXWindows)以使更改生效。


好的,所以我在文件末尾添加了 binnd-address = 127.0.0.1 并尝试使用来自外部主机的 Navicat 进行连接,但出现 10060 错误
嗯,你不需要添加它。就像我的回答说的那样,您需要将其注释掉,而不是添加它。默认情况下有一个,所以你需要找到它,并通过在它前面加上 # 来注释掉它
嗯,在 \MYsql Server 5.5\ 中只有 1 个名为 my-default.ini 的 ini 文件,唯一没有 # 的行是: sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
对于那些寻找 my.cnf 文件但没有在其中找到 bind-address 指令的人,请注意,在我的例子中(Ubuntu 16.04.2 上的 MySQL 版本 14.14)文件的位置是 /etc/mysql/mysql.conf.d/mysqld.cnf
我遵循并运行命令,但 mysql 返回 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IDENTIFIED BY '*****' WITH GRANT OPTION' at line 1 。我应该怎么办?
b
bounav

完成以上所有操作后,我仍然无法以 root 远程登录,但 Telnet 到端口 3306 确认 MySQL 正在接受连接。

我开始查看 MySQL 中的用户,发现有 multiple root users 的密码不同。

select user, host, password from mysql.user;

因此,在 MySQL 中,我再次set all the passwords for root,我终于可以以 root 的身份远程登录。

use mysql;
update user set password=PASSWORD('NEWPASSWORD') where User='root';
flush privileges;

这是对的。在执行其他答案中的步骤时,似乎创建了密码为空的用户帐户。所以你需要为他们添加密码。
我需要将接受的答案与这个答案结合起来,然后一切正常。
用于 5.7 及更高版本的 SQL update user set authentication_string=password('YOUR_PASSWORD') where user='root';
接受的答案设置密码并为我工作。
谢谢你,就像@James 一样,我必须将它与接受的答案结合起来才能修复。
C
Craig S. Anderson

只是根据我的经验,您可以在此路径 /etc/mysql/mysql.conf.d/mysqld.cnf 下找到配置文件。

(我挣扎了一段时间才找到这条路)


这在很大程度上取决于您使用的发行版。最好的方法是搜索它:sudo find /etc -iname 'mysql*.cnf'
我很欣赏“查找”命令。我是命令行新手,所以非常有帮助。谢谢!
我努力编辑 /etc/mysq/conf.d/mysql.cnf 几个小时,直到我发现这个答案。
在 Centos 7 上:查找 /etc -iname 'my*.cnf'
这很有帮助!到处都找不到。
K
Kushal

就我而言,我试图连接到 cent OS 上的远程 mysql 服务器。在经历了很多解决方案(授予所有权限、删除 ip 绑定、启用网络)之后,问题仍然没有得到解决。

事实证明,在研究各种解决方案时,我遇到了 iptables,这让我意识到 mysql 端口 3306 不接受连接。

这是关于我如何检查和解决此问题的小说明。

检查端口是否接受连接:

telnet (mysql server ip) [portNo]

添加 ip table 规则以允许端口上的连接:

iptables -A INPUT -i eth0 -p tcp -m tcp --dport 3306 -j ACCEPT

不建议将其用于生产环境,但如果您的 iptables 配置不正确,添加规则可能仍无法解决问题。在这种情况下,应执行以下操作:

service iptables stop

希望这可以帮助。


a
albus_severus

远程登录的所有过程。远程登录默认关闭。您需要为所有 ip 手动打开它..以授予所有 ip 访问权限

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password';

具体IP

GRANT ALL PRIVILEGES ON *.* TO 'root'@'your_desire_ip' IDENTIFIED BY 'password';

然后

flush privileges;

您可以检查您的用户主机和密码

SELECT host,user,authentication_string FROM mysql.user;

现在你的职责是改变这一点

bind-address = 127.0.0.1

你可以找到这个

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

如果你在那里找不到这个然后试试这个

sudo nano /etc/mysql/my.cnf

在此发表评论

#bind-address = 127.0.0.1

然后重启Mysql

sudo service mysql restart

现在享受远程登录


A
Antonio112009

请按照下面提到的步骤为 MySQL 用户设置通配符远程访问。

(1) 打开cmd。 (2) 导航到路径 C:\Program Files\MySQL\MySQL Server 5.X\bin 并运行此命令。 mysql -u root -p (3) 输入root密码。 (4) 执行以下命令提供权限。将 *.* 上的所有权限授予由“密码”标识的“用户名”@“IP”; USERNAME:您希望连接到 MySQL 服务器的用户名。 IP:您希望允许访问 MySQL 服务器的公共 IP 地址。 PASSWORD:使用的用户名的密码。 IP 可以替换为 % 以允许用户从任何 IP 地址进行连接。 (5) 执行命令刷新权限并退出。同花顺特权;出口;或 \q

https://i.stack.imgur.com/8bD4d.png


完成后,我的 root 仍然拒绝访问。我错过了什么?
您可以在第 4 步中尝试使用本地系统 IP 地址而不是 %。它应该工作。 % 表示任何 IP 地址。
P
Promise Preston

在使用 MySQL 服务器作为数据库的 Java 项目上工作时,我不得不面对这个挑战。

我是这样做的:

首先,确认你的 MySQL 服务器配置允许远程连接。使用您喜欢的文本编辑器打开 MySQL 服务器配置文件:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

向下滚动到 bind-address 行并确保将其注释掉或替换为 0.0.0.0(以允许所有远程连接)或替换为 Ip-您希望远程连接的地址

进行必要的更改后,保存并退出配置文件。通过重新启动 MySQL 服务来应用对 MySQL 配置文件所做的更改:

sudo systemctl restart mysql

接下来,登录到安装它的服务器上的 MySQL 服务器控制台:

mysql -u root -p

输入你的mysql用户密码

检查您希望的用户已经有权访问的主机。在我的情况下,用户是 root

SELECT host FROM mysql.user WHERE user = "root";

这给了我这个输出:

+-----------+
| host      |
+-----------+
| localhost |
+-----------+

接下来,我运行以下命令以授予 root 用户对名为 my_database 的数据库的远程访问权限:

USE my_database;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'my-password';

注意% 允许用户从网络上的所有主机进行远程访问。您可以使用命令 - GRANT ALL PRIVILEGES ON *.* TO 'root'@'Ip-Address' IDENTIFIED BY 'my-password'; 指定要授予用户访问权限的各个主机的 IP 地址

之后,我检查了用户现在可以访问的 hosts。在我的情况下,用户是 root

SELECT host FROM mysql.user WHERE user = "root";

这给了我这个输出:

+-----------+
| host      |
+-----------+
| %         |
| localhost |
+-----------+

最后,您可以尝试使用以下命令从另一台服务器连接到 MySQL 服务器:

mysql -u username -h mysql-server-ip-address -p

其中 u 代表用户,h 代表 mysql-server-ip-address,p 代表密码。所以在我的情况下是:

mysql -u root -h 34.69.261.158 -p

输入你的mysql用户密码

您应该根据您的 MySQL 服务器版本获得此输出:

Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.31 MySQL Community Server (GPL)

Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

资源How to Allow Remote Connections to MySQL

就这样。

我希望这有帮助


t
tadman

如果您的 MySQL 服务器进程仅在 127.0.0.1 或 ::1 上侦听,那么您将无法远程连接。如果您在 /etc/my.cnf 中有 bind-address 设置,这可能是问题的根源。

您还必须为非 localhost 用户添加权限。


奇怪,您的服务器怎么会“监听”除 127.0.0.1 之外的另一个 IP?
@Pacerier 127.0.0.1 仅绑定到环回接口。外部连接将不起作用。一个系统通常会有多个网络接口,每个网络接口都需要具体绑定,或者你可以使用 bind-all 0.0.0.0 地址。
T
Timmmm

如果您从 brew 安装 MySQL,它实际上只在默认情况下侦听本地接口。要解决此问题,您需要编辑 /usr/local/etc/my.cnf 并将 bind-address127.0.0.1 更改为 *

然后运行 brew services restart mysql


对于我的 ubuntu 16.04.4 服务器,绑定地址设置在 /etc/mysql/mysql.conf.d/mysqld.cnf
这不仅仅是使用 brew,任何 MySQL 都会有这个默认设置,只允许本地连接。
D
Dan

仅供参考,我为这个问题拉了几个小时。最后我打电话给我的托管服务提供商,发现在我的情况下,使用云服务器,在 1and1 的控制面板中,他们有一个二级防火墙,你必须克隆和添加端口3306. 添加后我直接进入..


这听起来非常适合您的情况。我不是网络知识的无穷无尽的来源,但你确定这个解决方案适用于这个问题吗?
我也遇到过这个问题。常见于云托管服务器,
我遇到过同样的问题。这对我有帮助。
Z
Zelkovar

对于需要它的人,如果您的防火墙服务正在运行,请检查防火墙端口 3306 是否也打开。


刚刚意识到完全禁用 Windows 防火墙也是不够的。我发现我需要禁用我的防病毒软件(Eset Endpoint Security)。现在我可以在我的 AV 中为 mysqld-nt.exe 添加异常后恢复 Windows 防火墙
K
Kasun Siyambalapitiya

此博客 How to setup a MySQL server on Local Area Network 将有助于从头开始设置 MySQL


@Kokodoko 我很高兴它做到了:)
W
Wesley Smith

如果 mysqldbind address 设置为环回/本地地址(例如 127.0.0.1),则无法从远程主机访问服务器,因为无法从任何远程主机访问环回接口。

将此选项设置为 0.0.0.0(对于 IPv4+6 为 ::)以接受来自任何主机的连接,或者如果您只想允许一个接口上的连接,则设置为另一个外部可访问地址。

Source


N
Nikola Petrovic

启用远程 root 访问可能很危险。如果您要设置具有更多限制性权限的用户帐户,那将是更好的选择。以下三个步骤应该可以做到。

确保以 bind-address ... 开头的行至少在您的 my.ini 或 my.cnf 文件中被注释掉。如果它不存在,请继续。您可以在 Windows 上的 C:\ProgramData\MySQL\MySQL Server 8.0 中找到此文件。然后,检查您正在与之建立连接的用户帐户在“限制主机匹配”字段中是否没有 localhost。虽然不建议这样做,但您可以将 % 放在该字段中以进行测试。您可以通过使用 MySQL Workbench 打开与服务器的本地连接来执行此操作,然后从菜单栏中转到服务器>用户和权限并找到要连接的用户帐户。

“限制主机匹配”字段是不允许您在非本地连接的。即,它将接受的连接限制为 IP 地址模式。理想情况下,您应该从静态 IP 地址或子网访问 MySQL 服务器,以便尽可能限制。

显然,您的防火墙应该允许 MySQL 服务器应用程序通过您想要的端口进行通信。您和您的服务器之间的物理网络设备应该允许在您要连接的端口上进行通信。 (通常为 3306 端口)


路由器中的端口(3306)转发帮助我谢谢。
有时它真的只是简单的事情:^) 很高兴我能提供帮助。
在 mSQL Workbench 中添加具有正确 IP 地址的正确用户..,就是这么简单。没有命令行。没有重新启动 mySQL。它立即生效。
t
tdmartin102

对于 OS X 的人来说,请注意 bind-address 参数通常是在 launchd plist 中设置的,而不是在 my.ini 文件中。因此,就我而言,我从 /Library/LaunchDaemons/homebrew.mxcl.mariadb.plist 中删除了 <string>--bind-address=127.0.0.1</string>


plist 文件的替代位置:~/Library/LaunchAgents
R
Rubén Ruíz

有时需要在 Windows 上使用 pc 的名称

第一步)放入mysql的配置文件:

mysqld.cnf SET 绑定地址= 0.0.0.0

(让 recibe 通过 tcp/ip 连接)

第二步)在 mysql 中创建用户,表用户,在 windows 属性上使用 pc 名称,而不是 ip

https://i.stack.imgur.com/bXLab.png


D
Duc Toan Pham

检查远程服务器授予通配符访问端口 3306 的权限:

须藤 lsof -i -P -n | grep 听

它不应该是这样的:

mysqld 23083 mysql 21u IPv4 145900142 0t0 TCP 127.0.0.1:3306 (LISTEN)

在这种情况下,我们需要更新 /etc/mysql/mysql.conf.d/mysqld.cnf 或 /etc/mysql/mariadb.conf.d/50-server.cnf :

绑定地址 = 127.0.0.1 --> 0.0.0.0

然后重启mysql“sudo service mysql restart”

为了测试来自客户端的 mySQL 连接:

nc -vz <主机地址> 3306


确保可通过以下方式访问开放端口 3306:sudo iptables -A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT #mysql
N
Nam Sama

在链接 /etc/mysql/mysql.conf.d/mysqld.cnf 或 /etc/mysql/my.cnf 处关闭评论:

bind-address = 127.0.0.1  =>>  #bind-address = 127.0.0.1

更改主机名,以便所有机器都可以访问它,在本地运行此 SQL 命令:

UPDATE mysql.user SET Host='%' WHERE Host='localhost' AND User='root';
FLUSH PRIVILEGES;

重启服务:

sudo service mysql restart

打开端口mysql:

sudo ufw allow 3306