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

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

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

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

 
  
  1. # systemctl restart nginx 

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

结语

如果你想深入研究,Nginx 可以做很多事情。但是,上面提供的配置是一个很好的开始,并且你可以用于实践中。 如果你见惯了 Apache 和臃肿的 PHP 应用程序,像这样的服务器配置的速度应该是一个惊喜。





作者:Nick Congleton
来源:51CTO
以下是一个基本的 NginxGunicornDjango 和 DRF 示例,涵盖了常见的配置和设置: 1. 安装和配置 Nginx 在服务器上安装 Nginx,并创建一个新的站点配置文件。以下是一个示例配置文件,将所有请求转发到 Gunicorn: ``` server { listen 80; server_name yourdomain.com; location / { proxy_pass http://127.0.0.1:8000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 2. 安装和配置 GunicornDjango 项目的虚拟环境中安装 Gunicorn: ``` pip install gunicorn ``` 创建一个 Gunicorn 配置文件(比如 gunicorn_config.py),指定项目的 WSGI 应用程序和其他选项: ``` import multiprocessing bind = "127.0.0.1:8000" workers = multiprocessing.cpu_count() * 2 + 1 ``` 3. 安装和配置 Django 和 DRF 在 Django 项目的虚拟环境中安装 Django 和 DRF: ``` pip install django djangorestframework ``` 创建一个 Django 项目,并在 settings.py 中添加 DRF 的应用程序: ``` INSTALLED_APPS = [ ... 'rest_framework', ... ] ``` 在 urls.py 中添加 DRF 的路由: ``` from django.urls import path, include urlpatterns = [ ... path('api/', include('rest_framework.urls')), ... ] ``` 创建一个 DRF 视图(比如 views.py),实现一个简单的 API: ``` from rest_framework.views import APIView from rest_framework.response import Response class HelloWorldView(APIView): def get(self, request): return Response("Hello, World!") ``` 在 urls.py 中添加一个路由,将视图映射到 URL: ``` from django.urls import path from .views import HelloWorldView urlpatterns = [ ... path('api/hello/', HelloWorldView.as_view()), ... ] ``` 4. 启动应用程序 使用 Gunicorn 启动 Django 项目: ``` gunicorn myproject.wsgi:application -c gunicorn_config.py ``` 访问 http://yourdomain.com/api/hello/,应该会看到 "Hello, World!" 的响应。如果您遇到任何问题,请参阅 NginxGunicornDjango 和 DRF 的文档和教程,以获取更详细的说明和指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值