在SAE上部署Python的Django框架的一些问题汇总

作者:goldensun 时间:2023-12-17 19:08:25 

花了些工夫将碎片网部署到了SAE,中途遇到各类问题。感觉SAE看上去很美,实际上却并不是太成熟(至少python版如此)。
下面记录下我遇到的一些主要问题以及解决方法。
django版本问题

Django1.4都即将发布了,SAE平台自带的SAE版本依旧为1.2x。为使用django1.3版本,你需上传自己的django。具体做法可参考SAE手册中的runtime.html#virtualenv
日志模块出错

最先遇到的是日至模块的问题。错误显示AdminEmailHandler中构造某个类时带了is_mail这个参数,但目标类的构造函数根本就不支持。好在日至模块不是必须。将日至处理模块换成django.utils.log.NullHandler解决问题。


'null': { 'level':'DEBUG', 'class':'django.utils.log.NullHandler', },

local_thread问题

在index.wsgi中加入


import threading
from django.utils import _threading_local
threading.local = _threading_local.local

settings文件

SAE默认安装了不少python包,其中包括django-userena。糟糕的是SAE将django-userena的demo项目也加到了python路径,而且加载的优先级比项目代码还高。直接导致os.environ[‘DJANGO_SETTINGS_MODULE'] = ‘settings'找到的是userena的settings文件。最终将settings文件改名为qnotes_settings.py解决该问题。
其他问题

    昨天部署上线后经常出现数据库错误,错误提示为Caught OperationalError while rendering: (1045, ‘access deny')  。SAE数据库不支持长连接,30s后主动超时。但django本就会在每次请求后自动关闭数据库连接,理论上不应当出现类似问题。该问题今天莫名其妙的自己好了。
    服务器非常不稳定,经常长时间的无法访问,不定期的可以正常访问。
    SAE可能hack了python的包加载机制的原因,SAE的python包的加载行为有些奇怪。本应当最先加载当前目录下的包,实际上却不一定。

标签:SAE,Python
0
投稿

猜你喜欢

  • js实现圆形菜单选择器

    2023-09-23 19:50:54
  • 浅谈Python flask框架

    2021-04-07 00:45:43
  • 深入string理解Golang是怎样实现的

    2024-02-07 06:45:24
  • 讲解SQL Server危险扩展存储删除和恢复

    2008-12-09 14:30:00
  • Django框架首页和登录页分离操作示例

    2022-10-06 02:16:42
  • 字符集和字符编码(Charset & Encoding)

    2023-08-24 16:37:44
  • python实现简单学生信息管理系统

    2022-01-28 12:40:00
  • python中使用pyhook实现键盘监控的例子

    2023-08-17 10:21:52
  • Mysql数据库group by原理详解

    2024-01-19 20:20:44
  • MySQL数据库21条最佳性能优化经验

    2024-01-14 13:17:11
  • JS点击图片弹出文件选择框并覆盖原图功能的实现代码

    2024-02-26 07:17:33
  • 解决layer弹出层msg的文字不显示的问题

    2024-04-23 09:07:51
  • spring boot 不连接数据库启动的解决

    2024-01-18 06:38:54
  • Django实现CAS+OAuth2的方法示例

    2023-01-26 17:32:46
  • 用Python的Django框架来制作一个RSS阅读器

    2023-01-31 19:17:33
  • 浅谈Selenium+Webdriver 常用的元素定位方式

    2022-04-17 23:14:43
  • PHP基础用法讲解及phpinfo();演示

    2023-05-29 08:34:29
  • Tensorflow之MNIST CNN实现并保存、加载模型

    2023-10-16 06:21:33
  • Python matplotlib通过plt.scatter画空心圆标记出特定的点方法

    2023-06-26 14:19:03
  • Python实现AI自动抠图实例解析

    2021-12-25 11:04:22
  • asp之家 网络编程 m.aspxhome.com