Hello! 欢迎来到小浪云!


Django运行migrate报错“django.db.utils.OperationalError”:如何解决SSL连接错误?


avatar
小浪云 2024-11-09 134

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。针对此问题,可以采用以下解决方法:

  1. 在mysql服务器的配置文件(通常是/etc/my.cnf)中找到[mysqld]部分,添加“skip_ssl”配置项。
  2. 检查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',         }     } }
登录后复制

相关阅读