Rumah > Artikel > pangkalan data > Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh
Jika anda perlu mengakses pangkalan data Mysql pelayan jauh, tetapi untuk tempoh keselamatan pangkalan data Mysql, langkah keselamatan ditetapkan untuk hanya membenarkan sambungan tempatan (iaitu, anda perlu log masuk ke pelayan untuk menggunakannya), yang lain Sambungan jauh tidak boleh diakses secara langsung, dan port yang sepadan telah diubah suai, jadi anda perlu menyambung ke pangkalan data berdasarkan ssh. Kaedah menyambung ke pangkalan data adalah serupa dengan sambungan antara muka dalam Navicat melalui SSH.
Navicat
Sambung ke pangkalan data
Jika anda ingin menyambung ke Mysql, anda perlu memasang pymysql
pip install pymysql
Pasang sshtunnel perpustakaan berasaskan ssh
pip install sshtunnel #当前最新 0.3.1版
Adalah disyorkan untuk memasang pustaka sshtunnel terkini. Pustaka versi lama mempunyai beberapa pepijat
Sambung ke Mysql berdasarkan ssh dokumentasi sshtunnel, yang mempunyai beberapa kes
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数据库连接成功') cursor = conn.cursor() ... #获取数据操作,此处省略 cursor.close() conn.close()
boleh merangkum sambungan di atas menjadi fungsi untuk memudahkan penggunaan di tempat lain
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数据库连接成功') cursor = conn.cursor() print('游标获取成功') try: print(f'执行查询语句:{sql} 参数:{args}') cursor.execute(sql,args) print('数据查询成功') conn.commit() print('事务提交成功') datas = cursor.fetchall() success = True except: print('数据查询失败') datas = None success = False print('正在关闭数据库连接') cursor.close() conn.close() return datas, success
Nota:
Apabila menggunakan pangkalan data, conn.commit()
, cursor.close()
dan conn.close()
mesti digunakan dengan cara yang standard untuk mengelakkan pepijat yang tidak diperlukan 🎜>
cursor.execute(sql,args)
Atas ialah kandungan terperinci Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!