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,根据文档配置就行
- SAE构建Django项目
- 在sae配置django项目
- SAE下创建一个django项目
- [django]项目打包构建
- [django]项目打包构建
- Django开源项目mezzanine迁移SAE分享
- django项目部署到SAE上的个人博客
- sae django+python部署
- python django sae杂记
- SAE 环境 django 配置
- sae+git+django上传
- Django的SAE部署
- python+django+sae
- python+django+sae
- python+django+sae(3)
- python+django+sae
- python+django+sae
- python+django+sae
- 什么是MAC地址及作用管理教程——What is the MAC address and role management tutorial
- 获取系统信息SystemParametersinfo
- 56. 让不可见的更可见
- 2014找工笔试之睿初科技
- Android TCP 文件客户端与服务器DEMO
- SAE构建Django项目
- lua源码到c的简单转换
- LRESULT CALLBACK
- OpenCV读取AVI
- Android ViewPager使用详解
- win7(64)未在本地计算机上注册 Microsoft.Jet.OLEDB.4.0 提供程序
- android 中有哪几种解析xml的类?
- java 对mysql数据的增删改查
- SQL删除重复数据只保留一条