使用Gunicorn和Nginx部署Django时出现500个内部服务器错误 - python

我创建了一个简单的django应用程序用于用户身份验证,然后我想使用gunicorn在nginx上进行部署。我用2个字段创建我的自定义用户模型:用户名,密码。

python manange.py runserver 0.0.0.0:8000

运行良好!但是,当我尝试使用gunicorn在nginx上进行部署时,出现500个内部服务器错误。我用gunicorn测试django的命令是:

gunicorn --bind 127.0.0.1:8080 backend.wsgi:application

后端是我的startapp。这是我的nginx配置:

server {
    listen 8000;
    server_name localhost;
    location / {
        include proxy_params;
        proxy_pass http://127.0.0.1:8080;
    }
}

当我从客户端站点登录时,它将带有用户凭据的发帖请求发送到服务器。在服务器端,它成功接收到具有正确凭据的请求,但是当它尝试通过查询User表来验证用户身份时:

User.objects.get(username=username, password=password)

它得到异常:

(1054, "Unknown column 'auth_user.last_login' in 'field list'")

嗯,奇怪! last_login列来自哪里?然后,我查看日志并在运行带有gunicorn和不使用gunicorn的django应用程序时发现了一些奇怪的东西。

在没有nginx和gunicorn的情况下运行时,以下是查询User表时的日志:

2016-06-25 10:38:11,815|DEBUG|(0.001) SELECT `auth_user`.`id`, `auth_user`.`username`, `auth_user`.`password`, `auth_user`.`role` FROM `auth_user` LIMIT 21; args=()

与Nginx和Gunicorn一起运行时:

2016-06-25 10:33:57,983|DEBUG|(0.000) SELECT `auth_user`.`id`, `auth_user`.`password`, `auth_user`.`last_login`, `auth_user`.`is_superuser`, `auth_user`.`username`, `auth_user`.`first_name`, `auth_user`.`last_name`, `auth_user`.`email`, `auth_user`.`is_staff`, `auth_user`.`is_active`, `auth_user`.`date_joined` FROM `auth_user` LIMIT 21; args=()

似乎在与nginx和gunicorn一起运行时,它没有使用我的自定义模型。有人对这个问题有任何想法吗?配置nginx和gunicorn时,我是否犯了任何错误?

参考方案

经过一整天的调试后,事实证明我的身份验证应用程序的名称(即auth)与django默认身份验证冲突。不知何故,当我通过gunicorn服务我的应用程序时,它使用的是Django默认身份验证应用程序,而不是我的。如果您仔细查看日志,它将查询django的默认用户模型。

要解决此问题,我转到应用程序设置并删除django.contrib.auth.middleware! 🙂

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python uuid4,如何限制唯一字符的长度 - python

在Python中,我正在使用uuid4()方法创建唯一的字符集。但是我找不到将其限制为10或8个字符的方法。有什么办法吗?uuid4()ffc69c1b-9d87-4c19-8dac-c09ca857e3fc谢谢。 参考方案 尝试:x = uuid4() str(x)[:8] 输出:"ffc69c1b" Is there a way to…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python:ConfigParser对象,然后再阅读一次 - python

场景:我有一个配置文件,其中包含要执行的自动化测试的列表。这些测试是长期循环执行的。   配置文件的设计方式使ConfigParser可以读取它。由于有两个三个参数,因此我需要通过每个测试。现在,此配置文件由script(s1)调用,并且按照配置文件中的列表执行测试。Script(s1)第一次读取配置,并且在每次测试完成后都会执行。阅读两次的要求:由于可能会…

Python exchangelib在子文件夹中读取邮件 - python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…