我想要从我的本地计算机连接到EC2上的数据库,我无法这样做,并且已经尝试了所有方法-我正在使用以下命令连接到EC2:
mysql -uUSERNAME -hEC2_IP -pPASSWORD
生成此错误
错误2003 (HY000):无法连接到'IP‘上的MySQL服务器(110)
我用以下命令修改了my.cnf
skip networking
bind-address = 0.0.0.0
仍然无法连接到数据库
发布于 2012-03-21 05:02:00
可能存在以下原因之一:
请访问以下链接:How Do I Enable Remote Access To MySQL Database Server?
发布于 2012-04-03 04:37:10
正如上面的响应中提到的,它可能与AWS安全组和其他事情有关。但是,如果您创建了一个用户并为其提供了远程访问'%‘,但仍然收到此错误,请检查您的mysql配置文件,在debian上,您可以在以下位置找到它: /etc/mysql/my.cnf并找到行:
bind-address = 127.0.0.1
并将其更改为:
bind-address = 0.0.0.0
然后重启mysql。
在debian/ubuntu上:
/etc/init.d/mysql restart
我希望这对你有用。
发布于 2017-02-07 21:58:59
更新: 2017年2月
以下是用于远程访问MySQL的COMPLETE STEPS (部署在亚马逊EC2上):-
1.在入站规则中添加MySQL。
转到您的ec2实例的安全组,编辑入站规则并添加新规则,然后选择MySQL/Aurora
-> -> to Anywhere
。
2.将绑定地址= 0.0.0.0添加到my.cnf
在实例控制台:
sudo vi /etc/mysql/my.cnf
这将打开vi编辑器。
在my.cnf文件中,在[mysqld]
之后添加新行,并这样写:
bind-address = 0.0.0.0
通过输入:wq
(enter)保存文件
现在重新启动MySQL:
sudo /etc/init.d/mysqld restart
3.创建远程用户并授予权限。
登录到MySQL:
mysql -u root -p mysql
(之后输入密码)
现在编写以下命令:
CREATE USER 'jerry'@'localhost' IDENTIFIED BY 'jerrypassword';
CREATE USER 'jerry'@'%' IDENTIFIED BY 'jerrypassword';
GRANT ALL PRIVILEGES ON *.* to jerry@localhost IDENTIFIED BY 'jerrypassword' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON *.* to jerry@'%' IDENTIFIED BY 'jerrypassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
EXIT;
在此之后,可以通过输入实例的公共dns/ip作为MySQL主机地址、用户名作为jerry和密码作为jerrypassword来远程访问MySQL dB。(端口设置为默认端口3306)
https://stackoverflow.com/questions/9766014
复制相似问题