python通过ssh连接mysql数据库的注意事项

在通过ssh 方法连接数据库时需要注意两层连接问题.
ssh 连接通道连接服务器
mysql 连接会话连接数据库
在python 中关闭服务器连接前,需要关闭数据库连接.否则出现线程锁死(不能关闭服务器连接)
以下为代码实例.

from sshtunnel import SSHTunnelForwarder
from sqlalchemy import create_engine
import pymysql
import pandas as pd
from sqlalchemy.pool import NullPool  

server = SSHTunnelForwarder(
    ('******', 22),
    ssh_username="***",
    ssh_pkey='***',
    remote_bind_address=('127.0.0.1', 3306))

server.start()

engine = create_engine(
    'mysql+pymysql://user:password*@127.0.0.1:%s/db?charset=utf8' % server.local_bind_port,poolclass=NullPool)
pd_dataFrame = pd.read_sql('target_feature', engine)
print(pd_dataFrame)
# 以下注释部分为pymysql方式连接
# myConfig = pymysql.connect(
#             user="****",
#             passwd="****",
#             host="127.0.0.1",  # 此处必须是 127.0.0.1
#             db='***',
#             port=server.local_bind_port)
# cursor = myConfig.cursor()
# cursor.execute('SELECT * FROM target_feature;')
# print(cursor.fetchall())
# myConfig.close()

server.stop()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值