(譯)一個完整的Django入門指南 第7部分

一、前言

本篇文章是翻譯 A Complete Beginner's Guide to Django 系列的最後一篇文章 A Complete Beginner's Guide to Django - Part 7,由於搜索找了好久都沒有找到對應的中文翻譯篇(若是有,就是我沒有找到...),又由於這個系列真的很是的好,簡單,容易,很是適配入門,因此就打算自已試試翻譯,也當是本身學習入門的一步吧!css

簡介(Introduction)

20180714-A-Complete Beginner's-Guide-to-Django-Part7.jpg

歡迎來到咱們教程系列的最後一部分!這篇文章,咱們將把Django應用程序部署到生產服務器。咱們還將爲咱們的服務器配置Email服務和HTTPS證書。html

首先,我想到了給一個使用虛擬專用服務器(VPS)的例子,它更通用,而後使用一個平臺好比 Heroku 服務。但它我寫得太詳細了,因此本教程我最終偏向關於VPS的內容。python

咱們的項目已經上線啦!您能夠在閱讀本文以前點擊在線查看,這是咱們本文要部署的應用程序:www.djangoboards.comjquery

版本控制(Version Control)

版本控制是軟件開發中很是重要的話題。特別是在團隊開發中同時開發多個功能,並一塊兒維護項目代碼時。不管是一個開發人員項目仍是多個開發人員項目,每一個項目都應該使用版本控制。linux

版本控制系統有幾種選擇。也許是由於GitHub的流行,Git 成爲版本控制的實際標準。因此若是你不熟悉版本控制,Git是一個很好的入門起點。通常有不少相關的教程,課程和資源,所以遇到問題很容易找到幫助。nginx

GitHub和Code School有一個關於Git的很棒的互動教程,這是一個很是好的介紹Git的網站。幾年前我就開始從SVN轉到Git。git

這是一個很是重要的話題,我其實應該從第一個教程開始講Git。但事實是我但願本教程系列的重點放在Django上。若是Git這東西對您來講都是新的,請不要擔憂。一步一步入門是很重要的。也許你的第一個項目並不完美。重要的是要堅持學習和慢慢提升你的技能,但要有恆心!github

關於Git的一個很是好的事情是它不只僅是一個版本控制系統。圍繞它創建了豐富的工具和服務生態系統。一些很好的例子好比持續集成、部署、代碼審查、代碼質量和項目管理。sql

使用Git來支持Django項目的部署過程很是有用。這是從源代碼存儲庫中拉取最新版本或在出現問題時回滾到特定版本的便捷方式。有許多服務使用Git來集成,以便執行自動化測試和部署。數據庫

若是您沒有在本地計算機上安裝Git,請從 git-scm.com/downloads 下載和安裝。

Git 基本配置(Basic Setup)

首先,設置你電腦的Git身份:

git config --global user.name "Vitor Freitas"
    git config --global user.email vitor@simpleisbetterthancomplex.com
複製代碼

譯者注:

  • git config --global user.name 「xxx」: 設置git操做者名稱
  • git config --global user.email 「email」 設置git操做者郵箱 這2個配置的名字和郵箱,會記錄在git操做記錄中。

在項目根目錄(與manage.py相同的目錄)中,初始化一個git存儲庫:

git init
複製代碼
Initialized empty Git repository in /Users/vitorfs/Development/myproject/.git/
複製代碼

檢查存儲庫的狀態:

git status
複製代碼
On branch master

Initial commit

Untracked files:
  (use "git add <file>..." to include in what will be committed)

  accounts/
  boards/
  manage.py
  myproject/
  requirements.txt
  static/
  templates/

nothing added to commit but untracked files present (use "git add" to track)
複製代碼

在繼續添加源文件以前,請在項目根目錄中建立名爲**.gitignore**的新文件。這個特殊的文件將幫助咱們保持Git倉庫的乾淨,保證緩存文件或日誌這樣的沒必要要的文件不會添加到Git倉庫中。

您能夠從 GitHub 獲取 Python項目的通用.gitignore文件

確保將它從 Python.gitignore 重命名爲 .gitignore(點很重要!)。

您能夠補充 .gitignore 文件內容,告訴它(Git)忽略SQLite數據庫文件,例如:

.gitignore 文件內容:

__pycache__/
*.py[cod]
.env
venv/

SQLite database files
*.sqlite3
複製代碼

如今將文件添加到存儲庫:

git add .
複製代碼

請注意上面add後面有一個點。上面的命令告訴Git 在當前目錄中添加全部未跟蹤的文件。(譯者注,點表示全部,整句就表示添加因此文件到Git,除了.gitignore文件列出的要忽略。)

如今進行第一次提交:

git commit -m "Initial commit"
複製代碼

必定要寫一個註釋說明這個提交是什麼,簡要描述你改變了什麼。

Git 遠程倉庫(Remote Repository)

如今讓咱們將 GitHub 設置爲遠程倉庫。首先,在GitHub上建立一個免費賬戶,而後在電子郵件中點擊GitHub發來的驗證連接確認您的電子郵件地址。而後您就能在GitHub上建立公開倉庫(譯者注:GitHub公開倉庫是免費的,私有倉庫收費。)。

如今,只需爲倉庫建立一個名稱,不要勾選使用自述文件初始化它(initialize this repository with a README),也不要添加 Add .gitignore 或添加 Add a license 許可證。確保倉庫開始爲空:

20180714-GitHub-Create-Repository.png

建立倉庫後,您應該看到以下內容:

20180714-GitHub-Repository.png

如今讓咱們將其配置爲咱們的遠程倉庫:

git remote add origin git@github.com:sibtc/django-boards.git
複製代碼

如今將代碼推送到遠程服務器,即GitHub倉庫:

git push origin master

Counting objects: 84, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (81/81), done.
Writing objects: 100% (84/84), 319.70 KiB | 0 bytes/s, done.
Total 84 (delta 10), reused 0 (delta 0)
remote: Resolving deltas: 100% (10/10), done.
To git@github.com:sibtc/django-boards.git
 * [new branch]      master -> master
複製代碼

20180714-GitHub-Initial-Commit.png

我建立此倉庫只是爲了演示使用現有代碼庫建立遠程倉庫的過程。該項目的源代碼正式託管在此倉庫中:github.com/sibtc/djang…

項目配置(Project Settings)

不管代碼是存儲在公共或私有遠程倉庫中,都不該提交敏感信息並將其推送到遠程倉庫。這包括密鑰,密碼,API密鑰等。

此時,咱們必須在 settings.py 模塊中處理兩種特定類型的配置:

  • 密鑰和密碼等敏感信息;
  • 針對特定的環境配置。

密碼和密鑰能夠存儲在環境變量中或使用本地文件(未提交到遠程倉庫):

# environment variables
import os
SECRET_KEY = os.environ['SECRET_KEY']

# or local files
with open('/etc/secret_key.txt') as f:
    SECRET_KEY = f.read().strip()
複製代碼

爲此, 我在我開發的每一個Django項目中都使用了一個名爲 Python Decouple 的優秀實用功能庫。它將搜索名爲 .env 的本地文件以設置這配置變量,並將內容配置到環境變量。它還提供了一個定義默認值的接口,在適當時將數據轉換爲intboollist

這不是強制性的,但我真的以爲它是一個很是有用的工具。它像Heroku這樣的服務同樣有魅力。

首先,讓咱們安裝它:

pip install python-decouple
複製代碼

myproject/settings.py

from decouple import config

SECRET_KEY = config('SECRET_KEY')
複製代碼

如今,咱們能夠將敏感信息放在一個名爲**.env的特殊文件中(注意前面的點),該文件位於manage.py**文件所在的目錄中:

myproject/
 |-- myproject/
 |    |-- accounts/
 |    |-- boards/
 |    |-- myproject/
 |    |-- static/
 |    |-- templates/
 |    |-- .env        <-- here!
 |    |-- .gitignore
 |    |-- db.sqlite3
 |    +-- manage.py
 +-- venv/
複製代碼

.env 文件內容:

SECRET_KEY=rqr_cjv4igscyu8&&(0ce(=sy=f2)p=f_wn&@0xsp7m$@!kp=d
複製代碼

該**.ENV文件中忽略的.gitignore文件,因此每次咱們要部署應用程序或在不一樣的機器上運行時,咱們將建立一個.ENV**文件,並添加必要的配置。

如今讓咱們安裝另外一個庫來幫助咱們用簡單一行代碼來編寫數據庫鏈接。這樣,在不一樣的環境中編寫不一樣的數據庫鏈接字符串會更容易:

pip install dj-database-url
複製代碼

目前,咱們須要解耦的所有配置:

myproject/settings.py

from decouple import config, Csv
import dj_database_url

SECRET_KEY = config('SECRET_KEY')
DEBUG = config('DEBUG', default=False, cast=bool)
ALLOWED_HOSTS = config('ALLOWED_HOSTS', cast=Csv())
DATABASES = {
    'default': dj_database_url.config(
        default=config('DATABASE_URL')
    )
}
複製代碼

本地計算機的**.env**文件示例:

SECRET_KEY=rqr_cjv4igscyu8&&(0ce(=sy=f2)p=f_wn&@0xsp7m$@!kp=d
DEBUG=True
ALLOWED_HOSTS=.localhost,127.0.0.1
複製代碼

請注意,在DEBUG配置中咱們給了一個默認值(True),所以在生產環境中咱們能夠忽略(註釋)此配置,所以它將被自動設置爲False,由於它生產環境應該是False的。

如今ALLOWED_HOSTS將被轉換成一個列表**['.localhost', '127.0.0.1'. ]。如今,這是在咱們的本地機器上,爲了生產,咱們將其設置爲相似於['.djangoboards.com', ]**您擁有的任何域名。

這特定配置可確保您的應用程序僅提供給這個域名。

記錄依賴庫版本(Tracking Requirements)

跟蹤項目的依賴關係是一個很好的作法,所以另外一臺機器上更容易安裝它(依賴的環境)。

咱們能夠經過運行下面的命令來檢查當前安裝的Python依賴庫:

pip freeze

dj-database-url==0.4.2
Django==1.11.6
django-widget-tweaks==1.4.1
Markdown==2.6.9
python-decouple==3.1
pytz==2017.2
複製代碼

在項目根目錄中建立名爲requirements.txt的文件,並在其中添加依賴項(就是上面 pip freeze獲得的項目全部的依賴庫):

requirements.txt 文件內容:

dj-database-url==0.4.2
Django==1.11.6
django-widget-tweaks==1.4.1
Markdown==2.6.9
python-decouple==3.1
複製代碼

我保留了pytz == 2017.2,由於它是由Django自動安裝的。

您能夠更新源代碼倉庫:

git add .
git commit -m "Add requirements.txt file"
git push origin master
複製代碼

域名(Domain Name)

若是咱們要正確部署Django應用程序,咱們將須要一個域名(譯者注:若是部署外網,給別人使用須要域名,但若是是內網使用,只有IP地址也能夠訪問。此處,做者意思要處理上線外網。)。擁有域名來爲應用程序提供服務,配置電子郵件服務和配置https證書很是重要。

最近,我一直在使用 Namecheap 。您能夠以8.88美圓/年的價格得到.com域名,或者若是您只是嘗試一下,您能夠用 0.99美圓/年 的價格註冊.xyz域名。(譯者注:在中國,能夠註冊阿里雲、騰訊雲等著名的註冊商都有域名賣買,你們可自行搜索官網。)

不管如何,您能夠自由使用任何註冊商。爲了演示部署過程,我註冊了 www.DjangoBoards.com 域名。

部署策略(20180714-GitHub-Initial-Commit.pn)

如下是咱們將在本教程中使用的部署策略的概述:

20180714-Django-Deployment-Strategy.jpg

雲服務是使用 Digital Ocean 提供的虛擬專用服務器。您可使用個人會員連接註冊Digital Ocean以得到 免費的10美圓信用額度(僅適用於新賬戶)。(譯者注:雲服務商在中國可選擇阿里雲、騰訊雲)

首先咱們將使用 NGINX(譯者注:Nginx是一個異步框架的 Web服務器,一般做爲負載均衡器。),其商標是食人魔。NGINX將收到訪問者對服務器的全部請求。但若是請求數據,它不會嘗試作任何不聰明的事情(譯者注:Nginx主要負責處理請求,並分發給文件系統或HTTP服務器等。)。它所要作的就是肯定所請求的信息是不是一個能夠自行提供的靜態資源,或者它是否更復雜。若是是,它會將請求傳遞給 Gunicorn(譯者注:Gunicorn「綠色獨角獸」是一個被普遍使用的高性能的Python WSGI UNIX HTTP服務器,移植自Ruby的獨角獸(Unicorn )項目,使用pre-fork worker模式,具備使用很是簡單,輕量級的資源消耗,以及高性能等特色。)。

NGINX 還將配置 HTTPS證書。這意味着它只接受經過HTTPS的請求。若是客戶端嘗試經過HTTP請求,NGINX將首先將用戶重定向到HTTPS,而後它纔會決定如何處理請求連接。

咱們還將安裝此 certbot 以自動續訂 Let’s Encrypt 的證書。(譯者注:想了解更多內容,可閱讀HTTPS 簡介及使用官方工具 Certbot 配置 Let’s Encrypt SSL 安全證書詳細教程 | Linux Story。)

Gunicorn是一個應用服務器。根據服務器擁有的CPU處理器數量,它能夠經過生成多個同時工做的程序以並行處理多個請求。它管理工做負載並執行Python和Django代碼。

Django是一個努力工做的表明。它能夠訪問數據庫(PostgreSQL)或文件系統。但在大多數狀況下,工做是在視圖內部完成,渲染模板,以及過去幾周咱們編寫過的全部內容。在Django處理請求以後,它會向Gunicorn返回一個響應,他將結果返回給NGINX,最終將響應傳遞給客戶端。

咱們還將安裝**PostgreSQL**,一個優秀的數據庫系統。因爲Django的ORM系統,很容易切換數據庫。(譯者注:PostgreSQL被業界譽爲「最早進的開源數據庫」,面向企業複雜SQL處理的OLTP在線事務處理場景,支持NoSQL數據類型(JSON/XML/hstore)、支持GIS地理信息處理。)

最後一步是安裝**Supervisor**。它是一個過程控制系統,它將密切關注Gunicorn和Django,以確保一切順利進行。若是服務器從新啓動,或者Gunicorn崩潰,它將自動重啓。(譯者注:Supervisor是一個Python開發的client/server系統,能夠管理和監控*nix上面的進程的工具。)

部署到VPS(Digital Ocean)(Deploying to a VPS (Digital Ocean))

您可使用您喜歡的任何其餘VPS(虛擬專用服務器)。配置應該很是類似,畢竟咱們將使用Ubuntu 16.04 做爲咱們的服務器。

首先,讓咱們建立一個新的服務器(在Digital Ocean上,他們稱之爲「Droplet」)。選擇Ubuntu 16.04:

20180714-Digital-Ocean-Create-Droplets.png

選擇尺寸。最小的空間就足夠了:

20180714-Digital-Ocean-Create-Droplets-Choose-Size.png

而後爲您的Droplet選擇一個主機名(在個人例子爲「django-boards」):

20180714-Digital-Ocean-Create-Droplets-Choose-Hostname.png

若是您有SSH密鑰,則能夠將其添加到您的賬戶。而後,您將可以使用它登陸服務器。不然,他們會經過電子郵件向您發送root密碼。(譯者注:SSH密鑰能夠不用輸入密碼就連接到服務器,具體可自行搜索瞭解更多。)

如今選擇服務器的IP地址:

20180714-Digital-Ocean-Choose-IPaddress.png

在咱們登陸服務器以前,讓咱們將域名指向此IP地址。這將節省一些時間,由於DNS設置一般須要幾分鐘才能傳播。

20180714-Digital-Ocean-Add-DNS-Record.png
因此這裏咱們添加了兩條A記錄,一條指向主域名「djangoboards.com」,另外一條指向「www.djangoboards.com」。咱們將使用NGINX配置規範URL。

如今讓咱們使用終端登陸服務器:

ssh root@45.55.144.54
root@45.55.144.54's password: 複製代碼

而後你應該看到如下消息:

You are required to change your password immediately (root enforced)
Welcome to Ubuntu 16.04.3 LTS (GNU/Linux 4.4.0-93-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/advantage

  Get cloud support with Ubuntu Advantage Cloud Guest:
    http://www.ubuntu.com/business/services/cloud

0 packages can be updated.
0 updates are security updates.


Last login: Sun Oct 15 18:39:21 2017 from 82.128.188.51
Changing password for root.
(current) UNIX password:
複製代碼

設置新密碼,而後開始配置服務器。

sudo apt-get update
sudo apt-get -y upgrade
複製代碼

若是在升級過程當中收到任何提示,請選擇"keep the local version currently installed"(保持當前安裝的本地版本)選項。

Python 3.6

sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt-get update
sudo apt-get install python3.6
複製代碼

PostgreSQL

sudo apt-get -y install postgresql postgresql-contrib
複製代碼

NGINX

sudo apt-get -y install nginx
複製代碼

Supervisor

sudo apt-get -y install supervisor

sudo systemctl enable supervisor
sudo systemctl start supervisor
複製代碼

Virtualenv

wget https://bootstrap.pypa.io/get-pip.py
sudo python3.6 get-pip.py
sudo pip3.6 install virtualenv
複製代碼

應用用戶(Application User)

使用如下命令建立新用戶:

adduser boards
複製代碼

一般,我只選擇應用程序的名稱。輸入密碼,並可選擇在提示中添加一些額外信息。

如今將用戶添加到sudoers列表:

gpasswd -a boards sudo
複製代碼

PostgreSQL數據庫配置(PostgreSQL Database Setup)

首先切換到postgres用戶:

sudo su - postgres
複製代碼

建立數據庫用戶:

createuser u_boards
複製代碼

建立一個新數據庫並將用戶設置爲全部者:

createdb django_boards --owner u_boards
複製代碼

爲用戶定義一個強密碼:

psql -c "ALTER USER u_boards WITH PASSWORD 'BcAZoYWsJbvE7RMgBPzxOCexPRVAq'" 複製代碼

咱們如今能夠退出postgres用戶了:

exit
複製代碼

Django項目配置(Django Project Setup)

切換到應用程序用戶:

sudo su - boards
複製代碼

開始前,咱們先檢查終端的位置:

pwd

/home/boards
複製代碼

首先,讓咱們用咱們的代碼克隆存儲庫:

git clone https://github.com/sibtc/django-beginners-guide.git
複製代碼

啓動虛擬環境(virtualenv):

virtualenv venv -p python3.6
複製代碼

初始化virtualenv:

source venv/bin/activate
複製代碼

安裝依賴的庫(譯者注:從文件中讀取依賴進行安裝。):

pip install -r django-beginners-guide/requirements.txt
複製代碼

咱們再添加兩個額外的庫,Gunicorn和PostgreSQL驅動程序:

pip install gunicorn
pip install psycopg2
複製代碼

如今在**/home/boards/django-beginners-guide文件夾中,讓咱們建立一個.env**文件來存儲數據庫憑據,密鑰和其餘全部內容:

/home/boards/django-beginners-guide/.env

SECRET_KEY=rqr_cjv4igscyu8&&(0ce(=sy=f2)p=f_wn&@0xsp7m$@!kp=d
ALLOWED_HOSTS=.djangoboards.com
DATABASE_URL=postgres://u_boards:BcAZoYWsJbvE7RMgBPzxOCexPRVAq@localhost:5432/django_boards
複製代碼

如下是數據庫URL的語法:postgres://db_user:db_password@db_host:db_port/db_name

如今讓咱們遷移數據庫,收集靜態文件並建立一個超級用戶:

cd django-beginners-guide
複製代碼
python manage.py migrate

Operations to perform:
  Apply all migrations: admin, auth, boards, contenttypes, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying boards.0001_initial... OK
  Applying boards.0002_auto_20170917_1618... OK
  Applying boards.0003_topic_views... OK
  Applying sessions.0001_initial... OK

複製代碼

如今靜態文件:

python manage.py collectstatic

Copying '/home/boards/django-beginners-guide/static/js/jquery-3.2.1.min.js'
Copying '/home/boards/django-beginners-guide/static/js/popper.min.js'
Copying '/home/boards/django-beginners-guide/static/js/bootstrap.min.js'
Copying '/home/boards/django-beginners-guide/static/js/simplemde.min.js'
Copying '/home/boards/django-beginners-guide/static/css/app.css'
Copying '/home/boards/django-beginners-guide/static/css/bootstrap.min.css'
Copying '/home/boards/django-beginners-guide/static/css/accounts.css'
Copying '/home/boards/django-beginners-guide/static/css/simplemde.min.css'
Copying '/home/boards/django-beginners-guide/static/img/avatar.svg'
Copying '/home/boards/django-beginners-guide/static/img/shattered.png'
...
複製代碼

此命令將全部靜態資產複製到外部目錄,NGINX能夠在該目錄中爲咱們提供文件。稍後會詳細介紹。

如今爲應用程序建立一個超級用戶:

python manage.py createsuperuser
複製代碼

配置Gunicorn(Configuring Gunicorn)

Gunicorn是負責在代理服務器後面執行Django代碼的工具。

在**/home/boards中建立一個名爲gunicorn_start**的新文件:

#!/bin/bash 
NAME="django_boards"
DIR=/home/boards/django-beginners-guide
USER=boards
GROUP=boards
WORKERS=3
BIND=unix:/home/boards/run/gunicorn.sock
DJANGO_SETTINGS_MODULE=myproject.settings
DJANGO_WSGI_MODULE=myproject.wsgi
LOG_LEVEL=error

cd $DIR
source ../venv/bin/activate

export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DIR:$PYTHONPATH

exec ../venv/bin/gunicorn ${DJANGO_WSGI_MODULE}:application \
  --name $NAME \
  --workers $WORKERS \
  --user=$USER \
  --group=$GROUP \
  --bind=$BIND \
  --log-level=$LOG_LEVEL \
  --log-file=-
  
複製代碼

此腳本將啓動應用程序服務器。咱們提供了一些信息,例如Django項目的位置,用於運行服務器的應用程序用戶等等。

如今讓這個文件可執行:

chmod u+x gunicorn_start
複製代碼

建立兩個空文件夾,一個用於套接字文件,另外一個用於存儲日誌:

mkdir run logs
複製代碼

如今**/home/boards**裏面的目錄結構應該是這樣的:

django-beginners-guide/
gunicorn_start
logs/
run/
staticfiles/
venv/
複製代碼

其中staticfiles文件夾由建立collectstatic命令。

配置Supervisor(Configuring Supervisor)

首先,在 /home/boards/logs/ 文件夾中建立一個空的日誌文件:

touch logs/gunicorn.log
複製代碼

如今建立一個新的supervisor文件:

sudo vim /etc/supervisor/conf.d/boards.conf
複製代碼
[program:boards]
command=/home/boards/gunicorn_start
user=boards
autostart=true
autorestart=true
redirect_stderr=true
stdout_logfile=/home/boards/logs/gunicorn.log
複製代碼

保存文件並運行如下命令:

sudo supervisorctl reread
sudo supervisorctl update
複製代碼

如今檢查狀態:

sudo supervisorctl status boards
複製代碼
boards        RUNNING   pid 308, uptime 0:00:07
複製代碼

配置NGINX(Configuring NGINX)

下一步是設置NGINX服務器以提供靜態文件並將請求傳遞給Gunicorn:

/etc/nginx/sites-available/ 中添加一個名爲boards的新配置文件:

upstream app_server {
    server unix:/home/boards/run/gunicorn.sock fail_timeout=0;
}

server {
    listen 80;
    server_name www.djangoboards.com;  # here can also be the IP address of the server

    keepalive_timeout 5;
    client_max_body_size 4G;

    access_log /home/boards/logs/nginx-access.log;
    error_log /home/boards/logs/nginx-error.log;

    location /static/ {
        alias /home/boards/staticfiles/;
    }

    # checks for static file, if not found proxy to app
    location / {
        try_files $uri @proxy_to_app;
    }

    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://app_server;
    }
}
複製代碼

建立指向已啓用站點的文件夾的引用連接:

sudo ln -s /etc/nginx/sites-available/boards /etc/nginx/sites-enabled/boards
複製代碼

刪除默認的NGINX網站:

sudo rm /etc/nginx/sites-enabled/default
複製代碼

重啓NGINX服務:

sudo service nginx restart
複製代碼

此時,若是DNS已經生效,則可能經過URL www.djangoboards.com 訪問該網站。

20180714-django-boards.png

配置電子郵件服務(Configuring an Email Service)

入門使用的最佳選擇之一是 Mailgun。它提供了一個很是可靠的免費計劃,每個月包含12,000封電子郵件。

註冊一個免費賬戶。而後按照步驟操做,這很是簡單。您必須與您註冊域名的服務一塊兒使用。在個人例子中,它是 Namecheap

點擊添加域以向您的賬戶添加新域。按照說明操做,確保使用 「mg.」 子域名:

20180714-mailgun-add-domain.png

如今抓取第一組DNS記錄,它是兩個TXT記錄:

20180714-mailgun-add-NDS-Records.png

使用您的註冊商提供的網絡界面將其添加到您的域中:

20180714-DNS-List-Add-mail-record.png

重複上述步驟,對MX記錄作一樣的事情:

20180714-DNS-list-MX-record.png

將它們添加到域中:

20180714-DNS-list-add-MX-Record.png

如今這一步不是強制性的,但因爲咱們已經在這裏,因此也配置一下:

20180714-Add-DNS-Records-For-Tracking.png

20180714-DNS-add-CNAME-Record.png

添加全部DNS記錄後,單擊「當即檢查DNS記錄」按鈕:

20180714-Domain-Verfication-Check-DNS-Recodrds.png

如今咱們須要有一些耐心。有時須要一段時間來驗證DNS。

同時,咱們能夠配置應用程序以接收鏈接參數。

myproject/settings.py

EMAIL_BACKEND = config('EMAIL_BACKEND', default='django.core.mail.backends.smtp.EmailBackend')
EMAIL_HOST = config('EMAIL_HOST', default='')
EMAIL_PORT = config('EMAIL_PORT', default=587, cast=int)
EMAIL_HOST_USER = config('EMAIL_HOST_USER', default='')
EMAIL_HOST_PASSWORD = config('EMAIL_HOST_PASSWORD', default='')
EMAIL_USE_TLS = config('EMAIL_USE_TLS', default=True, cast=bool)

DEFAULT_FROM_EMAIL = 'Django Boards <noreply@djangoboards.com>'
EMAIL_SUBJECT_PREFIX = '[Django Boards] '
複製代碼

而後,個人本地計算機**.env**文件將以下所示:

SECRET_KEY=rqr_cjv4igscyu8&&(0ce(=sy=f2)p=f_wn&@0xsp7m$@!kp=d
DEBUG=True
ALLOWED_HOSTS=.localhost,127.0.0.1
DATABASE_URL=sqlite:///db.sqlite3
EMAIL_BACKEND=django.core.mail.backends.console.EmailBackend
複製代碼

個人線上(雲服務器).env文件看起來像這樣:

SECRET_KEY=rqr_cjv4igscyu8&&(0ce(=sy=f2)p=f_wn&@0xsp7m$@!kp=d
ALLOWED_HOSTS=.djangoboards.com
DATABASE_URL=postgres://u_boards:BcAZoYWsJbvE7RMgBPzxOCexPRVAq@localhost:5432/django_boards
EMAIL_HOST=smtp.mailgun.org
EMAIL_HOST_USER=postmaster@mg.djangoboards.com
EMAIL_HOST_PASSWORD=ED2vmrnGTM1Rdwlhazyhxxcd0F
複製代碼

您能夠在Mailgun 的the Domain Information(域信息)部分中找到您的憑據。

  • EMAIL_HOST: SMTP Hostname(SMTP主機名)
  • EMAIL_HOST_USER: Default SMTP Login(默認SMTP登陸)
  • EMAIL_HOST_PASSWORD: Default Password(默認密碼)

咱們能夠在線上服務器中測試新設置。在本地計算機上的settings.py文件中進行更改,將更改提交到遠程倉庫。而後,在服務器中拉出新代碼並從新啓動Gunicorn進程:

git pull
複製代碼

使用電子郵件憑據編輯**.env**文件。

而後重啓Gunicorn進程:

sudo supervisorctl restart boards
複製代碼

如今咱們能夠嘗試測試重置密碼的郵件流程:

20180714-Email-Please-reset-your-password.png

在Mailgun儀表板上,您能夠得到有關電子郵件傳遞的一些統計信息:

20180714-Email-Mailgun-Message-Delivery.png

配置HTTPS證書(Configuring HTTPS Certificate)

如今讓咱們使用 Let's Encrypt 提供的一個很好的HTTPS證書來提升咱們的應用程序的安全性。

設置HTTPS從未如此簡單。更好的是,咱們如今能夠免費得到它。他們提供了一個名爲certbot的解決方案 ,負責爲咱們安裝和更新證書。這很是簡單:

sudo apt-get update
sudo apt-get install software-properties-common
sudo add-apt-repository ppa:certbot/certbot
sudo apt-get update
sudo apt-get install python-certbot-nginx
複製代碼

如今安裝證書:

sudo certbot --nginx
複製代碼

只需按照提示操做便可。當被問及:

Please choose whether or not to redirect HTTP traffic to HTTPS, removing HTTP access.

複製代碼

選擇2將全部HTTP流量重定向到HTTPS。

有了這個,該網站已經經過HTTPS提供服務:

20180714-Let's-Encrypt-certbot-Https.png

設置證書的自動續訂。運行如下命令編輯crontab文件:

sudo crontab -e
複製代碼

將如下行添加到文件末尾:

0 4 * * * /usr/bin/certbot renew --quiet
複製代碼

該命令將天天凌晨4點運行。全部在30天內到期的證書將自動續訂。

總結(Conclusions)

很是感謝全部關注本系列教程的人,給予評論和反饋!我真的很感激!這是該系列的最後一篇教程。我但願你喜歡它!

儘管這是教程系列的最後一部分,但我仍是計劃編寫一些後續教程來探索其餘有趣的主題,例如數據庫優化以及在咱們目前擁有的內容之上添加更多功能。

順便說一句,若是您有興趣爲項目作出貢獻,不多有人願意免費提交pull請求!該項目的源代碼可在GitHub上得到:github.com/sibtc/djang…

另外,請告訴我您還想看到的其餘內容!:-)

譯者總結

翻譯本文以前,歷來沒有翻譯過技術文章。如今用一天時間翻譯完,真的以爲翻譯的工做很辛苦,之前看了不少翻譯的文章,在這裏感謝那些無私奉獻的譯者們!

在翻譯過程當中,有不少技術點,須要自已查一下資料,帶出一些擴展;有一些技術知識,原做者一筆帶過,又懼怕讀者看不懂,而後又想展開述;遇到一些本身不懂的技術,也是要硬頭表去翻譯;也有一些翻譯的句子,反覆屢次斟酌文字,但願可以通俗易懂的描述出來。

最後,翻譯只是第一步,理解了原做者的文章,並更好的學習到知識,簡單明瞭的譯文,是翻譯的初心。固然,在這過程,也發現英文的重要性,但願你們也重視英文,爲本身的技術視野更廣,不斷努力!正如文中做者說的,也許是你第一次遇到的知識,只有堅持,反覆多看幾回,慢慢的,你必定會懂的!恆心!

參考擴展

教程材料一共會被分爲七個部分。 此教程將從安裝、開發環境的準備,模型,視圖,模板,URL到更高級的主題(如遷移,測試和部署)中詳細探討全部基本概念。

Vitor Freitas 原文系列:

公衆號Python之禪 翻譯:

蒼雲橫渡 翻譯的Windows版本:

擴展閱讀:


  • 若有疑問,歡迎在評論區一塊兒討論!
  • 若有不正確的地方,歡迎指導!
> 注:本文首發於 [iHTCboy's blog](https://iHTCboy.com),如若轉載,請注來源
相關文章
相關標籤/搜索