转载:http://www.codegong.com/document/19 非常感谢
转载请注明来自 代码功 ,本文标题: centos 7 下安装mysql 远程连接出现10038错误如何解决, 转载请保留本声明!
centos7 安装完mysql后想使用远程连接mysql进行管理,但是并没有那么简单 cant connect to mysql server on 10038
对没错,肯定会出现这样那样的问题,解决方案
首先 设置远程访问权限 在mysql中执行语句
grant all privileges on *.* to 'root'@'%' identified by 'youpassword' with grant option;
*.* 允许远程访问的IP地址 .表示所有IP都可以根据root用户进行访问
youpassword就是mysql数据库密码
flush privileges; //刷新MySQL的系统权限相关表
quit; // 退出mysql
好了,试试可以连接成功吗?结果是否定的,还是不行,怎么办?防火墙,对
但是centos7的防火墙默认使用的是firewall作为防火墙,这里改为iptables防火墙步骤。
1、关闭firewall:
systemctl stop firewalld.service #停止firewall
systemctl disable firewalld.service #禁止firewall开机启动
firewall-cmd --state #查看默认防火墙状态(关闭后显示notrunning,开启后显示running)
2、iptables防火墙(这里iptables已经安装,下面进行配置,如果没有安装可先安装防火墙)
#先检查是否安装了iptables
service iptables status
#安装iptables
yum install -y iptables
#升级iptables(安装的最新版本则不需要)
yum update iptables
#安装iptables-services
yum install iptables-services
iptables没有问题后执行下面的命令
vi /etc/sysconfig/iptables #编辑防火墙配置文件
这时候会进入vi编辑,你会看到里面的配置信息
# sampleconfiguration for iptables service
# you can edit thismanually or use system-config-firewall
# please do not askus to add additional ports/services to this default configuration
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT[0:0]
:OUTPUT ACCEPT[0:0]
-A INPUT -m state--state RELATED,ESTABLISHED -j ACCEPT
-A INPUT -p icmp -jACCEPT
-A INPUT -i lo -jACCEPT
-A INPUT -p tcp -mstate --state NEW -m tcp --dport 22 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -jACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 8080-j ACCEPT
-A INPUT -j REJECT--reject-with icmp-host-prohibited
-A FORWARD -jREJECT --reject-with icmp-host-prohibited
COMMIT
:wq! #保存退出
当然,里面的这三行是没有的,把下面的三行配置添加到里面,如果编辑vi不会可以百度,实际上按i就进入编辑模式了,具体操作可以百度
-A INPUT -p tcp -mstate --state NEW -m tcp --dport 22 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -jACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 8080-j ACCEPT
完成后执行下面的命令
systemctl restart iptables.service #最后重启防火墙使配置生效
systemctl enable iptables.service #设置防火墙开机启动
如果还没解决可能是远程端口(3306)未对外开放。 可能是以下情况:
2、修改 /etc/mysql/mysql.conf.d ( 老版本的是这个目录:/etc/mysql/my.conf )
找到bind-address = 127.0.0.1这一行
改为bind-address = 0.0.0.0即可
参考:http://jingyan.baidu.com/article/63acb44add614761fcc17ec2.html