【问题标题】:Connect to MySQL database (over SSH) in python script在 python 脚本中连接到 MySQL 数据库(通过 SSH)
【发布时间】:2021-12-31 02:15:27
【问题描述】:

我需要访问在另一台计算机(计算机 B)上运行的 MySQL 数据库。不幸的是,这些计算机不在同一个本地网络上。我发现我可以从我的笔记本电脑(计算机 A)访问计算机 B 上的 SQL 数据库的唯一方法是通过 SSH。

我的问题是,我可以从 python 通过 SSH 访问 SQL 数据库吗?

【问题讨论】:

  • 你想通过 OS 还是 python 创建隧道。从操作系统你可以尝试:ssh -N -L localhost:3306:localhost:3306 -p 22 root@dbserver.de 然后你可以通过 python 连接到 127.0.0.1 端口 3306
  • 为了清楚起见,您是说您可以访问服务器(计算机 B)上的 22 端口,但不能访问 3306 端口?

标签: python mysql ssh


【解决方案1】:

你可以使用这个sn-p:

import pymysql
import paramiko
import pandas as pd
from paramiko import SSHClient
from sshtunnel import SSHTunnelForwarder
from os.path import expanduser

home = expanduser('~')
mypkey = paramiko.RSAKey.from_private_key_file(home + pkeyfilepath)
# if you want to use ssh password use - ssh_password='your ssh password', bellow

sql_hostname = 'sql_hostname'
sql_username = 'sql_username'
sql_password = 'sql_password'
sql_main_database = 'db_name'
sql_port = 3306
ssh_host = 'ssh_hostname'
ssh_user = 'ssh_username'
ssh_port = 22
sql_ip = '1.1.1.1.1'

with SSHTunnelForwarder(
        (ssh_host, ssh_port),
        ssh_username=ssh_user,
        ssh_pkey=mypkey,
        remote_bind_address=(sql_hostname, sql_port)) as tunnel:
    conn = pymysql.connect(host='127.0.0.1', user=sql_username,
            passwd=sql_password, db=sql_main_database,
            port=tunnel.local_bind_port)
    query = '''SELECT VERSION();'''
    data = pd.read_sql_query(query, conn)
    conn.close()

【讨论】:

  • 好的,谢谢。我使用的是 SQLExpress,所以没有端口(SQLExpress 使用动态端口)。你知道我如何修改 pymysql.connect() 以使用 SQLExpress 吗?
猜你喜欢
  • 2015-05-15
  • 1970-01-01
  • 2013-08-06
  • 1970-01-01
  • 2021-10-03
  • 1970-01-01
  • 2016-10-25
  • 2012-05-10
  • 2014-09-17
相关资源
最近更新 更多