您好,登錄后才能下訂單哦!
這篇文章主要介紹解決python3數(shù)據(jù)庫(kù)主機(jī)拒絕無(wú)法連接的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
python3連接mysql數(shù)據(jù)庫(kù):
#!/usr/bin/python # -*- coding: UTF-8 -*- import pymysql # 打開(kāi)數(shù)據(jù)庫(kù)連接 db = pymysql.connect("111.230.43.239","root","password","RUNBOO" ) # 使用cursor()方法獲取操作游標(biāo) cursor = db.cursor() # 使用execute方法執(zhí)行SQL語(yǔ)句 cursor.execute("SELECT VERSION()") # 使用 fetchone() 方法獲取一條數(shù)據(jù) data = cursor.fetchone() print ("Database version : %s " % data) # 關(guān)閉數(shù)據(jù)庫(kù)連接 db.close()
報(bào)錯(cuò):pymysql.err.InternalError: (1130, u”Host ‘218.20.44.100’ is not allowed to connect to this MySql server,MySQL不允許從遠(yuǎn)程訪問(wèn)
解決方法:
(1)添加用戶允許從任何主機(jī)連接到mysql服務(wù)器
例如,你想myuser使用mypassword從任何主機(jī)連接到mysql服務(wù)器的話。
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION; FLUSH PRIVILEGES;
如果你想允許用戶root從ip為192.168.1.1的主機(jī)連接到mysql服務(wù)器,并使用password作為密碼
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.1' IDENTIFIED BY 'password' WITH GRANT OPTION; FLUSH PRIVILEGES;
如果你想允許用戶root從ip為192.168.1.1的主機(jī)連接到mysql服務(wù)器的dk數(shù)據(jù)庫(kù),并使用password作為密碼
GRANT ALL PRIVILEGES ON dk.* TO 'root'@'192.168.1.1' IDENTIFIED BY 'password' WITH GRANT OPTION; FLUSH PRIVILEGES;
已經(jīng)將任何主機(jī)允許連接到mysql服務(wù)器:
還是不行的話:
(2)修改防火墻設(shè)置,mysql默認(rèn)3306端口,編輯防火墻
vi /etc/sysconfig/iptables 增加端口 -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
重啟防火墻
service iptables restart
以上是解決python3數(shù)據(jù)庫(kù)主機(jī)拒絕無(wú)法連接的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。