sqlalchemy.exc.OperationalError: (MySQLdb._exceptions.OperationalError) (2026, 'SSL connection error: unknown error number')
时间: 2024-02-06 17:11:12 浏览: 335
这个错误提示是因为在使用 SQLAlchemy 连接 MySQL 数据库时,启用了 SSL 连接,但是连接过程中发生了未知的 SSL 错误。
要解决这个问题,可以按照以下步骤进行:
1. 确认 MySQL 数据库已经开启了 SSL 连接,可以使用以下命令进行查看:
```
SHOW VARIABLES LIKE '%ssl%';
```
如果 SSL 连接没有开启,可以使用以下命令进行开启:
```
SET GLOBAL ssl_ca='<path/to/ca.pem>';
SET GLOBAL ssl_cert='<path/to/client-cert.pem>';
SET GLOBAL ssl_key='<path/to/client-key.pem>';
```
其中,`<path/to/ca.pem>`、`<path/to/client-cert.pem>` 和 `<path/to/client-key.pem>` 分别是 CA 证书、客户端证书和客户端私钥的路径,可以根据实际情况进行替换。
2. 确认 SQLAlchemy 的连接字符串中启用了 SSL 连接,可以使用以下代码进行查看:
```
from sqlalchemy import create_engine
engine = create_engine('mysql://user:password@host/dbname?ssl_ca=<path/to/ca.pem>&ssl_cert=<path/to/client-cert.pem>&ssl_key=<path/to/client-key.pem>')
```
其中,`<path/to/ca.pem>`、`<path/to/client-cert.pem>` 和 `<path/to/client-key.pem>` 分别是 CA 证书、客户端证书和客户端私钥的路径,可以根据实际情况进行替换。
如果连接字符串中没有启用 SSL 连接,可以添加以下参数进行启用:
```
engine = create_engine('mysql://user:password@host/dbname?ssl_ca=<path/to/ca.pem>&ssl_cert=<path/to/client-cert.pem>&ssl_key=<path/to/client-key.pem>&ssl_mode=REQUIRED')
```
其中,`ssl_mode=REQUIRED` 表示必须启用 SSL 连接。
如果你已经按照以上步骤进行了操作,但还是出现了这个错误提示,可以尝试升级 MySQL 版本或者查看 MySQL 的错误日志,确认 SSL 连接过程中发生了什么未知错误。
阅读全文