linux配置mysql数据库远程连接失败的解决方法
今天配置linux下mysql数据库可以远程访问的问题,百度这方面的资料有很多,但是方法都一样,都试过了却未能解决,记录一下
第一步:在/etc/mysql/my.cnf下找到bind-address = 127.0.0.1
在这行前加个"#"进行注释,或者改为: bind-address = 0.0.0.0
允许任意ip访问;或者指定自己需要远程访问的ip地址。
然后重启mysql:sudo /etc/init.d/mysql restart
第二步:授权用户能进行远程连接
grant all privileges on *.* to root@"%" identified by "password" with grant option; flush privileges;
第一行命令解释如下,*.*:第一个*代表数据库名;第二个*代表表名。这里的意思是所有数据库里的所有表都授权给用户,如果只是授权某数据库或数据库下某张表,则把*替换成你所需的数据库名和表明即可。root:授予root账号。“%”:表示授权的用户ip可以指定,这里代表任意的ip地址都能访问mysql数据库。“password”:分配账号对应的密码,这里密码自己替换成你的 root帐号密码
第二行命令是刷新权限信息,让我们设置的权限马上生效。
但是最终还是不能访问,此时考虑有可能是防火墙及mysql的3306端口问题.
通过命令netstar -a查询所有端口没看到3306,通过命令nerstat -an|grep 3306,什么都不显示,可以确定是3306端口不存在。
登录阿里云控制台,在云服务安全组新增规则,克隆一个规则出来并把端口号修改成mysql的3306,再次远程连接还是失败。
此时需控制台重启系统让新增的规则生效,重启后再次连接依然失败,此时本地的navicat软件连接返回的是拒绝访问错误而不再是之前的无法连接错误。
此时再次执行上方的第二步授权用户命令,重启apache mysql之后终于连接成功。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: PHP-redis中文文档介绍
下一篇: MySQL服务自动停止的解决方法
推荐阅读
-
连接服务器MySQL,配置远程登录连接的实例操作讲解
-
Centos7下无法远程连接mysql数据库的原因与解决
-
navicat for mysql远程连接ubuntu服务器的mysql数据库
-
Linux中无法远程连接数据库问题的解决方法
-
Linux连接mysql报错:Access denied for user ‘root’@‘localhost’(using password: YES)的解决方法
-
node.js平台下的mysql数据库配置及连接
-
Linux中 MySQL 授权远程连接的方法步骤
-
linux安装jdk,tomcat 配置vsftp远程连接的步骤
-
PLSQL 连接远程数据库,ORA-12638: 身份证明检索失败的解决方法
-
Linux服务器端SSH远程连接速度慢的解决方法