我知道这命令:
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数据库呢?我怎么做呢?基本上,我将这个数据库公开,这样每个人都可以访问它。
当前回答
GRANT ALL PRIVILEGES ON *.* TO 'user'@'ipadress'
其他回答
您可以通过编辑/etc/my.cnf来禁用所有安全:
skip-grant-tables
GRANT ALL PRIVILEGES ON *.* TO 'user'@'ipadress'
使用admin用户启动MYSQL mysql -u admin-user -p (PASSWORD ON PROMPT) 创建新用户: 创建用户“newuser”@“%”(% -> anyhost) 授予特权: 对db_name授权SELECT,DELETE,INSERT,UPDATE。*到'newuser'@'%'; 冲洗特权;
如果您正在运行EC2实例,不要忘记在MYSQL/Aurura安全组中添加入站规则。
需要更改配置文件才能通过本地主机启用连接。
要通过远程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了。
你需要修改mysql的配置文件:
开始编辑mysql配置文件
vim /etc/mysql/my.cnf
add:
bind-address = 0.0.0.0