这篇文章主要介绍解决python3数据库主机拒绝无法连接的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

python3连接mysql数据库:

#!/usr/bin/python#-*-coding:UTF-8-*-importpymysql#打开数据库连接db=pymysql.connect("111.230.43.239","root","password","RUNBOO")#使用cursor()方法获取操作游标cursor=db.cursor()#使用execute方法执行SQL语句cursor.execute("SELECTVERSION()")#使用fetchone()方法获取一条数据data=cursor.fetchone()print("Databaseversion:%s"%data)#关闭数据库连接db.close()

报错:pymysql.err.InternalError: (1130, u”Host ‘218.20.44.100’ is not allowed to connect to this MySql server,MySQL不允许从远程访问

解决方法:

(1)添加用户允许从任何主机连接到mysql服务器

例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。

GRANTALLPRIVILEGESON*.*TO'myuser'@'%'IDENTIFIEDBY'mypassword'WITHGRANTOPTION;FLUSHPRIVILEGES;

如果你想允许用户root从ip为192.168.1.1的主机连接到mysql服务器,并使用password作为密码

GRANTALLPRIVILEGESON*.*TO'root'@'192.168.1.1'IDENTIFIEDBY'password'WITHGRANTOPTION;FLUSHPRIVILEGES;

如果你想允许用户root从ip为192.168.1.1的主机连接到mysql服务器的dk数据库,并使用password作为密码

GRANTALLPRIVILEGESONdk.*TO'root'@'192.168.1.1'IDENTIFIEDBY'password'WITHGRANTOPTION;FLUSHPRIVILEGES;

已经将任何主机允许连接到mysql服务器:

还是不行的话:

(2)修改防火墙设置,mysql默认3306端口,编辑防火墙

vi/etc/sysconfig/iptables增加端口-AINPUT-mstate--stateNEW-mtcp-ptcp--dport3306-jACCEPT

重启防火墙

serviceiptablesrestart

以上是解决python3数据库主机拒绝无法连接的方法的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!