SAE构建Django项目

来源:互联网 发布:sql 查询一天内的数据 编辑:程序博客网 时间:2024/05/16 15:29

非常简单的记录而已:


1. 创建python应用(废话),从sae的svn中checkout到本地,假设为checkout到 E:\xxx\project\1\ 

2. 在eclipse中创建django项目,前提是要装好pydev插件以及装好django框架。在新建django项目的时候,取消项目创建的默认目录,而是指定到E:\xxx\project\1\ 

3. 改写index.wsgi :sae的python项目入口是index.wsgi,我们需要修改其中的代码,把application指定为我们的django应用,代码如下:

import saefrom myproject import wsgiapplication = sae.create_wsgi_app(wsgi.application)
    wsgi在你创建的django应用中就已经有了,直接import就行

4. 直接访问sae的你的项目的网站。有可能会提示你找不到wsgi模块,那有可能是因为你没有修改config.yaml文件,将其修改成:

libraries:- name: "django"  version: "1.4"


5.数据库

为了在settings.py兼容本地和SAE上两种模式,在settings中做如下配置

from os import environonline = environ.get("APP_NAME",None)if not online:    db_name = 'dreamshare'      # 数据库名    user = 'root'    # 用户名    password = 'root'    # 密码    host = 'localhost'    # 主库域名(可读写)    port = 3306    # 端口,类型为,请根据框架要求自行转换为int    host_s = 'localhost'  # 从库域名(只读)else:
#     from sae._restful_mysql import monkey#     monkey.patch()
import sae.const db_name = sae.const.MYSQL_DB # 数据库名 user = sae.const.MYSQL_USER # 用户名 password = sae.const.MYSQL_PASS # 密码 host = sae.const.MYSQL_HOST # 主库域名(可读写) port = int(sae.const.MYSQL_PORT) # 端口,类型为,请根据框架要求自行转换为int host_s = sae.const.MYSQL_HOST_S # 从库域名(只读)DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'. 'NAME': db_name, # Or path to database file if using sqlite3. # The following settings are not used with sqlite3: 'USER': user, 'PASSWORD': password, 'HOST': host, # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP. 'PORT': port, # Set to empty string for default. }}

但是由于SAE数据库上还没有django默认创建的那些表,比如django-session,所以需要我们同步数据库或者人工导入SQL,按照官方文档,将上面代码中下面这一段:

#     from sae._restful_mysql import monkey#     monkey.patch()

去掉注释,然后在manage.py所在文件夹中在命令行敲入python manage.py syncdb,就可以同步到SAE数据库上,但是要事先安装SAE相关的模块,我没有安装,所以就不能用这种方法同步。

那怎么办呢,很简单,使用本地链接:

暂时把 

if not online
改成

if True

在本机数据库上创建一个和你的数据库名相同的数据库,然后运行python manage syncdb后,django 相关的表就会被创建在本机的数据库中了

然后我们用mysql相关的界面工具,比如我使用的是navicat for mysql,导出数据库表结构的SQL文件,回到SAE的phpmysqladmin上导入SQL文件,这样就完成创建了。

最后记得把  if True 改回来成 if not online

这样就应该可以了,其他的settings,根据文档配置就行

原创粉丝点击