Python基于ssh遠程連接Mysql數(shù)據(jù)庫操作
背景
如果需要訪問遠程服務(wù)器的Mysql數(shù)據(jù)庫,但是該Mysql數(shù)據(jù)庫為了安全期間,安全措施設(shè)置為只允許本地連接(也就是你需要登錄到該臺服務(wù)器才能使用),其他遠程連接是不可以直接訪問,并且相應(yīng)的端口也做了修改,那么就需要基于ssh來連接該數(shù)據(jù)庫。這種方式連接數(shù)據(jù)庫與Navicat里面界面化基于ssh連接一樣。

Navicat

連接數(shù)據(jù)庫
安裝支持庫
- 如果要連接Mysql,首先需要安裝pymysql
pip install pymysql
- 安裝基于ssh的庫sshtunnel
pip install sshtunnel #當(dāng)前最新 0.3.1版
建議安裝最新的sshtunnel庫,舊版本庫有一些bug
連接Mysql
基于ssh連接Mysql可以查看sshtunnel的文檔,里面有一些案例
with SSHTunnelForwarder(
('192.168.1.1', 2222),
ssh_password='123456',
ssh_username='root',
remote_bind_address=('127.0.0.1', 3306)) as server:
print('SSH連接成功')
conn = pymysql.connect(host='127.0.0.1',
port=server.local_bind_port,
user='root',
database='data',
charset='utf8')
print('mysql數(shù)據(jù)庫連接成功')
cursor = conn.cursor()
... #獲取數(shù)據(jù)操作,此處省略
cursor.close()
conn.close()
自定義查詢函數(shù)
可以對上面的連接進行封裝為一個函數(shù),方便其他地方使用
def mysql_ssh(sql,args=None):
with SSHTunnelForwarder(
('192.168.1.1', 2222),
ssh_password='123456',
ssh_username='root',
remote_bind_address=('127.0.0.1', 3306)) as server:
print('SSH連接成功')
conn = pymysql.connect(host='127.0.0.1',
port=server.local_bind_port,
user='root',
database='data',
charset='utf8')
print('mysql數(shù)據(jù)庫連接成功')
cursor = conn.cursor()
print('游標(biāo)獲取成功')
try:
print(f'執(zhí)行查詢語句:{sql} 參數(shù):{args}')
cursor.execute(sql,args)
print('數(shù)據(jù)查詢成功')
conn.commit()
print('事務(wù)提交成功')
datas = cursor.fetchall()
success = True
except:
print('數(shù)據(jù)查詢失敗')
datas = None
success = False
print('正在關(guān)閉數(shù)據(jù)庫連接')
cursor.close()
conn.close()
return datas, success
注意點:
- 在使用數(shù)據(jù)庫時,
conn.commit()、cursor.close()、conn.close()這些一定要規(guī)范使用,防止不必要的bug - 傳入?yún)?shù)時建議用這種方式
cursor.execute(sql,args),防止sql注入的風(fēng)險
相關(guān)參考:
Python加載txt數(shù)據(jù)亂碼問題升級版解決方法
以上就是Python基于ssh遠程連接Mysql數(shù)據(jù)庫操作的詳細內(nèi)容,更多關(guān)于Python ssh遠程連接Mysql的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python PyQt5中QRadioButton的詳細使用教程與應(yīng)用實戰(zhàn)
PyQt5是一個跨平臺的GUI工具包,用于創(chuàng)建具有Python綁定的Qt應(yīng)用程序,在PyQt5中,QRadioButton是一個非常有用的控件,用于在用戶界面上提供單選選項,本文將詳細介紹QRadioButton的基本用法、常用屬性和方法,需要的朋友可以參考下2024-08-08
Python面向?qū)ο缶幊剃P(guān)鍵深度探索類與對象
這篇文章主要為大家介紹了Python面向?qū)ο缶幊剃P(guān)鍵深度探索類與對象示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05
對Python中g(shù)ensim庫word2vec的使用詳解
今天小編就為大家分享一篇對Python中g(shù)ensim庫word2vec的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
Python使用GeekConcurrent實現(xiàn)量化編程
這篇文章主要為大家詳細介紹了Python中的協(xié)程并發(fā)編程以及如何使用GeekConcurrent庫來實現(xiàn)面向量化編程,感興趣的小伙伴可以了解一下2025-02-02
關(guān)于python的bottle框架跨域請求報錯問題的處理方法
這篇文章主要介紹了關(guān)于python的bottle框架跨域請求報錯問題的處理方法,需要的朋友可以參考下2017-03-03

