登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

阿飞与安达

每天进步一点点!

 
 
 

日志

 
 

How to setup django, python environment in ubuntu(转)  

2011-03-01 11:24:20|  分类: Linux_Ubuntu |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
转自http://blog.csdn.net/stefli/archive/2010/03/13/5377302.aspx

Django开源项目网站:http://www.djangoproject.com/
Django是用python语言写的开源web开发框架(open source web framework),它鼓励快速开发,并遵循MTV设计。Django遵守BSD版权,初次发布于2005年7月, 并于2008年9月发布了第一个正式版本1.0。Django 根据比利时的爵士音乐家Django Reinhardt命名,他是一个吉普赛人,主要以演奏吉它为主,还演奏过小提琴等。

Django的主要目的是简便、快速的开发数据库驱 动的网站。它强调代码复用,多个组件可以很方便的以“插件”形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己 的工具包。这使得Django具有很强的可扩展性。它还强调快速开发和DRY(Do Not Repeat Yourself)原则。

本文将演示如何在Debian Lenny服务器中快速搭建Django环境,使用Apach2 Web服务器及其mod_python模块提供对pyhton和Django的支持。另外,本文只是提供一个Django运行平台快速搭建的参考,最多Django开发等相关内容请参考其官方文档资料。

1. 安装MySQL

Django支持的数据库管理系统非常广泛,如PostgreSQL、MySQL、SQLite等等,如果你像我一样也是使用MySQL数据库的话,使用下面这个简单的命令安装它,
  1. aptitude install mysql-server mysql-client
复制代码
安装过程中,其中一个环节是要求输入MySQL根用户root的密码:

New password for the MySQL "root" user: <-- yourrootsqlpassword
Repeat password for the MySQL "root" user: <-- yourrootsqlpassword


如果希望远程访问MySQL的话,我们要修改 /etc/mysql/my.cnf配置文件,把其中的 bind-address=127.0.0.1 一行注释掉:
  1. vi /etc/mysql/my.cnf

  2. [...]
  3. # Instead of skip-networking the default is now to listen only on
  4. # localhost which is more compatible and is not less secure.
  5. #bind-address           = 127.0.0.1
  6. [...]
复制代码
然后,重启MySQL:
  1. /etc/init.d/mysql restart
复制代码
如果要检查是否能远程访问MySQL,可以使用netstat命令,
  1. netstat -tap | grep mysql
复制代码
会得到类似于下面的输出:
  1. server1:~# netstat -tap | grep mysql
  2. tcp        0      0 *:mysql                 *:*                     LISTEN      3403/mysqld
  3. server1:~#
复制代码
2. 安装Apache及mod_python模块

如果你的系统中Apache2及mod_python没有安装的话,也不必担心,同样一条安装命令搞定:
  1. aptitude install apache2 apache2-doc apache2-mpm-prefork apache2-utils libexpat1 ssl-cert libapache2-mod-python
复制代码
怎么样,看是不是非常快捷方便?


3. 安装Django

接下来我们该安装Django了,同样,还要安装Python对MySQL的支持,这样才能使用python、Django访问MySQL数据库,安装python-django、python-mysqldb:
  1. aptitude install python-django python-mysqldb
复制代码
4. 配置Apache

Apache 安装成功后,其默认的站点根目录为 /var/www,我们这里也不防简化一下:默认的虚拟目录(/etc/apache2/sites-available/default)就直接指向默 认的站点根目录(/var/www)了。不过,实际应用中要依自己的具体情况而定。

在正式配置Apache之前,我们必须先新建一个Django项目(比如,叫mysite,具体请参考:http://www.djangoproject.com/documentation/tutorial01/)。为了安全起见,这个项目不放在/var/www目录里,暂且改放在/home/mycode里:
  1. mkdir /home/mycode
  2. cd /home/mycode
  3. /usr/share/python-support/python-django/django/bin/django-admin.py startproject mysite
复制代码
这样,django-admin.py 就自动为我们新建了一个名为mysite的项目,位于/home/mycode/mysite,可以看看,里面已经有一些python程序文件了。

现在,我们来配置Apache,打开我们的默认虚拟主机配置文件/etc/apache2/sites-available/default,在配置文件中的<VirtualHost ...>和</VirtualHost>之前加入如下配置项:
  1. vi /etc/apache2/sites-available/default

  2. [...]
  3. <Location "/mysite">
  4.     SetHandler python-program
  5.     PythonHandler django.core.handlers.modpython
  6.     SetEnv DJANGO_SETTINGS_MODULE mysite.settings
  7.     PythonDebug On
  8.     PythonPath "['/home/mycode'] + sys.path"
  9. </Location>
  10. [...]
复制代码
上面加入的配置项,第一行的路径 /mysite 是该虚拟站点的子目录,假如,当前站点的URL为 http://www.example.com/的话,那么该路径即告诉apache,我的mysite站点就在该虚拟站点根目录下的mysite目录下,可以直接使用http://www.example.com/mysite 这个地址访问。

修改完成后,重启Apache:
  1. /etc/init.d/apache2 restart
复制代码
现在,我们就可以直接在浏览器中打开 http://www.example.com/mysite 查看了。如果一切顺利的话,我们可以看到如下的界面:


这说明Django已经安装成功了,我们可以立即着手Python Web应用程序的开发了,更多Django框架下的Python Web开发资料可以参见:http://www.djangoproject.com/documentation/

5. Django项目连接MySQL数据库

多数Web应用都要用到后台数据库以存取数据,这里我们也简要地说明一下其中的过程。

首先,我们新建一个数据库mysite,并为该库新建一个管理用户mysiteadmin:
  1. mysql -u root -p

  2. CREATE DATABASE mysite;
  3. GRANT ALL ON mysite.* TO 'mysiteadmin'@'localhost' IDENTIFIED BY 'mysiteadmin_password';
  4. GRANT ALL ON mysite.* TO 'mysiteadmin'@'localhost.localdomain' IDENTIFIED BY 'mysiteadmin_password';
  5. quit;
复制代码
然后,打开项目文件夹中的settings.py python程序文件,修改其中的数据库设置项:
  1. vi /home/mycode/mysite/settings.py

  2. [...]
  3. DATABASE_ENGINE = 'mysql'           # 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
  4. DATABASE_NAME = 'mysite'             # Or path to database file if using sqlite3.
  5. DATABASE_USER = 'mysiteadmin'             # Not used with sqlite3.
  6. DATABASE_PASSWORD = 'mysiteadmin_password'         # Not used with sqlite3.
  7. DATABASE_HOST = ''             # Set to empty string for localhost. Not used with sqlite3.
  8. DATABASE_PORT = ''             # Set to empty string for default. Not used with sqlite3.
  9. [...]
复制代码
OK,这样,我们在项目中就可以访问MySQL数据库了。
  评论这张
 
阅读(668)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018