• uwsgi 常用参数


    uwsgi 常用参数

    项目目录

    chdir=/var/www/orange_web/

    指定项目application

    module=orange_web.wsgi:application

    指定sock的文件路径(nginx使用)

    socket=/var/www/script/uwsgi.sock

    进程个数(processess一样效果)

    workers=2

    指定启动时的pid文件路径

    pidfile=/var/www/script/uwsgi.pid

    指定ip及端口(配置nginx就不需要单独启动uwsgi需要填写)

    http=172.16.0.4:8001

    指定静态文件(配置nginx不需要,单独启动uwsgi加载静态文件)

    static-map=/static=/var/www/orange_web/static

    启动uwsgi的用户名和用户组

    uid=root
    gid=root

    启用主进程

    master=true

    启用线程

    enable-threads=true

    自动移除unix Socket和pid文件当服务停止的时候

    vacuum=true

    设置日志目录

    daemonize=/var/www/script/uwsgi.log

    不记录信息日志,只记录错误以及uwsgi内部消息

    disable-logging=true

    序列化接受的内容,如果可能的话

    thunder-lock=true

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

    master = true

    在app加载前切换到当前目录, 指定运行目录

    chdir = /web/www/mysite

    加载一个WSGI模块,这里加载mysite/wsgi.py这个模块

    module = mysite.wsgi

    监控python模块mtime来触发重载 (只在开发时使用)

    py-autoreload=1

    在每个worker而不是master中加载应用

    lazy-apps=true

    指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字

    socket = /test/myapp.sock

    启动2个工作进程,生成指定数目的worker/进程

    processes = 2

    设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。

    buffer-size = 32768

    使进程在后台运行,并将日志打到指定的日志文件或者udp服务器

    daemonize = /var/log/myapp_uwsgi.log

    设置最大日志文件大小

    log-maxsize = 5000000

    禁用请求日志记录

    disable-logging = true

    当服务器退出的时候自动删除unix socket文件和pid文件。

    vacuum = true

    设置socket的监听队列大小(默认:100)

    listen = 120

    指定pid文件

    pidfile = /var/run/uwsgi.pid

    允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程

    enable-threads = true

    设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)

    reload-mercy = 8

    为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏

    max-requests = 5000

    通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。

    limit-as = 256

    一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启)

    harakiri = 60

    [uwsgi]

    #指定IP端口 // 直接外部访问
    #http-socket = 127.0.0.1:8080

    #项目目录
    chdir = /www/wwwroot/web/

    #指定项目的application
    module = web.wsgi:application

    #uwsgi启动用户名和用户组
    uid = www
    gid = www

    #启用主进程
    master = true

    #指定Socket路径 //内部访问 #权限和nginx一样
    socket = /www/wwwroot/web/script/uwsgi.sock
    #socket = :8080

    #socket权限设置
    chmod-socket = 755

    #进程个数
    processes = 5
    pidfile = /www/wwwroot/web/script/uwsgi.pid

    #自动移除unix Socket 和 Pid 文件 当服务停止的时候
    vacuum = true

    #序列化接受的内容,如果可能的话
    thunder-lock = true

    #启用线程
    enable-threads = true

    #设置自动中断时间
    harakiri = 30

    #设置缓冲
    post-buffering = 4096

    #设置静态文件
    #static-map = /static=//www/wwwroot/mysite/static

    #设置日志目录
    #daemonize = /www/wwwroot/mysite/uwsgi.log

    uwsgi的安装也是可以直接采用yum安装,配置也是比较简单,
    不过要想成功启动Python程序,需要用yum安装一个插件
    uwsgi-plugin-python
    如果想安装所有插件,可以直接安装uwsgi-plugin-all软件包
    说明:
    虚拟环境的python路径可以直接设置为本地python环境路径,其他路径根据自己需要修改

    UWSGI 配置说明

    1. 备份原配置文件 mv /etc/uwsgi.ini /etc/uwsgi.ini.bak

    2. 修改uwsgi.conf.example文件
    2.1 uwsgi 配置文件选择修改部分
    processes = 4 #进程数量
    threads = 5 #线程数量

    2.2 uwsgi 配置文件必须修改部分
    pythonpath = /opt/qogir/libs/bin/ #python 路径
    virtualenv = /opt/qogir/libs/ #虚拟环境路径

    socket = 192.168.2.22:9090 #uwsgi程序运行的Ip和端口

    chdir = /var/www/cloudmonitor/qogir_api/ #指定代码运行目录(根据代码存放路径修改)

    wsgi-file = /var/www/cloudmonitor/qogir_api/App.py #载入wsgi-file

    master = true #允许主进程存在

    callable = app #变量app 与 App.py文件中的app = Flask(__name__)对应

    3. 移动配置文件到 /etc/ 下
    cp uwsgi.ini.example /etc/uwsgi.ini

    4. 运行 uwsgi 查看运行状态
    启动uwsgi systemctl start uwsgi
    查看uwsgi运行状态 systemctl status uwsgi

    看到进程PID 以及 WSGI app ready 即为启动成功
    Process: 5371 ExecStartPre=/bin/chown uwsgi:uwsgi /run/uwsgi (code=exited, status=0/SUCCESS)
    Process: 5370 ExecStartPre=/bin/mkdir -p /run/uwsgi (code=exited, status=0/SUCCESS)
    Main PID: 5372 (uwsgi)
    Status: "uWSGI is ready"
    CGroup: /system.slice/docker-8b7ab6359ca7a84144e2fef73b926c75b8bd3010162e533b93908215d499ea19.scope/system.slice/uwsgi.service
    ├─5372 /usr/sbin/uwsgi --ini /etc/uwsgi.ini
    ├─5373 /usr/sbin/uwsgi --ini /etc/uwsgi.ini
    ├─5378 /usr/sbin/uwsgi --ini /etc/uwsgi.ini
    ├─5383 /usr/sbin/uwsgi --ini /etc/uwsgi.ini
    ├─5384 /usr/sbin/uwsgi --ini /etc/uwsgi.ini
    └─5385 /usr/sbin/uwsgi --ini /etc/uwsgi.ini

    from flask.ext.restful import reqparse
    WSGI app 0 (mountpoint='') ready in 1 seconds on interpreter 0x128e120 pid: 5372 (default app)
    *** uWSGI is running in multiple interpreter mode ***
    spawned uWSGI master process (pid: 5372)
    spawned uWSGI worker 1 (pid: 5378, cores: 5)
    spawned uWSGI worker 2 (pid: 5383, cores: 5)
    spawned uWSGI worker 3 (pid: 5384, cores: 5)
    spawned uWSGI worker 4 (pid: 5385, cores: 5)
    *** Stats server enabled on /run/uwsgi/stats.sock fd: 43 ***
    Started uWSGI Emperor Service.

    5.查看 uwsgi 运行日志
    uwsgi 配置日志命令 daemonize = /var/log/uwsgi/uwsgi.log
    daemonize 日志命令与 systemctl 启动模式有冲突,配置日志后启动会报错,所以只能查看systemctl日志
    systemctl 日志查看命令 journalctl

    附:uwsgi.conf.example

    [uwsgi]
    uid = uwsgi
    gid = uwsgi
    plugins = python
    pythonpath = /opt/qogir/libs/bin/
    virtualenv = /opt/qogir/libs/
    chmod-socket = 660

    socket = 192.168.2.22:9090

    processes = 4
    threads = 5

    chdir = /var/www/cloudmonitor/qogir/qogir_api/
    wsgi-file = /var/www/cloudmonitor/qogir/qogir_api/App.py

    master = true

    callable = app
  • 相关阅读:
    pydoc (Development Tools) – Python 中文开发手册
    CSS :out-of-range 选择器
    wcschr (Strings) – C 中文开发手册
    gl (SGI IRIX) – Python 中文开发手册
    排版 | Typography (CSS) – Bootstrap 3 中文开发手册
    HTML 音频,视频 DOM ended 属性
    ASP.NET Web Forms 教程
    Linux 系统目录结构
    ADO Connection 对象
    JavaWeb 之 HttpServletRequest 类
  • 原文地址:https://www.cnblogs.com/JIM-FAN/p/14680520.html
Copyright © 2020-2023  润新知