Django:Nginx und Gunicorn mit Socket: Unterschied zwischen den Versionen
// via Wikitext Extension for VSCode |
// via Wikitext Extension for VSCode |
||
Zeile 28: | Zeile 28: | ||
sudo mkdir -p /run/gunicorn | sudo mkdir -p /run/gunicorn | ||
sudo touch /run/gunicorn/thorsten.sock | sudo touch /run/gunicorn/thorsten.sock | ||
sudo chown thorsten:thorsten /run/gunicorn | sudo chown thorsten:thorsten /run/gunicorn/thorsten.sock | ||
sudo chmod 755 /run/gunicorn | sudo chmod 755 /run/gunicorn/thorsten.sock | ||
</pre> | </pre> | ||
Version vom 17. September 2024, 10:15 Uhr
Django: Nginx und Gunicorn mit unix:socket
Gunicorn ist ein WSGI-HTTP-Server für Python-Anwendungen. Er ist eine Alternative zu uWSGI und mod_wsgi. Gunicorn ist ein reiner Python-Server und kann mit Django, Flask und anderen Python-Web-Frameworks verwendet werden.
In diesem Tutorial werden wir zeigen, wie
- Django-Anwendung auf einem Gunicorn-Server ausgeführt wird. - Nginx als Reverse-Proxy-Server für Gunicorn konfiguriert wird. - Gunicorn mit einem Unix-Socket anstelle eines TCP-Sockets konfiguriert wird.
Schritt 1: Gunicorn mit einem Unix-Socket
Gunicorn kann mit einem Unix-Socket anstelle eines TCP-Sockets konfiguriert werden. Ein Unix-Socket ist ein Kommunikationsendpunkt, der auf dem Dateisystem erstellt wird. Es ist schneller als ein TCP-Socket, da es keine Netzwerkschicht durchläuft.
Erstellen Sie ein Verzeichnis für die Sockeldatei:
sudo mkdir /run/gunicorn
Erstellen Sie eine Sockeldatei:
Ändern Sie die Berechtigungen der Sockeldatei:
sudo chown -R thorsten:thorsten /home/thorsten/portal sudo chmod -R 755 /home/thorsten/portal sudo mkdir -p /run/gunicorn sudo touch /run/gunicorn/thorsten.sock sudo chown thorsten:thorsten /run/gunicorn/thorsten.sock sudo chmod 755 /run/gunicorn/thorsten.sock
Erstellen Sie eine Systemd-Dienstdatei für Gunicorn:
sudo nano /etc/systemd/system/gunicorn.service
Fügen Sie den folgenden Inhalt hinzu:
[Unit] Description=gunicorn daemon After=network.target [Service] User=thorsten Group=thorsten WorkingDirectory=/home/thorsten/portal ExecStart=/home/thorsten/portal/.venv/bin/gunicorn --access-logfile - --workers 3 --bind unix:/run/gunicorn/thorsten.sock portal.wsgi:application [Install] WantedBy=multi-user.target
Starten und aktivieren Sie den Gunicorn-Dienst:
sudo systemctl start gunicorn sudo systemctl enable gunicorn
Schritt 2: Nginx als Reverse-Proxy-Server für Gunicorn
Nginx kann als Reverse-Proxy-Server für Gunicorn konfiguriert werden. Ein Reverse-Proxy-Server empfängt Anfragen von Clients und leitet sie an den entsprechenden Server weiter.
Erstellen Sie eine Nginx-Konfigurationsdatei:
sudo nano /etc/nginx/sites-available/myproject
Fügen Sie den folgenden Inhalt hinzu:
server { listen 80; server_name example.com; location / { proxy_pass http://unix:/run/gunicorn/django.sock; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } }
Aktivieren Sie die Nginx-Konfigurationsdatei:
sudo ln -s /etc/nginx/sites-available/myproject /etc/nginx/sites-enabled
Starten Sie Nginx:
sudo systemctl start nginx