Python 为Django应用程序配置GAE
有人能帮我把django应用程序转换成Google应用程序引擎(GAE)吗?我想成为abel,将django应用程序中的所有文件复制到GAE应用程序中。但是,我不确定GAE的默认文件应该如何配置。main.py文件的外观应如何才能像设计的那样运行django应用程序: main.pyPython 为Django应用程序配置GAE,python,django,google-app-engine,Python,Django,Google App Engine,有人能帮我把django应用程序转换成Google应用程序引擎(GAE)吗?我想成为abel,将django应用程序中的所有文件复制到GAE应用程序中。但是,我不确定GAE的默认文件应该如何配置。main.py文件的外观应如何才能像设计的那样运行django应用程序: main.py import webapp2 class MainHandler(webapp2.RequestHandler): def get(self): self.response.write('
import webapp2
class MainHandler(webapp2.RequestHandler):
def get(self):
self.response.write('Hello world!')
app = webapp2.WSGIApplication([
('/', MainHandler)
], debug=True)
app.yaml
application: appname
version: 1
runtime: python27
api_version: 1
threadsafe: true
libraries:
- name: django
version: "1.3"
builtins:
- django_wsgi: on
我有一个django应用程序在应用程序引擎上运行。我按照此链接启动并运行它。与常规django相比,所有配置文件中都有很多小的变化。我现在不使用django,因为我喜欢应用程序引擎,讨厌django。下面是我的一些文件示例。请注意,在您的问题中,您有一个webapp2请求处理程序,您不会在django中使用类似的东西。它将是所有作为函数的普通视图定义,而不是像appengine这样的类。如果你决定尝试这种方法,让我知道它是如何进行的 这是我的app.yaml在我点击上面的链接后所做的
application: app
version: production
runtime: python27
api_version: 1
threadsafe: yes
libraries:
- name: django
version: latest
handlers:
- url: /_ah/queue/deferred
script: djangoappengine.deferred.handler.application
login: admin
- url: /_ah/stats/.*
script: djangoappengine.appstats.application
- url: /.*
script: djangoappengine.main.application
我的设置.py
# Initialize App Engine and import the default settings (DB backend, etc.).
# If you want to use a different backend you have to remove all occurences
# of "djangoappengine" from this file.
from djangoappengine.settings_base import *
import os
DEBUG = False
TEMPLATE_DEBUG = DEBUG
# Activate django-dbindexer for the default database
DATABASES['native'] = DATABASES['default']
DATABASES['default'] = {'ENGINE': 'dbindexer', 'TARGET': 'native'}
AUTOLOAD_SITECONF = 'indexes'
INSTALLED_APPS = (
'django.contrib.contenttypes',
'django.contrib.auth',
'django.contrib.sessions',
'djangotoolbox',
'autoload',
'dbindexer',
# djangoappengine should come last, so it can override a few manage.py commands
'djangoappengine',
)
MIDDLEWARE_CLASSES = (
# This loads the index definitions, so it has to come first
'autoload.middleware.AutoloadMiddleware',
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
)
TEMPLATE_CONTEXT_PROCESSORS = (
'django.contrib.auth.context_processors.auth',
'django.core.context_processors.request',
'django.core.context_processors.media',
'context_processors.general'
)
ADMIN_MEDIA_PREFIX = '/media/'
TEMPLATE_DIRS = (
os.path.join(os.path.dirname(__file__), 'templates'),
os.path.join(os.path.dirname(__file__), 'media'),
)
main.py
import os,sys
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'
from google.appengine.dist import use_library
use_library('django', '1.2')
# Google App Engine imports.
from google.appengine.ext.webapp import util
# Force Django to reload its settings.
from django.conf import settings
settings._target = None
import django.core.handlers.wsgi
import django.core.signals
import django.db
import django.dispatch
# Log errors.
#import logging
#def log_exception(*args, **kwds):
# logging.exception('Exception in request:')
#
#django.dispatch.Signal.connect(
# django.core.signals.got_request_exception, log_exception)
# Unregister the rollback event handler.
django.dispatch.Signal.disconnect(
django.core.signals.got_request_exception,
django.db._rollback_on_exception)
def main():
# Create a Django application for WSGI.
application = django.core.handlers.wsgi.WSGIHandler()
# Run the WSGI CGI handler with that application.
util.run_wsgi_app(application)
if __name__ == '__main__':
main()