SAE构建Django项目

这篇博客简单记录了如何在SAE上构建Django项目。首先从SAE SVN检出Python应用到本地,接着在Eclipse中创建并指定项目路径。然后,修改index.wsgi文件以指向Django应用,并更新config.yaml。由于数据库兼容问题,需要在settings.py中进行配置,同时在本地和SAE间切换。通过本机数据库同步和SQL文件导入,实现了数据库在SAE上的设置。最后调整online判断,完成配置。
摘要由CSDN通过智能技术生成

非常简单的记录而已:


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 sae
from myproject import wsgi
application = 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 environ
online = 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,根据文档配置就行

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值