Django运行migrate报错“django.db.utils.OperationalError”:如何解决SSL连接错误?
“纵有疾风来,人生不言弃”,这句话送给正在学习的朋友们,也希望在阅读本文后,能够真的帮助到大家。我也会在后续的文章中,陆续更新相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!
django运行migrate报错“django.db.utils.operationalerror”的解决方法
在使用django项目的过程中,有时候在命令行中运行“python manage.py migrate”命令时会遇到“django.db.utils.operationalerror”的错误。本文将针对该问题提供详细的解决方法。
问题情况
- python版本:3.7.4
- django版本:3.2.19
- mysqlclient版本:1.4.6
问题的具体表现是:
- 运行“python manage.py makemigrations”命令正常
- 运行“python manage.py migrate”命令报错“mysqldb._exceptions.operationalerror: (2026, ‘ssl connection error: unknown error number’)”
解决方法
该报错的原因是客户端和服务器的ssl设置不匹配导致的。客户端没有启用ssl,而服务器启用了ssl。针对此问题,可以采用以下解决方法:
- 在mysql服务器的配置文件(通常是/etc/my.cnf)中找到[mysqld]部分,添加“skip_ssl”配置项。
- 检查mysqlclient是否支持安全连接。如果支持,可以在django的settings.py文件中添加以下配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': 'localhost', 'PORT': '3306', 'NAME': 'my_database', 'USER': 'my_user', 'PASSWORD': 'my_password', 'OPTIONS': { 'sslmode': 'disable', } } }
今天关于《Django运行migrate报错“django.db.utils.OperationalError”:如何解决SSL连接错误?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在主机宝贝公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!