我知道这命令:
GRANT ALL PRIVILEGES
ON database.*
TO 'user'@'yourremotehost'
IDENTIFIED BY 'newpassword';
但它只允许我授予一个特定的IP地址来访问远程MySQL数据库。如果我想让任何远程主机都能访问这个MySQL数据库呢?我怎么做呢?基本上,我将这个数据库公开,这样每个人都可以访问它。
我知道这命令:
GRANT ALL PRIVILEGES
ON database.*
TO 'user'@'yourremotehost'
IDENTIFIED BY 'newpassword';
但它只允许我授予一个特定的IP地址来访问远程MySQL数据库。如果我想让任何远程主机都能访问这个MySQL数据库呢?我怎么做呢?基本上,我将这个数据库公开,这样每个人都可以访问它。
当前回答
适用于Ubuntu的是授予用户所有权限:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'yourpassword' WITH GRANT OPTION;
在/etc/mysql/mysql.conf.d/mysqld.cnf中设置绑定地址:
bind-address = 0.0.0.0
然后重新启动mysql守护进程:
service mysql restart
其他回答
进入“/etc/mysql/mysql.conf”目录。d”然后 编辑mysqld.cnf文件
纳米mysqld.cnf美元
bind-address = 127.0.0.1
mysqlx-bind-address = 127.0.0.1
编辑,
bind-address = 0.0.0.0
mysqlx-bind-address = 0.0.0.0
您可以通过以下命令解决MariaDB的问题:
注意:
GRANT ALL ON *.* to root@'%' IDENTIFIED BY 'mysql root password';
%是通配符。在本例中,它指所有IP地址。
使用该命令:
GRANT ALL ON yourdatabasename.* TO root@'%' IDENTIFIED BY 'yourRootPassword';
然后:
FLUSH PRIVILEGES;
然后注释掉文件"/etc/mysql/mysql.conf.d/mysql .cnf"(这是必须的!)
bind-address = 127.0.0.1
对我有用!
打开mysql控制台,执行以下命令(输入数据库名、用户名和密码):
GRANT ALL ON yourdatabasename。到管理员@“%” “yourRootPassword”;
然后执行:
冲洗特权;
打开命令行,使用任何具有root权限的编辑器打开/etc/mysql/mysql.conf.d/mysqld.cnf文件。
例如:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
然后注释掉下面这行:
Bind-address = 127.0.0.1
使用命令重新启动mysql以反映更改:
sudo service mysql restart
喜欢。)
要能够从任何IP地址连接到您的用户,请执行以下操作:
允许mysql服务器接受远程连接。打开mysqld.conf文件:
sudo gedit /etc/mysql/mysql.conf.d/mysqld.cnf
搜索以“bind-address”开头的行,并将其值设置为0.0.0.0
bind-address = 0.0.0.0
最后保存文件。
注意:如果你运行的是MySQL 8+,默认情况下bind-address指令不会出现在mysqld.cnf文件中。在这种情况下,将指令添加到文件/etc/mysql/mysql.conf.d/mysqld.cnf的底部。
现在重新启动mysql服务器,使用systemd或使用旧的service命令。这取决于你的操作系统:
sudo systemctl restart mysql # for ubuntu
sudo systemctl restart mysqld.service # for debian
最后,mysql服务器现在可以接受远程连接了。
现在我们需要创建一个用户并授予它权限,这样我们就可以使用该用户远程登录。
以root用户或其他具有root权限的用户连接MySQL数据库。
mysql -u root -p
现在在localhost和'%'通配符中创建所需的用户,并授予所有DB的权限。
CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypass';
CREATE USER 'myuser'@'%' IDENTIFIED BY 'mypass';
然后,
GRANT ALL ON *.* TO 'myuser'@'localhost';
GRANT ALL ON *.* TO 'myuser'@'%';
最后,别忘了冲洗特权
FLUSH PRIVILEGES;
注意:如果你在你的数据库服务器上配置了防火墙,你还需要打开端口3306 MySQL的默认端口来允许流量到MySQL。
希望这对你有所帮助;)