gpt4 book ai didi

django - Apache mod_wsgi django启用多线程多进程

转载 作者:行者123 更新时间:2023-12-02 02:09:05 24 4
gpt4 key购买 nike

问题:

  1. 我如何知道我的 apache 服务器是否已经在多进程和多线程模式下运行?因为当我对其进行负载测试时,它在不同的线程数下给出了相同的结果时间。我用 25 个线程和 50 个线程运行测试。

  2. 对于多线程/多进程工作,我需要在 Django 代码中进行任何调整吗?

  3. 我必须更改 MPM 配置 (/conf/extra/httpd-mpm.conf) 吗?

下面是我的服务器详细信息和配置:

Server redhat enterprise 6.9
Apache server 2.4.33
Postgre 9.6.6
Python 3.6
Virtualbox RAM 8Gb, 2 Core (4 vCpu).

我的httpd.conf:

Listen 8000

LoadModule wsgi_module modules/mod_wsgi.so

Include conf/extra/httpd-vhosts.conf

WSGIScriptAlias / /home/applmgr/Harpa/HarpaBackend/harpa/wsgi.py
WSGIPythonHome /home/applmgr/Harpa/pyenv_sl
WSGIPythonPath /home/applmgr/Harpa/HarpaBackend
WSGIPassAuthorization On

<Directory /home/applmgr/Harpa/HarpaBackend/harpa>
<Files wsgi.py>
Require all granted
</Files>
</Directory>

我的httpd-vhosts.conf:

<VirtualHost *:8000>

Alias /static /home/applmgr/Harpa/HarpaBackend/static
<Directory /home/applmgr/Harpa/HarpaBackend/static>
Require all granted
</Directory>

WSGIDaemonProcess harpa python-home=/home/applmgr/Harpa/pyenv_sl processes=15 threads=50 python-path=/home/applmgr/Harpa/HarpaBackend
WSGIProcessGroup harpa

<Directory /home/applmgr/Harpa/HarpaBackend/harpa>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
</VirtualHost>

ps -ef | grep httpd:

applmgr   2817     1  0 14:18 ?        00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2818 2817 0 14:18 ? 00:00:04 /opt/apache_http/bin/httpd -k start
applmgr 2819 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2820 2817 0 14:18 ? 00:00:03 /opt/apache_http/bin/httpd -k start
applmgr 2821 2817 0 14:18 ? 00:00:06 /opt/apache_http/bin/httpd -k start
applmgr 2822 2817 0 14:18 ? 00:00:03 /opt/apache_http/bin/httpd -k start
applmgr 2823 2817 26 14:18 ? 00:34:21 /opt/apache_http/bin/httpd -k start
applmgr 2824 2817 0 14:18 ? 00:00:06 /opt/apache_http/bin/httpd -k start
applmgr 2825 2817 47 14:18 ? 01:01:16 /opt/apache_http/bin/httpd -k start
applmgr 2826 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2827 2817 25 14:18 ? 00:33:00 /opt/apache_http/bin/httpd -k start
applmgr 2828 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2829 2817 0 14:18 ? 00:00:03 /opt/apache_http/bin/httpd -k start
applmgr 2830 2817 0 14:18 ? 00:00:03 /opt/apache_http/bin/httpd -k start
applmgr 2831 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2832 2817 0 14:18 ? 00:00:03 /opt/apache_http/bin/httpd -k start
applmgr 2833 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2834 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 2835 2817 0 14:18 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 3875 2817 0 14:23 ? 00:00:00 /opt/apache_http/bin/httpd -k start
applmgr 4979 2642 0 16:26 pts/1 00:00:00 grep httpd

./apachectl -V :

Server version: Apache/2.4.33 (Unix)
Server built: Apr 9 2018 16:42:03
Server's Module Magic Number: 20120211:76
Server loaded: APR 1.6.3, APR-UTIL 1.6.1
Compiled using: APR 1.6.3, APR-UTIL 1.6.1
Architecture: 64-bit
Server MPM: event
threaded: yes (fixed thread count)
forked: yes (variable process count)
Server compiled with....
-D APR_HAS_SENDFILE
-D APR_HAS_MMAP
-D APR_HAVE_IPV6 (IPv4-mapped addresses enabled)
-D APR_USE_SYSVSEM_SERIALIZE
-D APR_USE_PTHREAD_SERIALIZE
-D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
-D APR_HAS_OTHER_CHILD
-D AP_HAVE_RELIABLE_PIPED_LOGS
-D DYNAMIC_MODULE_LIMIT=256
-D HTTPD_ROOT="/opt/apache_http"
-D SUEXEC_BIN="/opt/apache_http/bin/suexec"
-D DEFAULT_PIDLOG="logs/httpd.pid"
-D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
-D DEFAULT_ERRORLOG="logs/error_log"
-D AP_TYPES_CONFIG_FILE="conf/mime.types"
-D SERVER_CONFIG_FILE="conf/httpd.conf"

最佳答案

由于 Python GIL 的原因,在 Python 中设置大量线程通常不是一个好主意。在系统过度过载的情况下进行基准测试会更糟糕,因为它只会加剧情况并给出不可靠的结果。我建议不要运行使用超过 40-60% 容量的线程的 Python Web 服务器,因为一旦你提高吞吐量,特别是如果 CPU 限制更多,那么事情就会迅速走下坡路。发送最大请求的基准测试执行得非常快,因此毫无意义。

我建议观看以下两个讨论某些问题的 session 演讲视频。

作为一般经验法则,请执行以下操作:

  • 使用守护进程模式。
  • 使用 WSGIRestrictEmbedded On 禁用嵌入模式。
  • 每个进程最多使用 5 个线程,除非 I/O 限制过多。
  • 使用进程而不是线程,但也不要沉迷于进程。
  • 跨多台机器进行扩展。
  • 检测 WSGI 服务器和应用程序,了解它在真实系统中的执行情况。

要添加指标来监控 mod_wsgi,请参阅:

如果想讨论指标,请使用 mod_wsgi 邮件列表获取最新信息。

<小时/>

更新1

另请注意:

最后,它讨论了您应该查看和设置的各种设置守护程序模式。另请参阅结尾:

了解守护进程设置的一些推荐默认值。

关于django - Apache mod_wsgi django启用多线程多进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49852894/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com