bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

Django+Gunicorn+Nginx如何部署-創新互聯

這篇文章主要介紹Django+Gunicorn+Nginx如何部署,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

創新互聯公司專注于企業營銷型網站、網站重做改版、海勃灣網站定制設計、自適應品牌網站建設、H5場景定制購物商城網站建設、集團公司官網建設、成都外貿網站建設、高端網站制作、響應式網頁設計等建站業務,價格優惠性價比高,為海勃灣等各大城市提供網站開發制作服務。

部署

網上有很多都是用 UWSGI 的方式來部署,但是我個人比較喜歡 Gunicorn,所以以下內容我只是記錄了 Django + Gunicorn + Nginx 在 Ubuntu 上的部署方式相關內容。

步驟一

上傳網站源碼至目標服務器

由于我的源碼是用 Github 來托管的,所以我直接執行下述命令來克隆我的網站源碼到服務器即可。

git clone https://github.com/your-name/repo-name.git

# 進入項目目錄
cd repo-name

# 創建并激活虛擬環境
python3 -m virtualenv venv
source venv/bin/activate

# 安裝項目依賴
pip install -r requirements.txt

目前我的網站采用的相關依賴包如下:

autopep8
Django
django-bootstrap4
django-ckeditor
gunicorn
Markdown
Pillow
python-slugify
requests

這里有個坑需要注意,如果你使用了 awesome-slugify,請嘗試使用 python-slugify,因為有的服務器可能無法正常安裝 awesome-slugify,具體 BUG 可參考:Clashes with python-slugify package。

步驟二

修改項目相關配置,并進行靜態資源收集

由于我需要將我的網站部署到生產環境,所以我需要關閉 Django 的調試模式,并修改靜態資源相關配置,示例配置如下所示:

settings.py

SECRET_KEY = os.environ.get('DJANGO_SECRET_KEY')

DEBUG = os.environ.get('DJANGO_DEBUG', False)

TEMPLATE_DEBUG = os.environ.get('DJANGO_TEMPLATE_DEBUG', False)

ALLOWED_HOSTS = ["*"]

TEMPLATES = [
  {
    'BACKEND': 'django.template.backends.django.DjangoTemplates',
    'DIRS': [os.path.join(BASE_DIR, 'templates')],
    'APP_DIRS': True,
    'OPTIONS': {
      'context_processors': [
        'django.template.context_processors.debug',
        'django.template.context_processors.request',
        'django.contrib.auth.context_processors.auth',
        'django.contrib.messages.context_processors.messages',
      ],
    },
  },
]

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATICFILES_DIRS = [
  os.path.join(BASE_DIR, 'static'),
]

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

然后執行如下命令進行靜態資源收集:

python manage.py collectstatic

之后,我還需要創建一個 Gunicorn 進程的相關配置,示例配置如下所示:

gunicorn.conf.py

# 安裝
# sudo pip3 install gunicorn

import sys
import os
import logging
import logging.handlers
from logging.handlers import WatchedFileHandler
import multiprocessing

BASE_DIR = '/home/hippie/hippiezhou.fun/src'
sys.path.append(BASE_DIR)

LOG_DIR = os.path.join(BASE_DIR, 'log')
if not os.path.exists(LOG_DIR):
  os.makedirs(LOG_DIR)

# 綁定的ip與端口
bind = "0.0.0.0:8000"

# 以守護進程的形式后臺運行
daemon = True

# 大掛起的連接數,64-2048
backlog = 512

# 超時
timeout = 30

# 調試狀態
debug = False

# gunicorn要切換到的目的工作目錄
chdir = BASE_DIR

# 工作進程類型(默認的是 sync 模式,還包括 eventlet, gevent, or tornado, gthread, gaiohttp)
worker_class = 'sync'

# 工作進程數
workers = multiprocessing.cpu_count()

# 指定每個工作進程開啟的線程數
threads = multiprocessing.cpu_count() * 2

# 日志級別,這個日志級別指的是錯誤日志的級別(debug、info、warning、error、critical),而訪問日志的級別無法設置
loglevel = 'info'

# 日志格式
access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"'
# 其每個選項的含義如下:
'''
h     remote address
l     '-'
u     currently '-', may be user name in future releases
t     date of the request
r     status line (e.g. ``GET / HTTP/1.1``)
s     status
b     response length or '-'
f     referer
a     user agent
T     request time in seconds
D     request time in microseconds
L     request time in decimal seconds
p     process ID
'''

# 訪問日志文件
accesslog = os.path.join(LOG_DIR, 'gunicorn_access.log')
# 錯誤日志文件
errorlog = os.path.join(LOG_DIR, 'gunicorn_error.log')
# pid 文件
pidfile = os.path.join(LOG_DIR, 'gunicorn_error.pid')

# 訪問日志文件,"-" 表示標準輸出
accesslog = "-"
# 錯誤日志文件,"-" 表示標準輸出
errorlog = "-"

# 進程名
proc_name = 'hippiezhou_fun.pid'

# 更多配置請執行:gunicorn -h 進行查看

之后可用通過如下方式啟動我們的網站:

# 啟動方式(首先需要切換到項目根目錄,即和 manage.py 在同級目錄下):

gunicorn -c gunicorn.conf.py website.wsgi:application

# 或
gunicorn website.wsgi:application -b 0.0.0.0:8000 -w 4 -k gthread

# 或
gunicorn website.wsgi:application -b 0.0.0.0:8000 -w 4 -k gthread --thread 40 --max-requests 4096 --max-requests-jitter 512

# 查看進程
ps aux | grep gunicorn

步驟三

配置 Nginx

通過前兩步,我們可以成功將我們的網站跑起來,但是目前還只能在內部訪問,所以我們需要通過 Nginx 來做反向代理,供外網訪問。

執行下述命令進行安裝和配置

sudo apt-get install nginx

sudo service nginx start

# 備份默認配置
sudo cp /etc/nginx/sites-available/default /etc/nginx/sites-available/default.bak

# 啟動 Vim 修改我們的網站配置
sudo vim /etc/nginx/sites-available/default

示例配置如下所示:

server{
    ...
    server_name hippiezhou.fun *.hippiezhou.fun;
    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;
    ...

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        # try_files $uri $uri/ =404;
        proxy_pass     http://127.0.0.1:8000; #此處要和你 gunicore 的 ip 和端口保持一致
        proxy_redirect   off;

        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;
    }

    location /static {
        alias /root/hippiezhou.fun/src/staticfiles; # 此次需要配置為你的網站對應的靜態資源的絕對路徑
    }

    location /media {
        alias /root/hipiezhou.fun/src/media; # 如果你的網站有上傳功能,需要配置該結點并指向目標路徑
    }

    ...
}

配置完成后執行下述操作即可將我們的網站運行起來

# 若網站未啟動執行該命令
gunicorn -c gunicorn.conf.py website.wsgi:application

sudo nginx -t
sudo service nginx restart

如果不出意外,網站應該是可以正常訪問,如果靜態資源依然不能訪問,打開網站的 開發者工具看一下是什么錯誤。

  • 如果是 404 的問題,請確保你的 settings 相關配置和我上面列出來的是一致的;

  • 如果是 403 的問題,應該是 Nginx 無權訪問你指定的靜態資源,你需要修改 Nginx 的用戶類型,親執行下述命令

sudo vim /etc/nginx/nginx.conf

將 user 后面的值修改為 root,然后重啟 Nginx 即可。

最后,關于如何配置 HTTPS,這里就不過多介紹了,直接列出相關示例腳本:

sudo apt-get update
sudo apt-get install software-properties-common
sudo add-apt-repository universe
sudo add-apt-repository ppa:certbot/certbot
sudo apt-get update
sudo apt-get install certbot python-certbot-nginx

sudo certbot --nginx

# sudo certbot renew --dry-run

sudo ufw allow https

sudo systemctl restart nginx

以上是“Django+Gunicorn+Nginx如何部署”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯成都網站設計公司行業資訊頻道!

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

分享題目:Django+Gunicorn+Nginx如何部署-創新互聯
地址分享:http://vcdvsql.cn/article44/ccseee.html

成都網站建設公司_創新互聯,為您提供網站導航自適應網站域名注冊Google搜索引擎優化靜態網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都seo排名網站優化