💾 Archived View for chirale.org › 2018-08-23_4358.gmi captured on 2024-12-17 at 10:16:39. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2024-05-12)

-=-=-=-=-=-=-

Nginx configuration for Django

Django is a powerful framework for building websites. To run a production website, usually an application server is used. So nginx will do two basic things:

The application server used in this example is gunicorn, the application server chosen by Instagram of the earlier days, but it can be anything running on port Change port number as required in the example.

chosen by Instagram of the earlier days

The following nginx conf was adapted from this, with some additions and it contains:

this

It works fine with Django 1 and

 # Howto: https://chirale.org/2018/08/23/nginx-configuration-for-django/ # uncomment for redirect # server { # # redirect WITH www from example.com and example.net # listen 80; # server_name example.com example.net; # return 301 http://www.example.com$request_uri; # } server { listen 80; # the domain name it will serve for server_name www.example.com; charset utf-8; # max upload size client_max_body_size 75M; # enable gzip for proxy requests gzip on; gzip_proxied any; gzip_vary on; gzip_http_version 1; gzip_types application/javascript application/json text/css text/xml; gzip_comp_level 4; # @see http://uwsgi-docs.readthedocs.org/en/latest/tutorials/Django_and_nginx.html#configure-nginx-for-your-site # Django media location /media { etag on; expires 365d; alias /path/to/media_root; # your Django project's media files - amend as required } location /static { etag on; expires 1m; alias /path/to/static_root; # your Django project's static files - amend as required } location /favicon.ico { # all favicons inside /path/to/favicons/ this directory # notation: www.example.com.ico alias /path/to/favicons/$host.ico; } location / { # an HTTP header important enough to have its own Wikipedia entry: # http://en.wikipedia.org/wiki/X-Forwarded-For proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # enable this if and only if you use HTTPS, this helps Rack # set the proper protocol for doing redirects: # proxy_set_header X-Forwarded-Proto https; # pass the Host: header from the client right along so redirects # can be set properly within the Rack application proxy_set_header Host $http_host; # we don't want nginx trying to do something clever with # redirects, we set the Host: header above already. proxy_redirect off; # set "proxy_buffering off" *only* for Rainbows! when doing # Comet/long-poll stuff. It's also safe to set if you're # using only serving fast clients with Unicorn + nginx. # Otherwise you _want_ nginx to buffer responses to slow # clients, really. # proxy_buffering off; # Uncomment for maintenance ### auth_basic "Insert password here"; ### auth_basic_user_file /path/to/.htpasswd; proxy_connect_timeout 30000; proxy_send_timeout 30000; proxy_read_timeout 30000; send_timeout 30000; # @see https://eng.eelcowesemann.nl/linux-unix-android/nginx/nginx-blocking/ and seositecheckup.com if ($http_user_agent ~ "libwww-perl") { return 403; break; } # Try to serve static files from nginx, no point in making an # *application* server like Unicorn/Rainbows! serve static files. if (!-f $request_filename) { proxy_pass http://localhost:9999; break; } } } 

Run nginx -t to check and then systemctl reload nginx to apply.

This is a http version, to configure the website for https follow this howto.

this howto

https://web.archive.org/web/20180823000000*/https://instagram-engineering.com/what-powers-instagram-hundreds-of-instances-dozens-of-technologies-adf2e22da2ad#040f

https://web.archive.org/web/20180823000000*/http://michal.karzynski.pl/blog/2013/06/09/django-nginx-gunicorn-virtualenv-supervisor/

# uncomment for redirect # server { # # redirect WITH www from example.com and example.net # listen 80; # server_name example.com example.net; # return 301 http://www.example.com$request_uri; # } server { listen 80; # the domain name it will serve for server_name www.example.com; charset utf-8; # max upload size client_max_body_size 75M; # enable gzip for proxy requests gzip on; gzip_proxied any; gzip_vary on; gzip_http_version 1.1; gzip_types application/javascript application/json text/css text/xml; gzip_comp_level 4; # @see http://uwsgi-docs.readthedocs.org/en/latest/tutorials/Django_and_nginx.html#configure-nginx-for-your-site # Django media location /media { etag on; expires 365d; alias /path/to/media_root; # your Django project's media files - amend as required } location /static { etag on; expires 1m; alias /path/to/static_root; # your Django project's static files - amend as required } location /favicon.ico { # all favicons inside /path/to/favicons/ this directory # notation: www.example.com.ico alias /path/to/favicons/$host.ico; } location / { # an HTTP header important enough to have its own Wikipedia entry: # http://en.wikipedia.org/wiki/X-Forwarded-For proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # enable this if and only if you use HTTPS, this helps Rack # set the proper protocol for doing redirects: # proxy_set_header X-Forwarded-Proto https; # pass the Host: header from the client right along so redirects # can be set properly within the Rack application proxy_set_header Host $http_host; # we don't want nginx trying to do something clever with # redirects, we set the Host: header above already. proxy_redirect off; # set

and seositecheckup.com if ($http_user_agent ~

break; } } } </pre> <p>Run <em>nginx -t</em> to check and then <em>systemctl reload nginx</em> to apply.</p> <p>This is a http version, to configure the website for https follow <a href=

https://web.archive.org/web/20180823000000*/http://chirale.org/2017/02/27/free-ssl-certificates-and-how-to-install-on-nginx-in-10-steps/