国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > Nginx > 正文

淺談Django+Gunicorn+Nginx部署之路

2024-08-30 12:23:57
字體:
來源:轉載
供稿:網友

前言

最近,我已經成功將我的個人網站從 Flask 遷移到 Django 了,最早接觸 Django 的時候大概是在 4 年前,我記得那個時候 Django 中的路由配置使用 正則 來進行的,但是我有特別煩這個東西,所以就果斷棄坑了。然后今年年初的時候,我用 Flask 寫了一個我的個人網站,剛開始的時候功能還是比較簡單,看著路由配置和部署規則都很方便,就果斷采用了。但是后來我想添加的功能越來越多的時候,我發現我已經越來越難掌控它了,正好最近我稍微看了一下 Django 這幾年的變化,最新的 2.2 版本還是很不錯的,路由規則和 Flask 已經一致了,所以我就重新入坑了。

目前我的個人網站基本功能已經遷移完畢。但是在部署的時候,我遇到了一些問題,在網上看了一些解決方法,要么太亂,要么太舊,個人覺得都已經不太適用了。所以在這里記錄一下我的部署過程。

部署

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

步驟一

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

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

git clone https://github.com/your-name/repo-name.git# 進入項目目錄cd repo-name# 創建并激活虛擬環境python3 -m virtualenv venvsource venv/bin/activate# 安裝項目依賴pip install -r requirements.txt

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

autopep8Djangodjango-bootstrap4django-ckeditorgunicornMarkdownPillowpython-slugifyrequests

這里有個坑需要注意,如果你使用了 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 gunicornimport sysimport osimport loggingimport logging.handlersfrom logging.handlers import WatchedFileHandlerimport multiprocessingBASE_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-2048backlog = 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 addressl     '-'u     currently '-', may be user name in future releasest     date of the requestr     status line (e.g. ``GET / HTTP/1.1``)s     statusb     response length or '-'f     referera     user agentT     request time in secondsD     request time in microsecondsL     request time in decimal secondsp     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 進行查看
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 齐齐哈尔市| 北宁市| 什邡市| 韩城市| 桦川县| 尼勒克县| 仁布县| 准格尔旗| 剑河县| 阿克| 阳城县| 遵化市| 北票市| 吴旗县| 关岭| 大连市| 阿图什市| 肃北| 仪征市| 陇南市| 东乡县| 荔波县| 西乌| 永和县| 恩施市| 泽库县| 尉犁县| 南宫市| 千阳县| 宁城县| 湘西| 普宁市| 荥阳市| 双桥区| 彭州市| 射阳县| 吉木萨尔县| 林芝县| 江油市| 铅山县| 石台县|