Django 开发者都应该清楚的 十 个点

  1. 使用 Celery 进行异步任务和 cron 作业(不需要使用 UNIX cron) 开发的前两个星期,你可能不需要将任务放到异步进程中执行,但是当你的非技术联合创始人开始问为什么这个站点 hang 住了,那就是时候祭出 Celery 了(如果你需要更轻巧的东西,当然还有其他选择)。任何不需要同步的请求都可以排队,并最终由 Celery Worker 处理掉。我建议使用 redis 作为 Celery 的后端。除非你有充分的理由,否则不要在 RabbitMQ 上浪费时间,我一般使用 Celery 发送邮件或者从 API 拉取数据。另一个小技巧是,你可以设置定期任务作为一个 cron job。
  2. 使用 Gunicorn 搭建你的网站,而不是 Apache Apache 是经过战斗考验的,但是两年前我还是个新手的时候,我屁都不知道,它配置起来相当复杂。我只是想让一个网站正常运行,并忽略掉我代码里面的 print。Apache 有大量的配置需要去理解,这是我最受不了的。而 Gunicorn 非常简单,你只需要 gunicorn myproject.wsgi 当然,处理静态文件,我推荐 Nginx
  3. 使用 PostgreSQL 作为你的主数据库 PostgreSQL 支持 JSONB 数据类型,这意味着你可以在 PostgreSQL 中存储 documents,运行类似 MongoDB 那样的查询(带索引),而不会影响性能。最最重要的是,你仍然可以使用 Django ORM 和 Django admin 最近笔者看到一个统计报告,关系数据库的份额不降反增,啧啧
  4. 为 URL 命一个别名 from django.urls import path from . import views urlpatterns = [ #... path('articles/<int:year>/', views.year_archive, name='news-year-archive'), #... ] 后端使用 reverse 来将别名转换为 URL from django.urls import reverse from django.http import HttpResponseRedirect def redirect_to_year(request): # ... year = 2006 # ... return HttpResponseRedirect(reverse('news-year-archive', args=(year,))) 前端则使用 URL 的模板标签 <a href="{% url 'news-year-archive' 2012 %}">2012 Archive</a> <ul> {% for yearvar in year_list %} <li> <a href="{% url 'news-year-archive' yearvar %}">{{ yearvar }} Archive</a> </li> {% endfor %} </ul> 看起来蛮笨的,但是它会为您节省大量的时间,因为没有任何 URL 的硬编码,一个 URL 的改变,不会破坏任何的单元测试。
  5. 正确的使用 settings.py 文件 关于这个,已经有很多讨论了,就我个人而言,我喜欢将生产环境和开发环境的通用配置创建一个新文件 common.py 保存,再创建两个配置文件:
    • 生产环境配置:prod_settings.py
    • 开发环境配置:settings.py

它们均会在开头将 common.py 中的所有配置导入进去,再差异化的添加配置(同名也可以覆盖),像这样:

from .common import *

然后修改 wsgi.py

"""
WSGI config for helloworld 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/2.0/howto/deployment/wsgi/
"""
import os
from django.core.wsgi import get_wsgi_application

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "myproject.prod_settings") <--- 注意这里

application = get_wsgi_application()

这样,我可以直接在本地使用:

python manage.py runserver

现在你明白为什么我们仍然使用 settings.py 作为开发环境配置的名字的原因了吗?

而在生产环境,我们可以直接:

gunicorn myproject.wsgi

So easy!

  1. 使用 Supervisor 来进行进程监控 如果你还没听过 supervisor,而且正要将服务部署在基于 UNIX 的计算机上,那你可以继续向下看:Supervisor 将为你控制所有进程,您只需要为每个进程添加一个单独的配置文件。如果进程挂了,Supervisor 将会为你重新启动,一些例子:Celery-beat,Celery,Gunicorn,StatsD,MongoDB 等。
  2. 选择在恰当的时候是用 JSON,比如使用 Django-rest-framework 除非你想用 HTML 来完成整个页面的更新(当然,这也没什么错) Django 有一个内置的 JSON HTTP 响应: >>> from django.http import JsonResponse >>> response = JsonResponse({'foo': 'bar'}) >>> response.content b'{"foo": "bar"}' 当然如果你是 Django ORM 的重度使用者(你应该是),那么 Django-rest-framework 是个神器
  3. 使用 Redis 因为它最终会成为你最好的帮手,正如文章开头建议的,在一开始,Redis 可以用来协助 Celery 工作,然后,当时机成熟,你可以将你的会话存储到 Redis 中,你还可以将 Redis 作为缓存,还可以使用 Redis 来自动完成,总之,我只用 Redis
  4. 使用 Munin 或者 StatsD 来监控进程 Munin 可以让你画出几乎任何图表,StatsD 可以让你为任何东西计时、计数(累加)。有了它们,你可以监控你想监控的一切 你还可以很轻松的使用 Python 编写自己的 Munin 插件
  5. 最后,使用 VueJS 全家桶构建你的前端页面

后续会出一个全栈教程

原文发布于微信公众号 - 随心DevOps(heart-devops)

原文发表时间:2017-12-20

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小狼的世界

HP-UX培训学习笔记

HP-UX操作系统全称为Hewlett Packard UniX,是惠普服务器上所有的操作系统。其发源自 AT & T SRV4系统,可以支持HP的PA-RIS...

1552
来自专栏编程

年底总结一下Python WEB最好用的几个框架,让你有一个系统的了解

2017年就要过完了,我们来总结一下2017年最好用的17个Python Web框架 群内不定时分享干货,包括2017最新的python企业案例学习资料和零基础...

8728
来自专栏信安之路

Cobalt Strike 初体验

Cobalt Strike 一款以 metasploit 为基础的 GUI 的框架式渗透测试工具,集成了端口转发、服务扫描,自动化溢出,多模式端口监听,win ...

1340
来自专栏FreeBuf

聊一聊万恶的锁首

当手持8倍镜的98K都不能在使用程序时干掉万恶的锁首时,内心是十万头羊驼奔跑的场景,那我们就来聊一聊市面上常见的锁首方式。 ① :设置OpenHomePage、...

2227
来自专栏FreeBuf

利用Pentestbox打造MS17-010移动杀器

1、前言 前段时间Shadow Broker披露了 Windows大量漏洞,甚至爆出黑客组织 Equation Group 对于Windows 远程漏洞 MS1...

3677
来自专栏walterlv - 吕毅的博客

Windows 10 四月更新,文件夹名称也能区分大小写了

发布于 2018-06-14 00:02 更新于 2018-09...

3323
来自专栏信安之路

Mimikatz 攻防杂谈

前几天看到了老外一篇讲 mimikatz 防御的文章,感觉行文思路还不错,但是内容稍有不足,国内也有一篇翻译,但是只是照着错误翻译的,所以就萌生了把那篇优秀文章...

4722
来自专栏小特工作室

Navi.Soft31.微信WinForm框架(含下载地址)

1.概述 1.1应用场景 微信的出现,改变了我们日常生活。而微信公众平台的出现,使我们每个人都可能成为一个品牌,微商的普及、微店越来越多。越来越多的人,借助微信...

2807
来自专栏FreeBuf

记我的一次账号劫持和BLIND XSS漏洞发现过程

我发现的第一个漏洞就是不安全对象引用漏洞(IDOR),利用该漏洞我能在每个账户中创建一个 element x元素,经过和朋友的交流,他建议我可以试试在其中注入一...

1750
来自专栏北京马哥教育

Windows10+Ubuntu双系统安装

最近因为毕设重新回归Ubuntu,手头有一台装了Win10的ThinkPad X240s,最终成功完成了Windows 10 教育版和Ubuntu Kylin ...

8116

扫码关注云+社区

领取腾讯云代金券