我在本地机器上安装了 MySQL Community Edition 5.5,我想允许远程连接,以便我可以从外部源连接。
我怎样才能做到这一点?
sudo mysql_secure_installation
。供参考。
默认情况下,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/OSX 和 Windows)以使更改生效。
完成以上所有操作后,我仍然无法以 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;
update user set authentication_string=password('YOUR_PASSWORD') where user='root';
只是根据我的经验,您可以在此路径 /etc/mysql/mysql.conf.d/mysqld.cnf
下找到配置文件。
(我挣扎了一段时间才找到这条路)
sudo find /etc -iname 'mysql*.cnf'
就我而言,我试图连接到 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
希望这可以帮助。
远程登录的所有过程。远程登录默认关闭。您需要为所有 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
现在享受远程登录
请按照下面提到的步骤为 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
在使用 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
就这样。
我希望这有帮助
如果您的 MySQL 服务器进程仅在 127.0.0.1 或 ::1 上侦听,那么您将无法远程连接。如果您在 /etc/my.cnf
中有 bind-address
设置,这可能是问题的根源。
您还必须为非 localhost
用户添加权限。
127.0.0.1
之外的另一个 IP?
如果您从 brew
安装 MySQL,它实际上只在默认情况下侦听本地接口。要解决此问题,您需要编辑 /usr/local/etc/my.cnf
并将 bind-address
从 127.0.0.1
更改为 *
。
然后运行 brew services restart mysql
。
仅供参考,我为这个问题拉了几个小时。最后我打电话给我的托管服务提供商,发现在我的情况下,使用云服务器,在 1and1 的控制面板中,他们有一个二级防火墙,你必须克隆和添加端口3306. 添加后我直接进入..
对于需要它的人,如果您的防火墙服务正在运行,请检查防火墙端口 3306 是否也打开。
如果 mysqld
将 bind address 设置为环回/本地地址(例如 127.0.0.1
),则无法从远程主机访问服务器,因为无法从任何远程主机访问环回接口。
将此选项设置为 0.0.0.0
(对于 IPv4+6 为 ::
)以接受来自任何主机的连接,或者如果您只想允许一个接口上的连接,则设置为另一个外部可访问地址。
启用远程 root 访问可能很危险。如果您要设置具有更多限制性权限的用户帐户,那将是更好的选择。以下三个步骤应该可以做到。
确保以 bind-address ... 开头的行至少在您的 my.ini 或 my.cnf 文件中被注释掉。如果它不存在,请继续。您可以在 Windows 上的 C:\ProgramData\MySQL\MySQL Server 8.0 中找到此文件。然后,检查您正在与之建立连接的用户帐户在“限制主机匹配”字段中是否没有 localhost。虽然不建议这样做,但您可以将 % 放在该字段中以进行测试。您可以通过使用 MySQL Workbench 打开与服务器的本地连接来执行此操作,然后从菜单栏中转到服务器>用户和权限并找到要连接的用户帐户。
“限制主机匹配”字段是不允许您在非本地连接的。即,它将接受的连接限制为 IP 地址模式。理想情况下,您应该从静态 IP 地址或子网访问 MySQL 服务器,以便尽可能限制。
显然,您的防火墙应该允许 MySQL 服务器应用程序通过您想要的端口进行通信。您和您的服务器之间的物理网络设备应该允许在您要连接的端口上进行通信。 (通常为 3306 端口)
对于 OS X 的人来说,请注意 bind-address 参数通常是在 launchd plist 中设置的,而不是在 my.ini 文件中。因此,就我而言,我从 /Library/LaunchDaemons/homebrew.mxcl.mariadb.plist
中删除了 <string>--bind-address=127.0.0.1</string>
。
~/Library/LaunchAgents
有时需要在 Windows 上使用 pc 的名称
第一步)放入mysql的配置文件:
mysqld.cnf SET 绑定地址= 0.0.0.0
(让 recibe 通过 tcp/ip 连接)
第二步)在 mysql 中创建用户,表用户,在 windows 属性上使用 pc 名称,而不是 ip
https://i.stack.imgur.com/bXLab.png
检查远程服务器授予通配符访问端口 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
在链接 /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
不定期副业成功案例分享
my.cnf
文件但没有在其中找到bind-address
指令的人,请注意,在我的例子中(Ubuntu 16.04.2 上的 MySQL 版本 14.14)文件的位置是/etc/mysql/mysql.conf.d/mysqld.cnf
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
。我应该怎么办?