我知道这命令:
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数据库呢?我怎么做呢?基本上,我将这个数据库公开,这样每个人都可以访问它。
当前回答
打开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连接,请以“root”用户登录并在mysql中运行以下查询。
CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON *.* TO 'username'@'localhost' WITH GRANT OPTION;
CREATE USER 'username'@'%' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
这将创建一个在本地主机和远程ip上都可以访问的新用户。
还要注释位于/etc/mysql/my.cnf中的my.cnf文件中的下面一行
bind-address = 127.0.0.1
重新启动mysql
sudo service mysql restart
现在你应该可以远程连接到你的mysql了。
只要创建一个用户到某个数据库
授予<database_name>的所有权限。* TO '<用户名>'@'%' IDENTIFIED BY '<密码>'
然后转到
执行nano /etc/mysql/mysql.conf.d/mysqld.cnf,将bind-address = 127.0.0.1修改为bind-address = 0.0.0.0
之后,您可以从任何IP连接到该数据库。
您可以通过以下命令解决MariaDB的问题:
注意:
GRANT ALL ON *.* to root@'%' IDENTIFIED BY 'mysql root password';
%是通配符。在本例中,它指所有IP地址。
我看到有很多答案,但除了公认的答案,它们都很长,很短,缺乏解释。由于我无法编辑,我正在添加我的答案。阿迪特问:
公开这个数据库,这样每个人都可以访问它
GRANT ALL PRIVILEGES
ON database.*
TO 'username'@'remote_host'
IDENTIFIED BY 'password';
上面的代码授予用户从一个给定的远程主机的权限,你可以允许一个用户从任何远程主机连接到MySQL通过更改'用户名'@'yourremotehost'到'用户名'@'%'。
因此,正确的查询授予用户从任何远程主机连接的权限是:
GRANT ALL PRIVILEGES
ON database.*
TO 'username'@'%'
IDENTIFIED BY 'password';
适用于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