在 Linux 上使用 Nginx 和 Gunicorn 托管 Django 应用

简介:

介绍

托管 Django Web 应用程序相当简单,虽然它比标准的 PHP 应用程序更复杂一些。 让 Web 服务器对接 Django 的方法有很多。 Gunicorn 就是其中最简单的一个。

Gunicorn(Green Unicorn 的缩写)在你的 Web 服务器 Django 之间作为中间服务器使用,在这里,Web 服务器就是 Nginx。 Gunicorn 服务于应用程序,而 Nginx 处理静态内容。

Gunicorn

安装

使用 Pip 安装 Gunicorn 是超级简单的。 如果你已经使用 virtualenv 搭建好了你的 Django 项目,那么你就有了 Pip,并且应该熟悉 Pip 的工作方式。 所以,在你的 virtualenv 中安装 Gunicorn。

 
  1. $ pip install gunicorn

配置

Gunicorn 最有吸引力的一个地方就是它的配置非常简单。处理配置最好的方法就是在 Django 项目的根目录下创建一个名叫 Gunicorn 的文件夹。然后在该文件夹内,创建一个配置文件。

在本篇教程中,配置文件名称是 gunicorn-conf.py。在该文件中,创建类似于下面的配置:

 
  1. import multiprocessing
  2. bind = 'unix:///tmp/gunicorn1.sock'
  3. workers = multiprocessing.cpu_count() * 2 + 1
  4. reload = True
  5. daemon = True

在上述配置的情况下,Gunicorn 会在 /tmp/ 目录下创建一个名为 gunicorn1.sock 的 Unix 套接字。 还会启动一些工作进程,进程数量相当于 CPU 内核数量的 2 倍。 它还会自动重新加载并作为守护进程运行。

运行

Gunicorn 的运行命令有点长,指定了一些附加的配置项。 最重要的部分是将 Gunicorn 指向你项目的 .wsgi文件。

 
  1. gunicorn -c gunicorn/gunicorn-conf.py -D --error-logfile gunicorn/error.log yourproject.wsgi

上面的命令应该从项目的根目录运行。 -c 选项告诉 Gunicorn 使用你创建的配置文件。 -D 再次指定 gunicorn 为守护进程。 最后一部分指定 Gunicorn 的错误日志文件在你创建 Gunicorn 文件夹中的位置。 命令结束部分就是为 Gunicorn 指定 .wsgi 文件的位置。

Nginx

现在 Gunicorn 配置好了并且已经开始运行了,你可以设置 Nginx 连接它,为你的静态文件提供服务。 本指南假定你已经配置好了 Nginx,而且你通过它托管的站点使用了单独的 server 块。 它还将包括一些 SSL 信息。

如果你想知道如何让你的网站获得免费的 SSL 证书,请查看我们的 Let'sEncrypt 指南

 
  1. # 连接到 Gunicorn
  2. upstream yourproject-gunicorn {
  3. server unix:/tmp/gunicorn1.sock fail_timeout=0;
  4. }
  5. # 将未加密的流量重定向到加密的网站
  6. server {
  7. listen 80;
  8. server_name yourwebsite.com;
  9. return 301 https://yourwebsite.com$request_uri;
  10. }
  11. # 主服务块
  12. server {
  13. # 设置监听的端口,指定监听的域名
  14. listen 443 default ssl;
  15. client_max_body_size 4G;
  16. server_name yourwebsite.com;
  17. # 指定日志位置
  18. access_log /var/log/nginx/yourwebsite.access_log main;
  19. error_log /var/log/nginx/yourwebsite.error_log info;
  20. # 告诉 nginx 你的 ssl 证书
  21. ssl on;
  22. ssl_certificate /etc/letsencrypt/live/yourwebsite.com/fullchain.pem;
  23. ssl_certificate_key /etc/letsencrypt/live/yourwebsite.com/privkey.pem;
  24. # 设置根目录
  25. root /var/www/yourvirtualenv/yourproject;
  26. # Nginx 指定静态文件路径
  27. location /static/ {
  28. # Autoindex the files to make them browsable if you want
  29. autoindex on;
  30. # The location of your files
  31. alias /var/www/yourvirtualenv/yourproject/static/;
  32. # Set up caching for your static files
  33. expires 1M;
  34. access_log off;
  35. add_header Cache-Control "public";
  36. proxy_ignore_headers "Set-Cookie";
  37. }
  38. # Nginx 指定你上传文件的路径
  39. location /media/ {
  40. Autoindex if you want
  41. autoindex on;
  42. # The location of your uploaded files
  43. alias /var/www/yourvirtualenv/yourproject/media/;
  44. # Set up aching for your uploaded files
  45. expires 1M;
  46. access_log off;
  47. add_header Cache-Control "public";
  48. proxy_ignore_headers "Set-Cookie";
  49. }
  50. location / {
  51. # Try your static files first, then redirect to Gunicorn
  52. try_files $uri @proxy_to_app;
  53. }
  54. # 将请求传递给 Gunicorn
  55. location @proxy_to_app {
  56. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  57. proxy_set_header Host $http_host;
  58. proxy_redirect off;
  59. proxy_pass http://njc-gunicorn;
  60. }
  61. # 缓存 HTMLXML JSON
  62. location ~* \.(html?|xml|json)$ {
  63. expires 1h;
  64. }
  65. # 缓存所有其他的静态资源
  66. location ~* \.(jpg|jpeg|png|gif|ico|css|js|ttf|woff2)$ {
  67. expires 1M;
  68. access_log off;
  69. add_header Cache-Control "public";
  70. proxy_ignore_headers "Set-Cookie";
  71. }
  72. }

配置文件有点长,但是还可以更长一些。其中重点是指向 Gunicorn 的 upstream 块以及将流量传递给 Gunicorn 的 location 块。大多数其他的配置项都是可选,但是你应该按照一定的形式来配置。配置中的注释应该可以帮助你了解具体细节。

保存文件之后,你可以重启 Nginx,让修改的配置生效。

 
  1. # systemctl restart nginx

一旦 Nginx 在线生效,你的站点就可以通过域名访问了。

原文发布时间为:2017-04-15

本文来自云栖社区合作伙伴“Linux中国”

相关文章
|
2月前
|
前端开发 JavaScript UED
探索Python Django中的WebSocket集成:为前后端分离应用添加实时通信功能
通过在Django项目中集成Channels和WebSocket,我们能够为前后端分离的应用添加实时通信功能,实现诸如在线聊天、实时数据更新等交互式场景。这不仅增强了应用的功能性,也提升了用户体验。随着实时Web应用的日益普及,掌握Django Channels和WebSocket的集成将为开发者开启新的可能性,推动Web应用的发展迈向更高层次的实时性和交互性。
101 1
|
1月前
|
缓存 Linux 开发者
Linux内核中的并发控制机制:深入理解与应用####
【10月更文挑战第21天】 本文旨在为读者提供一个全面的指南,探讨Linux操作系统中用于实现多线程和进程间同步的关键技术——并发控制机制。通过剖析互斥锁、自旋锁、读写锁等核心概念及其在实际场景中的应用,本文将帮助开发者更好地理解和运用这些工具来构建高效且稳定的应用程序。 ####
46 5
|
2月前
|
IDE 关系型数据库 MySQL
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
这篇文章是关于如何创建一个Django框架,介绍Django的项目结构和开发逻辑,并指导如何创建应用和编写“Hello, World!”程序的教程。
121 3
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
|
1月前
|
存储 安全 关系型数据库
Linux系统在服务器领域的应用与优势###
本文深入探讨了Linux操作系统在服务器领域的广泛应用及其显著优势。通过分析其开源性、安全性、稳定性和高效性,揭示了为何Linux成为众多企业和开发者的首选服务器操作系统。文章还列举了Linux在服务器管理、性能优化和社区支持等方面的具体优势,为读者提供了全面而深入的理解。 ###
|
2月前
|
消息中间件 存储 NoSQL
django的gunicorn的异步任务执行
django的gunicorn的异步任务执行
51 4
|
2月前
|
Kubernetes 负载均衡 应用服务中间件
k8s学习--ingress详细解释与应用(nginx ingress controller))
k8s学习--ingress详细解释与应用(nginx ingress controller))
395 0
|
2月前
|
监控 应用服务中间件 网络安全
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
169 0
|
2月前
|
存储 开发框架 JSON
【查漏补缺】Django模型字段类型及其应用
【查漏补缺】Django模型字段类型及其应用
30 0
|
2月前
|
存储 安全 UED
GitHub OAuth认证的Django应用
GitHub OAuth认证的Django应用
30 0
|
4月前
|
Unix Linux Ruby
在windows和linux上高效快捷地发布Dash应用
在windows和linux上高效快捷地发布Dash应用