首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >从远程服务器连接到亚马逊EC2上的mysql

从远程服务器连接到亚马逊EC2上的mysql
EN

Stack Overflow用户
提问于 2012-03-19 14:42:38
回答 20查看 159.4K关注 0票数 75

我想要从我的本地计算机连接到EC2上的数据库,我无法这样做,并且已经尝试了所有方法-我正在使用以下命令连接到EC2:

代码语言:javascript
复制
mysql -uUSERNAME -hEC2_IP -pPASSWORD

生成此错误

错误2003 (HY000):无法连接到'IP‘上的MySQL服务器(110)

我用以下命令修改了my.cnf

代码语言:javascript
复制
skip networking
bind-address            = 0.0.0.0

仍然无法连接到数据库

EN

回答 20

Stack Overflow用户

回答已采纳

发布于 2012-03-21 05:02:00

可能存在以下原因之一:

  1. 您需要在亚马逊安全组中输入一个条目,才能允许从您的计算机远程访问亚马逊EC2实例。:-我相信这是由您完成的,因为从您的问题看,您似乎已经使用0.0.0.0创建了一个条目,它允许每个人访问该计算机。
  2. MySql不允许用户从远程计算机连接:-默认情况下,MySql创建具有管理员访问权限的根用户id。但是root id的访问权限仅限于localhost。这意味着,如果您尝试从远程计算机访问MySql,则具有正确密码的根用户id将不起作用。要解决此问题,您需要允许根用户或其他数据库用户从远程计算机访问MySQL。我不建议允许root用户id从远程机器访问数据库。您可以使用通配符%指定任何远程计算机。
  3. 检查计算机的本地防火墙是否未启用。如果已启用,请确保端口3306已打开。

请访问以下链接:How Do I Enable Remote Access To MySQL Database Server?

票数 62
EN

Stack Overflow用户

发布于 2012-04-03 04:37:10

正如上面的响应中提到的,它可能与AWS安全组和其他事情有关。但是,如果您创建了一个用户并为其提供了远程访问'%‘,但仍然收到此错误,请检查您的mysql配置文件,在debian上,您可以在以下位置找到它: /etc/mysql/my.cnf并找到行:

代码语言:javascript
复制
bind-address            = 127.0.0.1

并将其更改为:

代码语言:javascript
复制
bind-address            = 0.0.0.0

然后重启mysql。

在debian/ubuntu上:

代码语言:javascript
复制
/etc/init.d/mysql restart

我希望这对你有用。

票数 91
EN

Stack Overflow用户

发布于 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

在实例控制台:

代码语言:javascript
复制
sudo vi /etc/mysql/my.cnf

这将打开vi编辑器。

在my.cnf文件中,在[mysqld]之后添加新行,并这样写:

代码语言:javascript
复制
bind-address = 0.0.0.0

通过输入:wq(enter)保存文件

现在重新启动MySQL:

代码语言:javascript
复制
sudo /etc/init.d/mysqld restart

3.创建远程用户并授予权限。

登录到MySQL:

mysql -u root -p mysql (之后输入密码)

现在编写以下命令:

代码语言:javascript
复制
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)

票数 57
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9766014

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档