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

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',
        }
    }
}

以上就是Django运行migrate报错“django.db.utils.OperationalError”:如何解决SSL连接错误?的详细内容,更多请关注其它相关文章!