《python》paramiko+paramiko实现远程通过ssh通道连接数据库

阿丹:

在一些特定的场景下面,需要使用线上的数据库。但是正常使用连接肯定是连接不上的,所以这里就需要使用ssh通道来连接线上的数据库。

复制代码
pip install paramiko pymysql

下面是示例代码:

python 复制代码
import paramiko
import pymysql

# SSH隧道配置
ssh_host = 'your_ssh_server_ip'
ssh_port = 22
ssh_user = 'your_ssh_username'
ssh_password = 'your_ssh_password'

# MySQL数据库配置
mysql_host = 'your_mysql_host_or_ip'  # 这里填写MySQL的实际地址,如果通过SSH隧道访问localhost即可
mysql_port = 3306
mysql_user = 'your_mysql_username'
mysql_password = 'your_mysql_password'
mysql_db = 'your_database_name'

def create_ssh_tunnel(ssh_host, ssh_port, ssh_user, ssh_password, remote_bind_address, local_bind_port):
    """创建SSH隧道"""
    transport = paramiko.Transport((ssh_host, ssh_port))
    transport.connect(username=ssh_user, password=ssh_password)
    
    # 设置转发规则,将本地端口转发到远程MySQL服务器
    channel = transport.open_channel("direct-tcpip", (remote_bind_address, mysql_port), ('', local_bind_port))
    return channel

def query_mysql_via_tunnel(mysql_user, mysql_password, mysql_db, local_bind_port):
    """通过SSH隧道连接MySQL并执行查询"""
    conn = pymysql.connect(host='127.0.0.1', port=local_bind_port, user=mysql_user, passwd=mysql_password, db=mysql_db)
    try:
        with conn.cursor() as cursor:
            cursor.execute('SELECT VERSION()')
            result = cursor.fetchone()
            print("MySQL version:", result)
    finally:
        conn.close()

if __name__ == "__main__":
    # 创建SSH隧道
    local_bind_port = 3307  # 选择一个未被占用的本地端口
    tunnel = create_ssh_tunnel(ssh_host, ssh_port, ssh_user, ssh_password, (mysql_host, mysql_port), local_bind_port)
    
    try:
        # 通过隧道连接MySQL并执行查询
        query_mysql_via_tunnel(mysql_user, mysql_password, mysql_db, local_bind_port)
    finally:
        # 关闭SSH连接
        tunnel.close()

请注意,需要将上述代码中的your_ssh_server_ipyour_ssh_usernameyour_ssh_passwordyour_mysql_host_or_ipyour_mysql_usernameyour_mysql_password以及your_database_name替换为实际的值。此外,确保你有权限通过SSH访问目标服务器,并且MySQL服务器允许来自SSH服务器的连接。

相关推荐
企服AI产品测评局14 分钟前
2026年Agent元年!深度解析实在Agent未来路线图:从自动化工具到全能数字员工的跃迁
运维·人工智能·ai·chatgpt·自动化
Leo.yuan16 分钟前
运维视角下的数据同步工具选型指南:2026年主流方案功能对比
运维
秋漓18 分钟前
Nginx学习与应用
运维·学习·nginx
TDengine (老段)19 分钟前
TDengine 数据修复与迁移 — VGroup 调度、S3 外挂与运维操作
大数据·运维·数据库·物联网·时序数据库·iot·tdengine
utf8mb4安全女神38 分钟前
shell中的判断语法
linux·运维·服务器
iDao技术魔方1 小时前
WSL 配 GPU 用 Docker 的折腾指南(2026 年版)
运维·docker·容器
2601_950368911 小时前
稀土合金粉末采购指南:3步筛选靠谱镁钆供应商
大数据·运维·人工智能·python
mifengxing1 小时前
操作系统(五)
linux·运维·服务器·操作系统·王道考研
跳动的世界线1 小时前
WSL 2 + Docker 本地全栈开发环境配置指南
运维·docker·容器
We Just Keep growing2 小时前
【MySQL运维篇】——日志、主从复制、分库分表、读写分离
java·运维·数据库·windows·学习·mysql