Django+uwsgi的配置

1. uwsgi加载配置文件
  • 可以使用 ini 文件,json 文件,xml 文件, YAML 文件,
    uwsgi --ini xxx.ini
2.常见的配置规则
[uwsgi]
;#使用nginx连接时使用,Django程序所在服务器地址
;socket=192.168.137.130:8001
;#直接做web服务器使用,Django程序所在服务器地址
http=192.168.137.130:9000
;#项目目录  (后端项目目录)切换文件夹到这个目录
;chdir=/home/python/Desktop/my_pro/
;项目中wsgi.py文件的目录,相对于项目目录
wsgi-file=my_pro/wsgi.py
# 进程数
;processes=4
# 线程数
;threads=2

;# 存放进程编号的文件,会在根目录生成uwsgi.pid
pidfile=uwsgi.pid
# uwsgi进程的状态文件存放,重启的时候可以使用这个配置
stats = uwsgi.status
;# 日志文件,因为uwsgi可以脱离终端在后台运行,日志看不见。我们以前的runserver是依赖终端的
daemonize=uwsgi.log
;# 指定依赖的虚拟环境
;virtualenv=/home/python/.virtualenvs/py3_django

;启动主进程,来管理其他进程,其它的uwsgi进程都是这个master进程的子进程,如果kill这个master进程,相当于重启所有的uwsgi进程。
master=true

;在每个worker而不是master中加载应用
;lazy-apps=true 
#设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。
;buffer-size = 32768 
listen = 120 #设置socket的监听队列大小(默认:100)
;#设置socket的监听队列大小(默认:100)
;listen = 120

module          =   my_pro.wsgi:application
env             =   DJANGO_SETTINGS_MODULE=my_pro.settings
;超时设置,如果一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用
harakiri        =   60
;指定工作者的数量 50个工作者
workers         =   50
; 允许内嵌的语言使用线程
enable-threads  =   true
# uwsgi的配置 每个worker超过这个次数会重启
max-requests = 10000
3.对项目进行操作
  • 启动项目
    uwsgi --ini xxxx.ini
  • 停止项目
    uwsgi --stop uwsgi.pid
  • 重启
    uwsgi --connect-and-read uwsgi.status

上面配置自行结合,并不是我实际项目中使用的配置

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Linux系统上部署Django + nginx + uWSGI的步骤如下: 1. 安装必要的软件 在Linux系统上安装必要的软件包,包括Python、pip、nginx、uWSGI等。 2. 创建Django项目 使用Django创建一个新项目或使用现有的Django项目。 3. 配置uWSGIDjango项目的根目录下创建一个uwsgi.ini文件,用于配置uWSGI。示例配置如下: ``` [uwsgi] # 指定运行模式为WSGI http = :8000 # 指定Django应用的wsgi模块 wsgi-file = myproject.wsgi # 指定进程数 processes = 4 # 指定线程数 threads = 2 # 指定静态文件路径 static-map = /static=/path/to/static # 指定日志路径 logto = /path/to/logfile ``` 其中,http参数指定了监听的端口号,wsgi-file参数指定了Django应用的wsgi模块,processes参数指定了进程数,threads参数指定了线程数,static-map参数指定了静态文件的路径,logto参数指定了日志文件的路径。 4. 配置nginx 在nginx的配置文件中添加以下内容: ``` server { listen 80; server_name example.com; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; location / { uwsgi_pass 127.0.0.1:8000; include uwsgi_params; } location /static { alias /path/to/static; } } ``` 其中,server_name指定了域名,access_log和error_log指定了日志文件的路径,uwsgi_pass指定了uWSGI的地址和端口号,include指定了uWSGI的参数。 5. 启动uWSGI服务 使用以下命令启动uWSGI服务: ``` uwsgi --ini uwsgi.ini ``` 6. 启动nginx服务 使用以下命令启动nginx服务: ``` sudo service nginx start ``` 这样就完成了Django + nginx + uWSGI的部署。可以通过访问该网站的域名来验证是否部署成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值