AmazingCounters.com

Ubuntu14.04 Django Mysql安装部署全过程

Ubuntu14.04 Django Mysql安装部署全过程

 

一、简要步骤。(阿里云Ubuntu14.04)

  • Python安装
  • Django
  • Mysql的安装与配置

  记录一下我的部署过程,也方便一些有需要的童鞋,大神勿喷~

 

二、Python的安装

 

由于博主使用的环境是Ubuntu14.04,所以系统自带了Python2.7.6。

我们可以使用Python –V查看自己Ubuntu中的Python版本。

 

 

三、Django

3.1

现在Django的版本已经到1.9.2了。我们可以到官网去下载,然后解压安装。

下载地址:http://www.djangoproject.com/download/

这里已经下载好了


 

3.2

解压安装

tar xzvf Django-1.9.2.tar.gz

cd Django-1.9.2/

sudo python setup.py install 

这里会提示一个报错是因为setuptools没有安装,我们再安装一个setuptools就好了。


Python2.x

wget https://bootstrap.pypa.io/ez_setup.py -O - | sudo python

Python 3.x

wget https://bootstrap.pypa.io/ez_setup.py -O - | sudo python3.4

然后再次安装Django即可成功。

sudo python setup.py install


安装成功。

3.3

搭建项目

要创建一个Django项目非常简单,使用startproject命令,输入项目名称:

django-admin.py startproject PPNotes

Django会在当前目录下面创建一个PPNotes项目。里面的文件如下所示:

root@iZ94a2sp0pwZ:/work/Django-1.9.2# tree PPNotes/

PPNotes/

├── manage.py

└── PPNotes

    ├── __init__.py

    ├── settings.py

    ├── urls.py

    └── wsgi.py

1 directory, 5 files 


  __init__.py:Python特性,可以是空文件,表明这个文件夹是一个可以导入的包。

  settings.py:配置文件,本文主要修改数据库信息、模板目录、加载模块的信息。

  url.py:URL配置文件,指定函数与URL的映射关系。

  wsgi.py:本文中不会使用,nginx/apache+wsgi在生产环境中运行Django时使用

3.4

启动Django

创建完成之后,我们可以在项目文件夹里面启动Django自带的web服务器。

python manage.py runserver 0.0.0.0:8080

这时候很明显,我们需要执行一下python manage.py migrate

话说这个到底有什么用呢,它可以让我们在修改Model后可以在不影响现有数据的前提下重建表结构。

再次python manage.py runserver 0.0.0.0:8080

root@iZ94a2sp0pwZ:/work/Django-1.9.2/PPNotes# python manage.py runserver 0.0.0.0:8080

Performing system checks...
 
System check identified no issues (0 silenced).

February 26, 2016 - 04:11:33

Django version 1.9.2, using settings 'PPNotes.settings'

Starting development server at http://0.0.0.0:8080/

Quit the server with CONTROL-C. 

表示已经成功,下面我们用浏览器打开试试

OK,Django项目搭建成功。下面的步骤就是配置Mysql数据库。

四、Mysql的安装与配置。

4.1

Django默认的数据库是sqlite,我们可以看到项目文件夹下面有个自动生成的db.sqlite3文件。而我们是需要使用Mysql的。

4.2 

要让Django支持Mysql数据库,我们需要改一下配置文件settings.py(mysite/mysite目录下面)。知道DATABASES进行如下修改即可。

DATABASES = {

    'default': {

        'ENGINE''django.db.backends.mysql',

        'NAME': 数据库名,

        'USER''用户名,

        'PASSWORD''密码',

        'HOST''127.0.0.1',

        'PORT''3306',

    }

}

4.3

安装Mysql

sudo apt-get install mysql-server mysql-client

sudo apt-get install libmysqld-dev

在这个过程他会提示你输入root的密码并确认密码。

Django(Python)操作MySQL依赖第三方包,所以要先安装MySQL for Python

sudo apt-get install python-dev

wget https://pypi.python.org/packages/source/M/MySQL-python/MySQL-python-1.2.5.zip

解压MySQL-python-1.2.5.zip

cd MySQL-python-1.2.5/

sudo python setup.py install

4.4 

配置mysql远程访问权限(用户名密码自行修改)

GRANT ALL PRIVILEGES ON *.* TO '用户名'@'%' IDENTIFIED BY '密码' WITH GRANT OPTION;

FLUSH  PRIVILEGES;(配置立即生效)

 

这个时候我们还是无法远程连接Mysql,下面还得修改/etc/mysql/my.cnf文件;

将bind-address                  = 127.0.0.1中的IP地址修改为0.0.0.0

重启mysql

service mysql restart

OK,远程连接成功。

4.5

新建数据库

新建一个数据库,名字需要续我们前面配置Django中settings.py里面的DATABASES里面的数据库名一致。

4.6

再次执行python manage.py migrate

 

当我们看到新建的数据库中增加了如上所以的表,证明Mysql已经配置成功。

创建管理员账户

python manage.py createsuperuser

python manage.py runserver 0.0.0.0:8080

 

OK,大功告成。

五、附加启动脚本。start.sh

 

#!/bin/bash

cd /work/Django-1.9/PPNotes

nohup python manage.py runserver 0.0.0.0:8000  >/dev/null 2>&1 &

while true

do

#PIDS=`ps -ef |grep 8000 |grep -v grep | awk '{print $2}'`

num=`ps -ef|grep -v grep|grep 8000|wc -l`

if [ $num -eq 0 ];then

cd /work/Django-1.9/PPNotes

nohup python manage.py runserver 0.0.0.0:8000  >/dev/null 2>&1 &

fi

sleep 10

done



本文为博主原创文章,转载请注明出处

http://www.cnblogs.com/rencm/p/5220042.html

 

 

posted @ 2016-02-26 13:41 rencm 阅读(...) 评论(...) 编辑 收藏