Maison >Opération et maintenance >Nginx >Comment déployer Django via Nginx basé sur Ubuntu
Django peut être déployé de plusieurs manières, et nginx+uwsgi est l'une des méthodes les plus courantes.
Dans cette méthode, notre approche habituelle consiste à utiliser nginx comme frontal du serveur, qui recevra toutes les requêtes du Web et gérera les requêtes de manière uniforme. nginx gère lui-même toutes les requêtes statiques (c'est la force de nginx). Ensuite, nginx transmet toutes les requêtes non statiques à Django via uwsgi, qui est traité par Django, complétant ainsi une requête Web. On voit que uwsgi fonctionne comme un pont. Agir comme un pont.
1. Ses caractéristiques sont qu'il occupe moins de mémoire et possède de fortes capacités de concurrence. En fait, les capacités de concurrence de nginx fonctionnent mieux entre les serveurs Web du même type. nginx est également un serveur Web très populaire. Nous donnerons également ici une brève introduction pour l'utiliser pour déployer Django.
Site officiel de Nginx : Ouvrez la console Ubuntu (ctrl+alt+t) et utilisez l'entrepôt Ubuntu pour l'installer.fnngj@ubuntu:~$ sudo apt-get install nginx #安装Démarrez nginx :
fnngj@ubuntu:~$ /etc/init.d/nginx start #启动 fnngj@ubuntu:~$ /etc/init.d/nginx stop #关闭 fnngj@ubuntu:~$ /etc/init.d/nginx restart #重启Modifiez le numéro de port par défaut de nginx, ouvrez le fichier /etc/nginx/nginx.conf et modifiez le numéro de port.
server { listen 8088; # 修改端口号 server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; }Approximativement à la ligne 36 du fichier, remplacez le numéro de port par défaut 80 par un autre numéro de port, tel que 8088. Parce que le numéro de port par défaut 80 est facilement occupé par d'autres applications. Ensuite, redémarrez nginx via la commande ci-dessus. Visitez : http://127.0.0.1:8088/
Si l'image ci-dessus apparaît, cela signifie que nginx a démarré avec succès. W 2 : Installez UWSGI
Installez UWSGI via PIP.
root@ubuntu:/etc# python3 -m pip install uwsgi
Pour tester uwsgi, créez le fichier test.py : def application(env, start_response):
start_response('200 ok', [('content-type','text/html')])
return [b"hello world"]
Exécutez le fichier via uwsgi. fnngj@ubuntu:~/pydj$ uwsgi --http :8001 --wsgi-file test.py
uwsgi --http :8001 --chdir /home/fnngj/pydj/myweb / -- wsgi-file myweb/wsgi.py --master --processes 4 --threads 2 --stats 127.0.0.1:9191
Options communes :http : type de protocole et numéro de port
processus : activé Nombre de processus
workers : Le nombre de processus démarrés est équivalent aux processus (le site officiel indique qu'il génère le nombre spécifié de travailleurs/processus) chdir : Spécifiez le répertoire en cours d'exécution (chdir vers le répertoire spécifié avant le chargement des applications)
wsgi-file : Charger Entrez le fichier wsgi (charger le fichier .wsgi)
stats : Activer le serveur de statistiques sur l'adresse spécifiée (activer le serveur de statistiques sur l'adresse spécifiée)
threads : Exécuter les threads. En raison de l’existence de Gil, je pense que c’est vraiment inutile. (exécutez chaque travailleur en mode préthread avec le nombre de threads spécifié)
master : autorisez le processus maître à exister (activez le processus maître)
daemonize : faites en sorte que le processus s'exécute en arrière-plan et se connecte au fichier journal ou au serveur udp spécifié ( démoniser uwsgi). En fait, la méthode la plus couramment utilisée consiste à exporter les enregistrements en cours dans un fichier local.
pidfile : spécifiez l'emplacement du fichier pid et enregistrez le numéro pid du processus principal.
Vide : Nettoyez automatiquement l'environnement à la fermeture du serveur, supprimez le fichier de socket Unix et le fichier pid (essayez de supprimer tous les fichiers/sockets générés)
Trois, nginx+uwsgi+django Ensuite, nous voulons combiner les trois. Commençons par lister les fichiers requis pour le projet :myweb/ ├── manage.py ├── myweb/ │ ├── __init__.py │ ├── settings.py │ ├── urls.py │ └── wsgi.py └── myweb_uwsgi.iniLorsque nous avons créé le projet myweb via Django, le fichier wsgi.py a été généré pour nous dans le sous-répertoire myweb. Par conséquent, il suffit de créer le fichier de configuration myweb_uwsgi.ini. Bien entendu, uwsgi prend en charge plusieurs types de fichiers de configuration, tels que XML, ini, etc. Ici, utilisez la configuration de type ini.
# myweb_uwsgi.ini file [uwsgi] # django-related settings socket = :8000 # the base directory (full path) chdir = /home/fnngj/pydj/myweb # django s wsgi file module = myweb.wsgi # process-related settings # master master = true # maximum number of worker processes processes = 4 # ... with appropriate permissions - may be needed # chmod-socket = 664 # clear environment on exit vacuum = true
这个配置,其实就相当于在上一小节中通过wsgi命令,后面跟一堆参数的方式,给文件化了。
socket 指定项目执行的端口号。
chdir 指定项目的目录。
module myweb.wsgi ,可以这么来理解,对于myweb_uwsgi.ini文件来说,与它的平级的有一个myweb目录,这个目录下有一个wsgi.py文件。
其它几个参数,可以参考上一小节中参数的介绍。
接下来,切换到myweb项目目录下,通过uwsgi命令读取myweb_uwsgi.ini文件启动项目。
fnngj@ubuntu:~$ cd /home/fnngj/pydj/myweb/ fnngj@ubuntu:~/pydj/myweb$ uwsgi --ini myweb_uwsgi.ini [uwsgi] getting ini configuration from myweb_uwsgi.ini *** starting uwsgi 2.0.12 (32bit) on [sat mar 12 13:05:06 2016] *** compiled with version: 4.8.4 on 26 january 2016 06:14:41 os: linux-3.19.0-25-generic #26~14.04.1-ubuntu smp fri jul 24 21:18:00 utc 2015 nodename: ubuntu machine: i686 clock source: unix detected number of cpu cores: 2 current working directory: /home/fnngj/pydj/myweb detected binary path: /usr/local/bin/uwsgi !!! no internal routing support, rebuild with pcre support !!! chdir() to /home/fnngj/pydj/myweb your processes number limit is 15962 your memory page size is 4096 bytes detected max file descriptor number: 1024 lock engine: pthread robust mutexes thunder lock: disabled (you can enable it with --thunder-lock) uwsgi socket 0 bound to tcp address :8000 fd 3 python version: 3.4.3 (default, oct 14 2015, 20:37:06) [gcc 4.8.4] *** python threads support is disabled. you can enable it with --enable-threads *** python main interpreter initialized at 0x8b52dc0 your server socket listen backlog is limited to 100 connections your mercy for graceful operations on workers is 60 seconds mapped 319920 bytes (312 kb) for 4 cores *** operational mode: preforking *** wsgi app 0 (mountpoint='') ready in 1 seconds on interpreter 0x8b52dc0 pid: 7158 (default app) *** uwsgi is running in multiple interpreter mode *** spawned uwsgi master process (pid: 7158) spawned uwsgi worker 1 (pid: 7160, cores: 1) spawned uwsgi worker 2 (pid: 7161, cores: 1) spawned uwsgi worker 3 (pid: 7162, cores: 1) spawned uwsgi worker 4 (pid: 7163, cores: 1)
注意查看uwsgi的启动信息,如果有错,就要检查配置文件的参数是否设置有误。
再接下来要做的就是修改nginx.conf配置文件。打开/etc/nginx/nginx.conf文件,添加如下内容。
…… server { listen 8099; server_name 127.0.0.1 charset utf-8; access_log /var/log/nginx/myweb_access.log; error_log /var/log/nginx/myweb_error.log; client_max_body_size 75m; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:8000; uwsgi_read_timeout 2; } location /static { expires 30d; autoindex on; add_header cache-control private; alias /home/fnngj/pydj/myweb/static/; } } ……
listen 指定的是nginx代理uwsgi对外的端口号。
server_name 网上大多资料都是设置的一个网址(例,www.example.com),我这里如果设置成网址无法访问,所以,指定的到了本机默认ip。
在进行配置的时候,我有个问题一直想不通。nginx到底是如何uwsgi产生关联。现在看来大概最主要的就是这两行配置。
include uwsgi_params;
uwsgi_pass 127.0.0.1:8000;
include 必须指定为uwsgi_params;而uwsgi_pass指的本机ip的端口与myweb_uwsgi.ini配置文件中的必须一直。
现在重新启动nginx,翻看上面重启动nginx的命令。然后,访问:http://127.0.0.1:8099/
通过这个ip和端口号的指向,请求应该是先到nginx的。如果你在页面上执行一些请求,就会看到,这些请求最终会转到uwsgi来处理。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!