我的配置

  1. [uwsgi]
  2. # Django-related settings
  3. # the base directory (full path)
  4. chdir = /alidata/www/chhc
  5. # Django's wsgi file
  6. module = CHHC.wsgi
  7. # the virtualenv (full path)
  8. home = %(chdir)/venv
  9. # process-related settings
  10. # master
  11. master = true
  12. # maximum number of worker processes
  13. processes = 2
  14. # the socket (use the full path to be safe
  15. socket = 127.0.0.1:8083
  16. # ... with appropriate permissions - may be needed
  17. # chmod-socket = 664
  18. # clear environment on exit
  19. vacuum = true
  20. # 禁止记录请求日志
  21. disable-logging = true
  22. # 日志文件位置
  23. daemonize = %(chdir)/log/uwsgi.log
  24. # 日志文件最大20M
  25. log-maxsize = 20971520
  26. # uwsgi运行相关文件路径
  27. stats = %(chdir)/uwsgi.status
  28. pidfile = %(chdir)/uwsgi.pid

启动、重新加载、停止命令

  1. # 启动
  2. uwsgi --ini uwsgi.ini
  3. # 重新加载
  4. uwsgi --reload uwsgi.pid
  5. # 停止
  6. uwsgi --stop uwsgi.pid
  7. # 详细状态
  8. uwsgi --connect-and-read uwsgi.status

常用配置介绍

uwsgi官方文档

  1. #启动主进程,来管理其他进程,其它的uwsgi进程都是这个master进程的子进程,
  2. #如果kill这个master进程,相当于重启所有的uwsgi进程。
  3. master = true
  4. #在app加载前切换到当前目录, 指定运行目录
  5. chdir = /web/www/mysite
  6. # 加载一个WSGI模块,这里加载mysite/wsgi.py这个模块
  7. module = mysite.wsgi
  8. #监控python模块mtime来触发重载 (只在开发时使用)
  9. py-autoreload=1
  10. #在每个worker而不是master中加载应用
  11. lazy-apps=true
  12. #指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字
  13. socket = /test/myapp.sock
  14. #启动2个工作进程,生成指定数目的worker/进程
  15. processes = 2
  16. #设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。
  17. buffer-size = 32768
  18. # 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器
  19. daemonize = /var/log/myapp_uwsgi.log
  20. #设置最大日志文件大小
  21. log-maxsize = 5000000
  22. #禁用请求日志记录
  23. disable-logging = true
  24. vacuum = true #当服务器退出的时候自动删除unix socket文件和pid文件。
  25. listen = 120 #设置socket的监听队列大小(默认:100)
  26. pidfile = /var/run/uwsgi.pid #指定pid文件
  27. #允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程
  28. enable-threads = true
  29. #设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,
  30. #等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,
  31. #如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)
  32. reload-mercy = 8
  33. #为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,
  34. #那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏
  35. max-requests = 5000
  36. #通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。
  37. #这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,
  38. #并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。
  39. limit-as = 256
  40. #一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,
  41. #并且当前处理这个请求的工作进程会被回收再利用(即重启)
  42. harakiri = 60