内容转载自:我自己的博客地址

这是花费了一个月的时间摸索整理出来的一份总结。分享出来一方面是给新人一个借鉴,另一方面对自己也算是个备份。


整个Django项目:

├── examples.desktop
├── microblog
│ ├── blog
│ │ ├── admin.py
│ │ ├── __init__.py
│ │ ├── migrations
│ │ │ └── __init__.py
│ │ ├── models.py
│ │ ├── __pycache__
│ │ │ ├── __init__.cpython-35.pyc
│ │ │ └── views.cpython-35.pyc
│ │ ├── static
│ │ │ └── zfbcdn.js
│ │ ├── templates
│ │ │ └── index.html
│ │ ├── tests.py
│ │ └── views.py
│ ├── db.sqlite3
│ ├── manage.py
│ └── microblog
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-35.pyc
│ │ ├── settings.cpython-35.pyc
│ │ ├── urls.cpython-35.pyc
│ │ └── wsgi.cpython-35.pyc
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── PycharmProjects
│ ├── 1A
│ │ ├── setup.py
│ │ └── testA.py

1. Django项目如何创建呢?

1.1 首先需要在ubuntu上面安装python-pip

    sudo apt-get install python3-pip

1.2 升级pip

    sudo pip3 install –upgrade pip

1.3 安装django

    sudo pip3 install Django==1.8.0

1.4 创建工程项目microblog

    django-admin.py startproject microblog

此时的情况:

	│── microblog
│ ├── db.sqlite3
│ ├── manage.py
│ └── microblog
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-35.pyc
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py

1.5 创建app项目blog(此命令在manage.py同级的目录处执行)

   python3 manage.py startapp blog

1.6 首先在settings.py中添加自己的app名称:

	INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles', 'blog',
)

新建的 app 如果不加到 INSTALL_APPS 中的话, Django 就不能自动找到app中的模板文件(app-name/templates/下的文件)和静态文件(app-name/static/中的文件)

1.7 在views.py中定义视图函数:

# coding:utf-8
# !usr/bin/env python3 from django.http import HttpResponse
from django.shortcuts import render
from django.views.decorators.csrf import csrf_exempt # Create your views here. # 定义了一个index()函数,第一个参数必须是 request,与网页发来的请求有关,request 变量里面包含get或post的内容,用户浏览器,系统等信息在里面
# HttpResponse,它是用来向网页返回内容的,就像Python中的 print 一样,只不过 HttpResponse 是把内容显示到网页上 def index(request):
return render(request, 'index.html', {'title': '我是自由修改的标题'})
# return HttpResponse(u'欢应') # 由于使用POST要CSTF,因此要加上这个
@csrf_exempt
def user(request):
if request.method=='POST':
m_user = request.POST.get('user', 'default')
m_pwd = request.POST.get('pwd', '111111')
m_option = request.POST.get('love', 'default')
return HttpResponse(m_user + m_pwd + m_option)
else:
return HttpResponse("这是get请求")

1.8 在urls.py中定义视图函数相关的url:

# coding:utf-8
# !usr/bin/env python3 from django.conf.urls import include, url
from django.contrib import admin # 自己导入
from blog import views as blog urlpatterns = [
# Examples:
# url(r'^$', 'microblog.views.home', name='home'),
# url(r'^blog/', include('blog.urls')), url(r'^$', blog.index, name='default'),
url(r'^admin/', include(admin.site.urls)),
url(r'^index', blog.index, name='index'),
url(r'^user', blog.user, name='user')
]

(注意需要在settings.py添加模板的路径,顺便添加静态文件位置,以及ALLOWED_HOSTS

# 需要在DIRS中添加模板文件路径
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': ['blog/templates'],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
# 此处填写Ip(比如23.12.34.56)和对应的域名(www.baidu.com)
ALLOWED_HOSTS = ['XX.XXX.XX.X','XXX'] STATIC_URL = '/static/' # python manage.py collectstatic
# 就会自动把所有STATICFILES_DIRS静态文件全部复制到STATIC_ROOT中
# STATIC_ROOT = os.path.join(BASE_DIR, '/home/') # 用来存放单个App的静态文件
STATICFILES_DIRS = (
'blog/static',
)

1.9 更改一下models.py文件并:

python3 manage.py makemigrations

python3 manage.py migrate

1.10 此时运行:

python3 manage.py runserver 8000

(默认在8000端口运行)


2. 把本地项目部署在服务器

2.1 安装pip3:

sudo apt install python3-pip

2.2 在服务器上下载uwsgi:

sudo python3 -m pip install uwsgi

2.3 安装nginx:

sudo apt-get install nginx

2.4 在工程目录下建立myweb_uwsgi.ini文件:

|-- blog
| |-- __init__.py
| |-- __pycache__
| | |-- __init__.cpython-35.pyc
| | |-- views.cpython-35.pyc
| |-- admin.py
| |-- migrations
| | |-- __init__.py
| |-- models.py
| |-- static
| | |-- zfbcdn.js
| |-- templates
| | |-- index.html
| |-- tests.py
| |-- views.py
|-- db.sqlite3
|-- manage.py
|-- microblog
| |-- __init__.py
| |-- __pycache__
| | |-- __init__.cpython-35.pyc
| | |-- settings.cpython-35.pyc
| | |-- urls.cpython-35.pyc
| | |-- wsgi.cpython-35.pyc
| |-- settings.py
| |-- urls.py
| |-- wsgi.py
|-- myweb_uwsgi.ini

文件内容如下:

# myweb_uwsgi.ini file
[uwsgi]
# django-related settings
# django project socket port
socket = :8000
# set running directory before loading
chdir = /home/microblog
# python project's wsgi file location
module = microblog.wsgi
# enable master process
master = true
# processes that were opened
processes = 4
# file permission
chomd-socket = 664
# autoclean environments when server exits
vacuum = true
# let process run in daemonize
daemonize = /home/log/blogserver.log
# split log file by size(KB)
log-maxsize = 1000000

2.5 然后进入/etc/nginx目录下:

mylinux@VM-11-11-mylinux:/home/microblog$ cd /etc/nginx
mylinux@VM-11-11-mylinux:/etc/nginx$ ls
conf.d koi-utf nginx.conf sites-available uwsgi_params
fastcgi.conf koi-win proxy_params sites-enabled win-utf
fastcgi_params mime.types scgi_params snippets
mylinux@VM-11-11-mylinux:/etc/nginx$

然后sudo vi nginx.conf后不更该其他内容,只在http{}内增加以下代码:

server {
listen 80 ;
server_name XX ; # 此处填写域名或者ip,比如www.baidu.com
charset UTF-8 ;
access_log /home/log/myweb_access.log ;
error_log /home/log/myweb_error.log ;
client_max_body_size 75M ;
location / {
include uwsgi_params ;
uwsgi_pass 127.0.0.1:8000 ;
uwsgi_read_timeout 2 ;
}
location /static {
expires 30d ;
autoindex on ;
add_header Cache-Control private ;
alias /home/microblog/blog/static/ ;
}
}

2.6 运行Django项目:

uwsgi –ini /home/microblog/myweb_uwsgi.ini

2.7 然后运行或重启nginx:

service nginx restart

附录:各文件内容


manage.py

# manage.py
#!/usr/bin/env python
# manage.py
import os
import sys if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "microblog.settings") from django.core.management import execute_from_command_line execute_from_command_line(sys.argv)

settings.py

# coding:utf-8
# !usr/bin/env python3
# settings.py
"""
Django settings for microblog project. Generated by 'django-admin startproject' using Django 1.8. For more information on this file, see
https://docs.djangoproject.com/en/1.8/topics/settings/ For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.8/ref/settings/
""" # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
import os BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.8/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'v%-j08&2k4!$&jlr7ld(v+e*1#-x3j7xl)6$x-1@xokqena5rt' # SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True ALLOWED_HOSTS = [] # Application definition # following lists were added by myself
"""
新建的 app 如果不加到 INSTALL_APPS 中的话, django 就不能自动找到app中的模板文件(app-name/templates/下的文件)和静态文件(app-name/static/中的文件)
"""
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles', 'microblog',
) MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.security.SecurityMiddleware',
) ROOT_URLCONF = 'microblog.urls' # 需要在DIRS中添加模板文件路径
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': ['blog/templates'],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
] WSGI_APPLICATION = 'microblog.wsgi.application' # Database
# https://docs.djangoproject.com/en/1.8/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
} # Internationalization
# https://docs.djangoproject.com/en/1.8/topics/i18n/ LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True # Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/ STATIC_URL = '/static/' # python manage.py collectstatic
# 就会自动把所有STATICFILES_DIRS静态文件全部复制到STATIC_ROOT中
# STATIC_ROOT = os.path.join(BASE_DIR, '/home/') # 用来存放单个App的静态文件
STATICFILES_DIRS = (
'blog/static',
) '''
STATIC_URL = '/static/'
# 当运行 python manage.py collectstatic 的时候
# STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用apache等部署的时候更方便
STATIC_ROOT = os.path.join(BASE_DIR, 'collected_static') # 其它 存放静态文件的文件夹,可以用来存放项目中公用的静态文件,里面不能包含 STATIC_ROOT
# 如果不想用 STATICFILES_DIRS 可以不用,都放在 app 里的 static 中也可以
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "common_static"),
'/path/to/others/static/', # 用不到的时候可以不写这一行
) # 这个是默认设置,Django 默认会在 STATICFILES_DIRS中的文件夹 和 各app下的static文件夹中找文件
# 注意有先后顺序,找到了就不再继续找了
STATICFILES_FINDERS = (
"django.contrib.staticfiles.finders.FileSystemFinder",
"django.contrib.staticfiles.finders.AppDirectoriesFinder"
)
'''

urls.py

# coding:utf-8
# !usr/bin/env python3
# urls.py from django.conf.urls import include, url
from django.contrib import admin # 自己导入
from blog import views as blog urlpatterns = [
# Examples:
# url(r'^$', 'microblog.views.home', name='home'),
# url(r'^blog/', include('blog.urls')), url(r'^$', blog.index, name='default'),
url(r'^admin/', include(admin.site.urls)),
url(r'^index', blog.index, name='index'),
url(r'^user', blog.user, name='user')
]

wsgi.py

# wsgi.py
"""
WSGI config for microblog project. It exposes the WSGI callable as a module-level variable named ``application``. For more information on this file, see
https://docs.djangoproject.com/en/1.8/howto/deployment/wsgi/
""" import os from django.core.wsgi import get_wsgi_application os.environ.setdefault("DJANGO_SETTINGS_MODULE", "microblog.settings") application = get_wsgi_application()

admin.py

# coding:utf-8
# !usr/bin/env python3
# admin.py # Register your models here.
from django.contrib import admin
from .models import Article, Person class ArticleAdmin(admin.ModelAdmin):
list_display = ('title', 'pub_date', 'update_time',)

views.py

# coding:utf-8
# !usr/bin/env python3
# views.py from django.http import HttpResponse
from django.shortcuts import render
from django.views.decorators.csrf import csrf_exempt # Create your views here. # 定义了一个index()函数,第一个参数必须是 request,与网页发来的请求有关,request 变量里面包含get或post的内容,用户浏览器,系统等信息在里面
# HttpResponse,它是用来向网页返回内容的,就像Python中的 print 一样,只不过 HttpResponse 是把内容显示到网页上 def index(request):
return render(request, 'index.html', {'title': '我是自由修改的标题'})
# return HttpResponse(u'欢应') # 由于使用POST要CSTF,因此要加上这个
@csrf_exempt
def user(request):
if request.method=='POST':
m_user = request.POST.get('user', 'default')
m_pwd = request.POST.get('pwd', '111111')
m_option = request.POST.get('love', 'default')
return HttpResponse(m_user + m_pwd + m_option)
else:
return HttpResponse("这是get请求") class PersonAdmin(admin.ModelAdmin):
list_display = ('full_name',) admin.site.register(Article, ArticleAdmin)
admin.site.register(Person, PersonAdmin)

models.py

# coding:utf-8
# !usr/bin/env python3
# models.py # Create your models here.
from __future__ import unicode_literals from django.db import models
from django.utils.encoding import python_2_unicode_compatible # python_2_unicode_compatible 会自动做一些处理去适应python不同的版本,
# 本例中的 unicode_literals 可以让python2.x 也像 python3 那个处理 unicode 字符 @python_2_unicode_compatible
class Article(models.Model):
title = models.CharField(u'标题', max_length=256)
content = models.TextField(u'内容') pub_date = models.DateTimeField(u'发表时间', auto_now_add=True, editable=True)
update_time = models.DateTimeField(u'更新时间', auto_now=True, null=True) def __str__(self):
return self.title class Person(models.Model):
first_name = models.CharField(max_length=50)
last_name = models.CharField(max_length=50) def my_property(self):
return self.first_name + ' ' + self.last_name my_property.short_description = "Full name of the person" full_name = property(my_property)

tests.py

# tests.py
from django.test import TestCase # Create your tests here.

结束

编写Django项目并使用uwsgi和nginx部署在Linux平台的更多相关文章

  1. django,uwsgi, nginx部署项目

    在liunx中环境中 对于nginx来说: 1.先安装nginx sudo apt-get install nginx 2.启动nginx服务 sudo /etc/init.d/nginx resta ...

  2. Django 1.6 最佳实践: 如何设置django项目的设置(settings.py)和部署文件(requirements.txt)

    Django 1.6 最佳实践: 如何设置django项目的设置(settings.py)和部署文件(requirements.txt) 作者: Desmond Chen,发布日期: 2014-05- ...

  3. 使用Nginx+uwsgi在亚马逊云服务器上部署python+django项目完整版(二)——部署配置及相关知识

    ---恢复内容开始--- 一.前提: 1.django项目文件已放置在云服务器上,配置好运行环境,可正常运行 2.云服务器可正常连接 二.相关知识 1.python manage.py runserv ...

  4. uwsgi+anaconda+nginx部署django项目(ubuntu下)

    conda 环境不必多说: conda(或source)  activate  test 进入test虚拟环境 接下来安装uwsgi: pip install uwsgi 在conda环境下大概率安装 ...

  5. uwsgi加nginx部署django restframework前后端分离项目

    一.uwsgi和nginx简介 1.uwsgi(摘抄于百度百科): uWSGI是一个Web服务器,它实现了WSGI协议.uwsgi.http等协议.Nginx中HttpUwsgiModule的作用是与 ...

  6. 白手起家Django项目发布上篇_linux centos 环境部署

    在项目发布之前,首先准备好我们编写好的Django项目,这个我们在之后博客有写,大家可以去看, 首先,先开始安装linux服务器,作为Django项目的发布服务器.以Vmware虚拟机为例子,大家也可 ...

  7. django -- uwsgi+nginx部署

    一. 安装nginx How To Install Nginx on CentOS 7 添加epel扩展仓 sudo yum install epel-release 安装Nginx yum inst ...

  8. [原创]Flask+uwsgi+virtualenv+nginx部署配置

    1.创建工程python2.7版本虚目录: #virtualenv -p /usr/bin/python2.7 CDN_resource #cd CDN_resource #source ./bin/ ...

  9. Spring Boot 项目本地运行无异常,部署到 Linux 服务器运行报错:java.lang.ClassNotFoundException

    一 背景 最近在用 Springboot 开发项目 A,引了小伙伴开发的模块 B,本地起服务,运行的好好的,等部署到服务器上,一运行就报错:Caused by: java.lang.ClassNotF ...

随机推荐

  1. Spring中如何获取request的方法汇总及其线程安全性分析

    前言 本文将介绍在Spring MVC开发的web系统中,获取request对象的几种方法,并讨论其线程安全性.下面话不多说了,来一起看看详细的介绍吧. 概述 在使用Spring MVC开发Web系统 ...

  2. 从 docker 到 runC

    笔者在前文<RunC 简介>和<Containerd 简介>中分别介绍了 runC 和 containerd.本文我们将结合 docker 中的其它组件探索 docker 是如 ...

  3. 【搜索引擎】Solr Suggester 实现全文检索功能-分词和和自动提示

    功能需求 全文检索搜索引擎都会有这样一个功能:输入一个字符便自动提示出可选的短语: 要实现这种功能,可以利用solr的SuggestComponent,SuggestComponent这种方法利用Lu ...

  4. Spring Boot之Actuator的端点

    Spring Boot Actuator的关键特性是在应用程序里提供众多Web端点,通过它们了解应用程序 运行时的内部状况.有了Actuator,你可以知道Bean在Spring应用程序上下文里是如何 ...

  5. never下ioc

    生命周期 当前分单例,作用域(范围),短暂.单例是整个服务中只有一个实例,短暂则是每一次得到的都是新的实例,作用域就是在该一套行动中内得到的是同一个实例,该行动中指的是什么?我们看看demo下的sta ...

  6. 《深入理解ES6》读书笔记

    文章目录 第一章 块级绑定 1. var 声明与变量提升 2. let 与 var 的区别 第二章 字符串与正则表达式 1.字符串扩展 1.1 includes().startsWith() .end ...

  7. 第二章: Identifiers, Keywords and Types

    一:方法的定义和方法的调用 方法的定义:修饰符 方法的返回值 方法名(参数列表){ 方法体 } 如果没有方法的返回值就写成:void 参数列表:参数类型 参数名 方法的调用:方法名(参数值) 第二天: ...

  8. 洛谷 题解 UVA658 【这不是bug,而是特性 It's not a Bug, it's a Feature!】

    [题意] 补丁在修正\(BUG\)时,有时也会引入新的\(BUG\),假定有\(n(n<=20)\)个潜在\(BUG\),和\(m(m<=100)\)个补丁,每个补丁用两个长度为\(n\) ...

  9. 汇编入门二 一些概念与PC组件

    1.内存:想让CPU工作,必须提供指令与数据,而指令和数据存在于内存中. 2.指令和数据:有点抽象,上书(汇编语言 第二版): 3.存储单元:存储器(内存)被划分为多个存储单元,内个存储单元从0开始顺 ...

  10. 2019.ccpc女生赛-wfinal总结

    2019ccpc女生赛离它结束有四天了,在这个期间我想了很多,想了想还是决定写这个总结.作为这个队伍唯一的一名大一队员,我很庆幸,能跟着两个学姐一起打比赛,计爱玲师姐,即将工作,张莹俐学姐.这估计都是 ...