Django学习记录11——利用uwsgi在ubuntu18.04server上部署

2024-05-27 21:18

本文主要是介绍Django学习记录11——利用uwsgi在ubuntu18.04server上部署,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.安装各种东西

首先在能够在本地通过python manage.py runserver实现Django服务器的启动的情况下,通过安装uwsgi服务器进行部署。如果安装了宝塔,记得ssh登录的时候先将权限切换至sudo su

  • 假设安装了Anaconda,那么安装uwsgi的过程应该如下:
conda install uwsgi
  • 如果是普通的Python的话,直接:
pip3 install uwsgi

二.配置uwsgi

在任意一个目录,推荐在Django的项目的根目录下,也就是有manage.py的目录下进行配置,创建uwsgi.ini(当然名字随便取):
Django项目名称为Kanna

[uwsgi]
chdir=/home/kanna/django_ws/Kanna
wsgi-file=Kanna/wsgi.py
py-autoreload=1
module=Kanna.wsgi.application
master=true
max-requests=5000
vacuum=true
pidfile=/home/kanna/django_ws/Kanna/log/pid/uwsgi.pid
logto=/home/kanna/django_ws/Kanna/log/log/web.log
http=0.0.0.0:80
uid=root
gid=root
enable-threads=true
harakiri=30
processes=4
threads=2
post-buffering=4096
virtualenv=/home/kanna/anaconda3/envs/django/

这里是解释一下各行参数的意思:

  • chdir=/home/kanna/django_ws/Kanna这个是项目目录,填绝对路径
  • wsgi-file=Kanna/wsgi.py 指定加载WSGI文件,填Django项目里的wsgi模块
  • py-autoreload=1修改了Django源码后,uwsgi会自动重启,避免手动重启
  • module=Kanna.wsgi.application 这个就填settings里的WSGI_APPLICATION字符串的内容
  • master指定启动主进程,到时候uwsgi多进程的父进程是这个启动的pid
  • max-requests 最大访问数量
  • vacuum 服务器退出时,自动删除socket文件和pid文件
  • pidfile=/home/kanna/django_ws/Kanna/log/pid/uwsgi.pid这个是当前进程的绝对路径,同时以后重启,停止也是基于操作该pid文件进行的。
  • daemonize=/home/kanna/django_ws/Kanna/log/log/web.log 以守护进程的方式启动,且日志文件的绝对路径。会造成systemd阻塞,所以不用。
  • logto=/home/kanna/django_ws/Kanna/log/log/web.log 记录日志文件
  • http=0.0.0.0:80 服务器的ip地址。若要用nginx反向代理,则不用该字段,用socket
  • uid=root gid=root 服务器的用户id和用户组id
  • enable-threads 启用线程
  • harakiri 自动中断时间
  • processes 多进程数目
  • threads 单进程线程数
  • post-buffering=4096 开启http请求体的缓存。uWSGI将所有大于限定大小的HTTP请求体保存到磁盘中
  • virtualenv=/home/kanna/anaconda3/envs/django/ 可填。若环境默认python不是该项目使用的python,则需要把其他环境的python的绝对路径填上。

更多的参数内容,可以看看这篇大佬的博客:

uWSGI参考资料(1.0版本的配置选项列表)

三.运行

在配置文件的目录下

uwsgi --ini uwsgi.ini

手动重启

uwsgi --reload xxx.pid

关闭

uwsgi --stop xxx.pid

四.开机自启

在ubuntu18.04的环境下,以下代码测试无误
使用systemd服务。更多的systemd介绍在该博客下有详细介绍:

Systemd及service文件解析

4.1 创建.service文件

sudo vim /etc/systemd/system/web_uwsgi.service

4.2 写入内容

uwsgi的绝对路径建议使用whereis uwsgi来查看

[Unit]
Description=HTTP Interface Server For Django[Service]
#自己修改一下路径
ExecStart=/usr/local/bin/uwsgi --ini /www/wwwroot/Kanna/uwsgi.ini
ExecReload=/usr/local/bin/uwsgi --reload /www/wwwroot/Kanna/log/pid/uwsgi.pid
ExecStop=/usr/local/bin/uwsgi --stop /www/wwwroot/Kanna/log/pid/uwsgi.pid[Install]
WantedBy=multi-user.target

4.3 运行服务

sudo systemctl enable /etc/systemd/system/web_uwsgi.service

4.4 管理服务

因为已经配置好,startreloadstop,所以用systemd命令也可以操作uwsgi
systemctl stop web_uwsgi.service 关闭uwsgi服务
systemctl start web_uwsgi.service 开启uwsgi服务
systemctl restart web_uwsgi.service 重启uwsgi服务

这篇关于Django学习记录11——利用uwsgi在ubuntu18.04server上部署的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1008616

相关文章

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序