您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“怎么在Linux上托管Django應(yīng)用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么在Linux上托管Django應(yīng)用”吧!
介紹
托管 Django Web 應(yīng)用程序相當(dāng)簡單,雖然它比標(biāo)準(zhǔn)的 PHP 應(yīng)用程序更復(fù)雜一些。 讓 Web 服務(wù)器對接 Django 的方法有很多。 Gunicorn 就是其中最簡單的一個(gè)。
Gunicorn(Green Unicorn 的縮寫)在你的 Web 服務(wù)器 Django 之間作為中間服務(wù)器使用,在這里,Web 服務(wù)器就是 Nginx。 Gunicorn 服務(wù)于應(yīng)用程序,而 Nginx 處理靜態(tài)內(nèi)容。
Gunicorn
安裝
使用 Pip 安裝 Gunicorn 是超級簡單的。 如果你已經(jīng)使用 virtualenv 搭建好了你的 Django 項(xiàng)目,那么你就有了 Pip,并且應(yīng)該熟悉 Pip 的工作方式。 所以,在你的 virtualenv 中安裝 Gunicorn。
$ pip install gunicorn
配置
Gunicorn 最有吸引力的一個(gè)地方就是它的配置非常簡單。處理配置***的方法就是在 Django 項(xiàng)目的根目錄下創(chuàng)建一個(gè)名叫 Gunicorn 的文件夾。然后在該文件夾內(nèi),創(chuàng)建一個(gè)配置文件。
在本篇教程中,配置文件名稱是 gunicorn-conf.py。在該文件中,創(chuàng)建類似于下面的配置:
import multiprocessing bind = 'unix:///tmp/gunicorn1.sock' workers = multiprocessing.cpu_count() * 2 + 1 reload = True daemon = True
在上述配置的情況下,Gunicorn 會在 /tmp/ 目錄下創(chuàng)建一個(gè)名為 gunicorn1.sock 的 Unix 套接字。 還會啟動一些工作進(jìn)程,進(jìn)程數(shù)量相當(dāng)于 CPU 內(nèi)核數(shù)量的 2 倍。 它還會自動重新加載并作為守護(hù)進(jìn)程運(yùn)行。
運(yùn)行
Gunicorn 的運(yùn)行命令有點(diǎn)長,指定了一些附加的配置項(xiàng)。 最重要的部分是將 Gunicorn 指向你項(xiàng)目的 .wsgi 文件。
gunicorn -c gunicorn/gunicorn-conf.py -D --error-logfile gunicorn/error.log yourproject.wsgi
上面的命令應(yīng)該從項(xiàng)目的根目錄運(yùn)行。 -c 選項(xiàng)告訴 Gunicorn 使用你創(chuàng)建的配置文件。 -D 再次指定 gunicorn 為守護(hù)進(jìn)程。 ***一部分指定 Gunicorn 的錯(cuò)誤日志文件在你創(chuàng)建 Gunicorn 文件夾中的位置。 命令結(jié)束部分就是為 Gunicorn 指定 .wsgi 文件的位置。
Nginx
現(xiàn)在 Gunicorn 配置好了并且已經(jīng)開始運(yùn)行了,你可以設(shè)置 Nginx 連接它,為你的靜態(tài)文件提供服務(wù)。 本指南假定你已經(jīng)配置好了 Nginx,而且你通過它托管的站點(diǎn)使用了單獨(dú)的 server 塊。 它還將包括一些 SSL 信息。
如果你想知道如何讓你的網(wǎng)站獲得免費(fèi)的 SSL 證書,請查看我們的 Let'sEncrypt 指南。
# 連接到 Gunicorn upstream yourproject-gunicorn { server unix:/tmp/gunicorn1.sock fail_timeout=0; } # 將未加密的流量重定向到加密的網(wǎng)站 server { listen 80; server_name yourwebsite.com; return 301 https://yourwebsite.com$request_uri; } # 主服務(wù)塊 server { # 設(shè)置監(jiān)聽的端口,指定監(jiān)聽的域名 listen 443 default ssl; client_max_body_size 4G; server_name yourwebsite.com; # 指定日志位置 access_log /var/log/nginx/yourwebsite.access_log main; error_log /var/log/nginx/yourwebsite.error_log info; # 告訴 nginx 你的 ssl 證書 ssl on; ssl_certificate /etc/letsencrypt/live/yourwebsite.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/yourwebsite.com/privkey.pem; # 設(shè)置根目錄 root /var/www/yourvirtualenv/yourproject; # 為 Nginx 指定靜態(tài)文件路徑 location /static/ { # Autoindex the files to make them browsable if you want autoindex on; # The location of your files alias /var/www/yourvirtualenv/yourproject/static/; # Set up caching for your static files expires 1M; access_log off; add_header Cache-Control "public"; proxy_ignore_headers "Set-Cookie"; } # 為 Nginx 指定你上傳文件的路徑 location /media/ { Autoindex if you want autoindex on; # The location of your uploaded files alias /var/www/yourvirtualenv/yourproject/media/; # Set up aching for your uploaded files expires 1M; access_log off; add_header Cache-Control "public"; proxy_ignore_headers "Set-Cookie"; } location / { # Try your static files first, then redirect to Gunicorn try_files $uri @proxy_to_app; } # 將請求傳遞給 Gunicorn location @proxy_to_app { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://njc-gunicorn; } # 緩存 HTML、XML 和 JSON location ~* \.(html?|xml|json)$ { expires 1h; } # 緩存所有其他的靜態(tài)資源 location ~* \.(jpg|jpeg|png|gif|ico|css|js|ttf|woff2)$ { expires 1M; access_log off; add_header Cache-Control "public"; proxy_ignore_headers "Set-Cookie"; } }
配置文件有點(diǎn)長,但是還可以更長一些。其中重點(diǎn)是指向 Gunicorn 的 upstream 塊以及將流量傳遞給 Gunicorn 的 location 塊。大多數(shù)其他的配置項(xiàng)都是可選,但是你應(yīng)該按照一定的形式來配置。配置中的注釋應(yīng)該可以幫助你了解具體細(xì)節(jié)。
保存文件之后,你可以重啟 Nginx,讓修改的配置生效。
# systemctl restart nginx
一旦 Nginx 在線生效,你的站點(diǎn)就可以通過域名訪問了。
到此,相信大家對“怎么在Linux上托管Django應(yīng)用”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。