1-1 主要内容
Django项目部署
uwsgi部署
uwsgi+nginx部署
uwsgi + nginx 分布式项目部署
tornado快速入门
1-2 课程内容
- Django项目部署-uwsgi
a. 确定远程主机IP地址,登录账号,登录密码
FTP登录账号+密码
SSH远程终端登录账号+密码
工作环境:申请 [邮件申请-> 上级-> 审批回复邮件(账号密码-使用时限)]
b. 确定远程主机软件环境(项目环境)
python 是否安装配置完成
django模块是否安装配置完成
mysql数据库是否安装配置完成
确定项目中使用的第三方模块是否安装配置完成
(一般情况下,远程主机中,创建一个给予系统的虚拟环境,虚拟环境中运行项目)
新项目部署:以上环境中的软件和模块的版本号,要和开发环境一致!
遗留项目更新:一定要确保开发环境使用的软件版本和生产环境一致!
c. uwsgi项目部署
确认uwsgi是否安装成功[uwsgi是python的一个模块]
如果没有安装-> pip3 install uwsgi
d. 上传项目,部署web app
FTP上传已经打包压缩好的web项目
在服务器上解压缩,检查项目的完整性
e. 创建对应的数据库,同步数据模型对应的数据表
初始化导入需要的数据
f. 命令行运行django项目
收集Django项目静态文件
uwsgi --http=ip:port --file=wsgi_path --static-map=/static=..
问题:命令行尽管方便,但是每次项目启动操作都比较繁琐,同时启动的这个窗口不能关闭,尽管可以使用[命令 &]后台执行命令
g. 配置所有需要的选项,通过配置文件启动uwsgi服务器[推荐使用]
uwsgi官方网站
- uwsgi+nginx项目部署【推荐】
uwsgi:部署web app
nginx:反向代理、静态文件服务器
修改uwsgi配置文件-> nginx反向代理 [nginx接受请求-> 传递-> uwsgi]
http=..--> socket=..
为了保证项目的访问安全性,IP地址-> 本机地址
[uwsgi]
socket=127.0.0.1:800
chdir=..
wsgi-file=..
master=..
proceses=..
static-map=.. 注释掉静态文件映射-> 静态文件的操作交由nginx进行处理
确认服务器是否安装了 nginx-> apt-get install nginx
下载nginx源代码(nginx.tar.gz)->解压->make & make install
修改nginx配置文件:/etc/nginx/nginx.conf
添加虚拟服务器配置[server]
添加反向代理路由配置[location – uwsgi_pass ]
添加静态文件服务路由配置[location – alias ]
重启nginx
备注:nginx对于静态文件的处理优于uwsgi
uwsgi对于动态请求的操作非常优秀[nginx反向代理让uwsgi处理动态请求]
- uwsgi+nginx分布式部署
并发请求数据特别巨大情况下,第二种部署方式就不一定满足!
此时就需要分布式项目部署操作
单服务器模式[伪分布式]
uwsgi改造
将uwsgi的接受请求的方式,修改为http方式[nginx反向代理->请求分发]
[uwsgi]
http=127.0.0.1:8000
..
nginx配置配置静态文件服务器
location /static {
alias /home/damu/work/shopping/static_file;
}
负载均衡
upstream myweb {
server ip:port;
server ip:port;
..
}
location / {
proxy_pass http://myweb;
}
备注:默认情况下,nginx的负载均衡,请求轮询分发给所有后端服务器
多服务器模式[分布式集群]
tornado web framework
项目场景:Django程序员
项目:tornado 开发[小白]-mysql->web
项目经理:一周[熟悉技术 + 需求分析]
目标:tornado开发 web项目
web项目的要求:
成型的MVC模式——hello world!
路由怎么定义?
视图请求怎么处理?
数据模型怎么定义?
网页模板怎么操作?
静态文件怎么操作?
网页参数->传递->视图处理函数/类?
视图处理函数/类-> 数据-> 网页 展示?
会话跟踪/状态保持:session/cookie怎么操作?
表单操作?
缓存操作?
数据库怎么支持?
学习计划:
tornado是个什么东西?有什么优势?[简单了解]
程序结构,入门程序开发[hello world]?
网页-路由-视图处理
多个路由配置
视图处理
网页、静态文件放置
参数传递,渲染
表单操作
数据模型定义
数据库操作
缓存支持
more..
重要:怎么开始[对比熟悉的技术Django]
首先了解官方文档、社区重要资料
中文文档——[深入浅出\快速入门\从入门到精通..]
其次:开发一个入门程序
了解整个框架开发web app整体结构
第三:开始了解每个步骤的细节操作
第四:开发简单案例项目——摄影、博客
第一步:了解官方文档和中文文档
tornado是一个web框架:封装了web开发的基本流程处理
tornado是一个非阻塞式的异步IO高性能服务器,可以部署web项目
tornado开发的web项目,就可以直接部署到tornado服务器中。
import tornado.web
import tornado.ioloop
class IndexHandler(tornado.web.RequestHandler):
def get(self):
self.write('<h1>hello tornado!</h1>')
def main():
app = tornado.web.Application([
(r'/', IndexHandler)
])
return app
if name == "main":
app = main()
app.listen(8000)
tornado.ioloop.IOLoop.current().start()
- tornado核心处理模块
tornado.web
tornado.ioloop - 视图处理:类型
自定义视图处理类:继承tornado.web.RequestHandler - 请求处理:视图处理类中的函数:重写父类RequestHandler中的函数:具备了处理请求的功能
def get(self): .. 处理get请求
def post(self): .. 处理post请求 - web应用程序定义[web application]
tornado中,将开发人员自己开发的代码,封装在tornado.web.Application中创建一个web应用程序
app = tornado.web.Application() # 创建web应用程序 - 路由定义
通过创建的web应用程序,添加url地址和视图处理类之间的映射配置-> 路由
app = tornado.web.Application([
(r’/’, IndexHandler) # 定义了请求路径 / 和视图处理类 IndexHandler之间的映射
]) - 将web项目,部署到web服务器中
tornado有内置的web服务器[非阻塞式的异步IO的高性能的web服务器]
直接可以使用,推荐tornado应用程序,最好部署到tornado服务器中,体现最优雅的性能处理
app.listen(8000)-> 部署 + 监听 - 启动项目
tornado.ioloop.IOLoop.curent().start()
启动项目-> 启动IO事件轮询监听[like unix:epoll like bsd: kqueue]提升服务器处理性能
tornado vs Django
服务器性能处理:tornado >> Django
项目开发效率:Django >> tornado
业务数据处理:tornado == Django 【业务处理模式】
网络限制
项目开发:Django > tornado
开发效率[成本-利润-性能]
tornado性能 > Django
2. tornado网页模板和静态文件处理
分离架构 | 耦合架构
分离架构:前端开发[HTML/CSS/JS]和后端[Python/Java/Php/C#..]
前端和后端数据交互:Ajax 异步JSON数据交互(xml数据)
耦合架构:前端设计开发[HTML/CSS/JS/后端提供模板语言(渲染数据)]
[JAVA-jsp | Python-模板语言DTL/Jinja..]
耦合架构:前端网页展示、静态文件加载
网页模板:
在自己的项目中,创建一个任意名称的文件夹专门用于存放各种网页文件,但是项目中一般推荐使用templates/作为文件夹的名称
在Application配置中,添加一个网页文件夹的定义配置
template_path=os.path.join(os.path.dirname(file), ‘templates’),
在视图处理类的请求处理函数中,就可以通过self.render()渲染展示网页
self.render(‘index.html’) 表示从templates/文件夹中查询index.html
静态文件:
在自己项目中,创建一个任意名称的文件夹专门用于存放各种静态文件[css/images/js/fonts/..],项目中一般推荐static/作为文件夹的名称
在Application配置中,添加一个静态文件位置的定义配置
static_path=os.path.join(os.path.dirname(file), ‘static’)
在其他网页中,就可以直接通过路径进行引入
<link rel=’stylesheet’ href=’/static/css/index.css’/>
http://demo.pythoner.com/itt2zh/index.html
3.参数操作
--| 视图处理类中,处理完数据[和数据库交互完成后的数据]传递给前端网页进行展示
--| 前端网页中,通过超链接、表单、Ajax提交数据给后端程序,后端程序接受数据
(1) 后端程序中的数据,传递给前端页面
Django-> 通过字典的形式传递数据,前端网页中,通过DTL语法进行展示
Tornado-> 后端处理函数中,直接传递关键字参数,将数据添加到响应中即可
self.render(‘path’, k=v, k1=v1, k2=v2..)
前端网页中,通过jinja模板语法直接渲染[高度类似DTL模板语法]
DTL:Django template language:Django模板语法
(2) 前端数据[超链接、表单、Ajax- get/post参数]
get数据
前端网页:超链接、表单、Ajax、RESTful传递数据
post数据
前端网页:表单、Ajax
后端处理:
self.get_query_argument()获取GET方式提交的数据
self.get_body_argument()获取POST方式提交的数据
self.get_argument()获取提交的数据【在不同的请求处理中接受对应的数据】
self.get_argumnets()获取提交的多个数据【如:复选框】
4. 会话跟踪[cookie(session)]
什么是会话:浏览器和服务器之间一次完成的数据交互过程,包含多次请求和响应。
会话跟踪:在浏览器客户端访问服务器进行业务处理的的过程中,对于重要的数据进行临时存储记录,在后续客户端的操作过程中提供更加便捷的服务的过程。会话跟踪最典型的的应用如状态保持[登录状态保持,视频播放进度记录等等],主要通过存储在服务器端的session对象和存储在客户端的cookie数据完成跟踪操作。
session:主要是存储在服务器空间中,所以一般情况下不要存储大量数据[如果存储大量数据/大型对象,在高并发的情况下,很容易让服务器空间吃紧],一般存储重要的占用空间比较小的数据进行一个简单的状态记录即可
cookie:主要是存在客户端计算机中,只能存储字符串[不能包含中文],存储的大小也受到限制;一般主要是用来记录用户历史操作重要数据。
tornado中操作cookie:
self.set_cookie(name, value, expire_days)
在cookie中存放一个数据,设置过期时间[value中不能包含中文和空格]
self.get_cookie(name)
cookie中的数据:明文显示——不安全
self.set_secure_cookie(..)
self.get_secure_cookie(..)
tornado中操作session: