Python的Django部署uwsgi后自签名实现的HTTPS

通过SSL/TLS来加密和客户端的通信内容。提高网络安全性,但是会损耗部分的服务器资源。

HTTPS 的原理图。

web.key 是打死也不能给其他人的。一定要保存好。里面主要是私钥。是各种认证的根基。本地测试的话生成1024的即可,如果是生产环境推荐使用2048。

web.csr 通过私钥 web.key生成。 包含 私钥和公钥。

通过x509格式的规范,通过证书生成,包含各类签名算法,加密算法(对称和非对称等),需要客户端支持对应的协议和各类算法。

具体命令:

复制代码
#安装uwsgi

sudo apt install uwsgi

#安装openssl

sudo apt install openssl

# 生成rsa秘钥,2048位
openssl genrsa -out web.key 1024

# 生成证书请求
openssl req -new -key web.key -out web.csr
# 

# 自行签署,输入证书请求,秘钥签名,输出证书,有效期:10年(自己设置)
openssl x509 -req -days 3650 -in web.csr -signkey web.key -out web.crt

定义xxx.ini文件。

复制代码
# 更正后的uwsgi.ini,主要是指定chdir 和 wsgi-file

[uwsgi]
#具体是你的地址
https = 0.0.0.0:8066,/root/web/ssl/foobar.crt,/root/web/ssl/foobar.key

chdir = /root/web/mydjango

wsgi-file = mydjango/wsgi.py

master = true

pidfile = /var/run/xxx.pid 
# 通过pid停止重启服务

daemonnize = true
# 守护进程,后台运行

执行命令:

复制代码
# 启动服务
uwsgi --ini xxx.ini

其他命令:

复制代码
# 重启服务
uwsgi --reload /var/run/xxx.pid

# 停止服务
uwsgi --stop /var/run/xxx.pid
相关推荐
遇见火星4 分钟前
在Linux中使用parted对大容量磁盘进行分区详细过程
linux·运维·网络·分区·parted
yuyousheng14 分钟前
CentOS7更换为阿里源
linux·c语言
微露清风1 小时前
系统性学习Linux-第一讲-Linux基础指令
java·linux·学习
zl_dfq1 小时前
Linux 之 【日志】(实现一个打印日志的类)
linux
EmbedLinX1 小时前
一文理解后端核心概念:同步/异步、阻塞/非阻塞、进程/线程/协程
linux·服务器·c语言·网络
zhangrelay1 小时前
linux下如何通过与AI对话设置thinkpad电池充电阈值
linux·运维·笔记·学习
小王努力学编程1 小时前
LangChain——AI应用开发框架(核心组件2)
linux·服务器·c++·人工智能·python·langchain·信号
云服务器租用费用2 小时前
京东云主机企业用户能参与的优惠活动汇总
服务器·网络·京东云
浅水壁虎2 小时前
任务调度——XXLJOB3(执行器)
java·服务器·前端·spring boot
hqwest2 小时前
WPF真入门教程36--真硬核【自动化生产管理平台】
运维·自动化·modbus通信·串口设备·自动化生产管理平台·wpf开发