Centos6下MySQL远程连接失败
来源:SegmentFault
时间:2023-02-16 15:28:48 369浏览 收藏
编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《Centos6下MySQL远程连接失败》,文章讲解的知识点主要包括MySQL、centos6.5,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。
解决办法
之前遇到过MySQL本地可以连接但是远程连不上的问题,没有记录,今天又遇到这个问题,记录一下解决过程(MySQL版本5.5)。
1.先将mysql服务停掉
/etc/init.d/mysqld stop
2.查看mysql配置文件
vim /etc/my.cnf
****特别要注意****
bind_address和skip_networking
在bind_address前加个"#"进行注释,或者改为:bind-address = 0.0.0.0 允许任意IP访问;或者指定自己需要远程访问的IP地址。
bind_address一定不能为127.0.0.1,否则只能在本地连接;
skip_networking一定不能出现,否则只接受unix socket而不能提供tcp socket服务;
建议把两者都注释掉。
3.重启mysql服务
/etc/init.d/mysqld start
4.对用户授权,允许指定用户远程访问,最简单的方式是将mysql库中user表中的对应的用户的host设置为%,亦即允许该用户从任意ip远程访问
方法一:
use mysql; update user set host = '%' where user = 'root'; //这个命令执行错误时可略过 flush privileges; select host, user from user; //检查‘%’ 是否插入到数据库中
方法二:
grant all privileges on *.* to root@"%" identified by "password" with grant option;
第一行命令解释如下,*.*:第一个*代表数据库名;第二个*代表表名。
这里的意思是所有数据库里的所有表都授权给用户,如果只是授权某数据库或数据库下某张表,则把*替换成你所需的数据库名和表明即可。
root:授予root账号。%:表示授权的用户IP可以指定,这里代表任意的IP地址都能访问MySQL数据库。
password:分配账号对应的密码,这里密码自己替换成你的 root帐号密码
5.一般情况下此时就能满足远程访问的要求,但对于某些系统还需要检查防火墙设置,和ip访问策略,以防系统对网络访问的限制造成无法远程访问mysql
对于CentOS系统而言,最好检测iptables设置。具体步骤如下:
5.1 暂停iptables服务
service iptables stop
5.2 查看iptables配置文件
vim /etc/sysconfig/iptables
5.3 也许会看到如下内容
:OUTPUT ACCEPT [1009120:257185920] -A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT #-A INPUT -s 118.144.89.18 -p tcp -m tcp --dport 3306 -j ACCEPT #-A INPUT -s 123.127.177.239 -p tcp -m tcp --dport 3306 -j ACCEPT
建议直接开放3306端口,而不是仅限定某个ip才可以访问3306
5.4 重启iptables服务
service iptables start
参考资料
CentOS下mysql远程连接的失败的解决方法
MySQL本地可以连接,远程连接不上的问题
linux配置mysql数据库远程连接失败的解决方法
今天关于《Centos6下MySQL远程连接失败》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
195 收藏
-
334 收藏
-
420 收藏
-
165 收藏
-
397 收藏
-
489 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习