Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh

Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh

WBOY
WBOYke hadapan
2023-05-27 16:07:131324semak imbas

Latar Belakang

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.

Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh

Navicat

Bagaimana untuk menyambung ke pangkalan data Mysql dari jauh menggunakan Python berdasarkan ssh

Sambung ke pangkalan data

Pasang pustaka sokongan

  • 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

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()

Mentakrifkan Sendiri fungsi pertanyaan

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 🎜>

  • Adalah disyorkan untuk menggunakan kaedah ini apabila menghantar parameter
  • , mengelakkan risiko suntikan sql

    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!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam