sqlalchemyerror 9002,SSL connection is required. Please specify SSL options and retry

最近在把项目部署到服务器时,出现了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)

也可以参考其他情况

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值