最近在把项目部署到服务器时,出现了mysql连接的问题。网上找了一圈也没有解决掉,最后试了出来,这里记录一下,方便大家参考。
之前的测试环境是这样的
PARAM_FOR_MYSQL='mysql://v_user:v_pase@localhost:3306/test_database?charset=utf8&ssl=true'
然后create_engine是这样的
engine=create_engine(config.PARAM_FOR_MYSQL,poolclass=QueuePool,echo=False,pool_size=20,pool_timeout=30,pool_recycle=100,pool_pre_ping=True,encoding='utf-8',connect_args={'ssl:{'ca':None}})
测试环境这样是OK的,ssl链接也没有报错,然后链接mysql是这样的
mysql -u user -p pwd --ssl
一切都是OK的,然后再次如法炮制时就谜一般的不行了,当然每天就是有意外的惊喜
然后就开始各种百度谷歌,最后发现这样修改下就可以了
https://www.digicert.com/CACerts/DigiCertGlobalRootCA.crt 证书下载地址
这里看你的情况,数据库ssl链接时用的什么证书 ssl_args = { 'ssl': { 'cert': None, 'key': None, 'ca': '证书路径' } }
engine = create_engine(config.PARAM_FOR_MYSQL,poolclass=QueuePool,echo=False,pool_size=20,pool_timeout=30,pool_recycle=100,pool_pre_ping=True,encoding='utf-8',connect_args=ssl_args)
也可以参考其他情况