nginx+uwsgi+django
上一涨讲解了如何使用nginx+uwsgi部署wsgi application
其实django配置方式和 application都一样,因为如果我们对application进行扩展就是一个WSGI framework
我们使用
django-admin.py startproject mysite
创建一个简单的 django app命名为mysite
然后我们在mysite中创建一个 static 目录,主要用于放置mysite的静态文件。因为我们不打算让Djando管理静态文件,把管理静态文件的任务交给nginx,因为那是它的强项
我们咋 static 目录下创建一个 js 目录 和一个 time.html ,我们把 jquery.js 放到 js目录下
time.html
<html>
<head>
<title>time
</title>
<script type="text/javascript" src="js/jquery-1.7.min.js"></script>
<script type="text/javascript">
$(function () {
$(':button').click(function () {
$.ajax({
url: '/query_time',
dataType: 'text',
success: function (time) {
$('[name="time"]').val(time)
}
});
});
});
</script>
</head>
<body>
<table style="margin: 0 auto">
<tr>
<td>
<input type="text" name="time" disabled="disabled" /></td>
</tr>
<tr>
<td>
<input type="button" value="Query Time" /></td>
</tr>
</table>
</body>
</html>
主页 home.html
<html>
<head>
<title>home</title>
<style type="text/css">
div {
width: 200px;
height: 100px;
background-color: aquamarine;
font-family: 'Arial Black', Gadget, sans-serif;
margin: 0 auto;
text-align: center;
font-size: 20px;
}
</style>
</head> <body>
<div>
Home Page
</div>
</body>
</html>
我们在 mysite中的创建一个 views.py 文件:
from django.shortcuts import HttpResponse
import datetime static_path = os.path.join(os.path.dirname(sys.argv[0]).replace('\\', '/'), 'static') def home(request):
try:
home_file = open(static_path + '/home.html')
except IOError:
return Http404()
html = home_file.read()
home_file.close()
return HttpResponse(html) def query_time(request):
now = datetime.datetime.now().strftime("%Y-%m-%d %H:%M")
return HttpResponse(now)
urls.py代码:
from django.conf.urls import patterns, url
from mysite.views import home, query_time urlpatterns = patterns('',
url(r'^$', home),
url(r'^query_time/$', query_time),
)
nginx配置
location / {
#wsgi config
include uwsgi_params;
uwsgi_pass localhost:9000;
}
location ~* ^.+\.(ico|gif|jpg|jpeg|png|html|htm)$ {
root /home/artscrafts/mysite/static;
access_log off;
}
location ~* ^.+\.(css|js|txt|xml|swf|wav)$ {
root /home/artscrafts/mysite/static;
access_log off;
}
这次我们使用 uwsgi 的.ini文件启动
mysite.ini
[uwsgi]
chdir=/home/artscrafts/mysite
module=mysite.wsgi:application
env DJANGO_SETTINGS_MODULE=mysite.settings
socket=127.0.0.1:9000
processes=5
max-requests=5000
daemonize=/var/log/uwsgi/mysite.log
部署
sudo uwsgi mysite.ini
访问 localhost/time.html
nginx+uwsgi+django的更多相关文章
- 五步教你实现使用Nginx+uWSGI+Django方法部署Django程序
Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...
- Nginx+uWSGI+Django+Python+ MySQL 搭建可靠的Python Web服务器
一.安装所需工具 yum -y install gcc gcc-c++ rpm-build mysql* libtool-ltdl* libtool automake autoconf libtool ...
- 安装Nginx+uWSGI+Django环境
Ubuntu Server 12.04 安装Nginx+uWSGI+Django环境 今天要介绍的是利用APT源直接apt-get install安装配置我们所需要的环境,首先按惯例先安装MySQL和 ...
- debian完整部署 Nginx + uWSGI + Django
手工部署一个Django服务器真心不容易,需要安装很多东西.从头开始搭建服务器,主要是为了梳理一下后续开发中一般为碰到的平台部署.对后续问题的解决有一定帮助. 通常部署有2中方式: 一种是使用现成提供 ...
- Nginx+uWSGI+Django原理
Python的Web开发中,如果使用Django框架,那么较为成熟稳定的服务器架构一般是Nginx+uWSGI+Django.而为什么一定要三个结合在一起呢?直接使用Django的runserver来 ...
- Nginx+uWSGI+Django环境配置
通常项目会部署在虚拟环境,虚拟环境的使用可以参考这里,点击前往 当然你也可以直接部署,这里不多说. 一.安装uWSGI 1.通过pip安装 pip install uwsgi 这里只说明了一种安装方式 ...
- nginx+uwsgi+django 部署原理
python开发群里经常有同学问 nginx+uwsgi+django 着了教程部署,但是不知道他们之间怎么样的关系,于是我就google到了一个让我看起来很认同的图,大家看了也比较认同,于是就分享出 ...
- SLAM+语音机器人DIY系列:(八)高阶拓展——2.centos7下部署Django(nginx+uwsgi+django+python3)
0.安装步骤预览(1)系统默认自带python2.x,所以需要先安装python3.x(2)python2对应pip,python3对应pip3,用源码安装python3后pip3也自动安装了(3)用 ...
- nginx+uwsgi+django开发环境搭建
Nginx+uWSGI+Djangoi开发环境搭建 Django简介,环境搭建 uWSGI简介,安装与配置 Nginx安装与配置 Nginx+uWSGI+Django原理解析 1.django简介,环 ...
- nginx+uWSGI+django+virtualenv+supervisor发布web服务器
nginx+uWSGI+django+virtualenv+supervisor发布web服务器 导论 WSGI是Web服务器网关接口.它是一个规范,描述了Web服务器如何与Web应用程序通信,以 ...
随机推荐
- thinkphp I方法取传参
/** * 获取输入参数 支持过滤和默认值 * 使用方法: * <code> * I('id',0); 获取id参数 自动判断get或者post * I('post.name','','h ...
- 如何正确并完全安装Visual Studio 2015企业版本[转]
http://blog.csdn.net/code_godfather/article/details/47381631 [注意事项]1> 本文描述的是: Visual Studio 2015企 ...
- Sencha Touch 和 jQuery Mobile 的比较
Sencha Touch 和 jQuery Mobile 的比较 英文原文:Sencha Touch vs jQuery Mobile 标签: Sencha Touch jQuery Mobile 1 ...
- WebKit历史项管理的实现
历史项管理依据标准定义,由Page管理一个Joint Session History, 包括了各个子Frame的历史项.逻辑上相应例如以下的关系: 从上面看三个层次:Page,Frame,以及JS B ...
- Qt 学习之路:模型-视图高级技术
PathView PathView是 QtQuick 中最强大的视图,同时也是最复杂的.PathView允许创建一种更灵活的视图.在这种视图中,数据项并不是方方正正,而是可以沿着任意路径布局.沿着同一 ...
- myeclipse一些技巧
ctrl+h-----------------查找字符串 ctrl+A 全选→ctrl+shift+f 代码格式化,排版 ctrl+shift+O 自动引用
- YouTube CEO关于工作和生活平衡的完美回答
原文地址:http://www.businessinsider.com/youtubes-ceo-response-to-work-life-balance-2015-7 译文: 在2015年Aspe ...
- Junit简介和常用API
测试几个的概念 白盒测试——把测试对象看作一个打开的盒子,程序内部的逻辑结构和其他信息对测试人员是公开的. 回归测试——软件或环境的修复或更正后的“再测试”,自动测试工具对这类测试尤其有用. 单元测试 ...
- URLConnection类详解
为了防止无良网站的爬虫抓取文章,特此标识,转载请注明文章出处.LaplaceDemon/SJQ. http://www.cnblogs.com/shijiaqi1066/p/3753224.html ...
- 学习微信小程序之css15解决父盒子高度塌陷
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...