gpt4 book ai didi

apache - 分享 Apache Prefork/WSGI 中的 Python 解释器

转载 作者:行者123 更新时间:2023-12-04 14:21:09 26 4
gpt4 key购买 nike

我正在尝试使用 WSGI 在 Apache(prefork)中运行 Python 应用程序,以便使用单个 Python 解释器。这是必要的,因为应用程序使用线程同步来防止发生竞争条件。由于 Apache prefork 产生了多个进程,代码最终不会在解释器之间共享,因此线程同步是无关紧要的(即每个线程只看到它自己的锁,与其他进程无关)。

这是设置:

  • Apache 2.0 (prefork)
  • WSGI
  • Python 2.5

  • 以下是相关的 Apache 配置:
    WSGIApplicationGroup %{GLOBAL}
    <VirtualHost _default_:80>

    WSGIScriptAlias / /var/convergedsecurity/apache/osvm.wsgi

    Alias /admin_media/ /var/www/html/admin_media/

    <Directory /var/www/html/admin_media>
    Order deny,allow
    Allow from all
    </Directory>

    Alias /media/ /var/www/html/media/

    <Directory /var/www/html/media>
    Order deny,allow
    Allow from all
    </Directory>

    </VirtualHost>

    这是我迄今为止尝试过的(都没有奏效):
  • 添加 WSGIApplicationGroup %{GLOBAL}
  • 指定 WSGIDaemonProcess WSGIProcessGroup 在虚拟主机内:

    WSGIDaemonProcess osvm 线程=50
    WSGIProcessGroup osvm

  • 有没有办法强制 Apache prefork 使用带有 WSGI 的单个 Python 解释器?这些文档似乎暗示您可以使用 WSGIDaemonProcess 和 WSGIApplicationGroup 选项,但 Apache 仍然为每个进程创建一个单独的 Python 解释器。

    最佳答案

    您不能让 WSGI 应用程序在 UNIX 系统上以嵌入式模式运行,无论是 prefork 还是 worker MPM,因为确实会有多个进程。看:

    http://code.google.com/p/modwsgi/wiki/ProcessesAndThreading

    创建一个由单个进程组成的守护进程组并将 WSGI 应用程序委托(delegate)给它应该可以实现您想要的。如果它只是您正在谈论的一个已安装的 WSGI 应用程序,您甚至不需要使用 WSGIApplicationGroup。如果你想绝对确定,你也可以设置它。

    因此 VirtualHost 中的配置将是:

    WSGIDaemonProcess osvm
    WSGIProcessGroup osvm
    WSGIApplicationGroup %{GLOBAL}

    WSGIScriptAlias / /var/convergedsecurity/apache/osvm.wsgi

    尽管 WSGIDaemonProcess 的 'processes=1' 明确表明创建了一个进程,但不要提供该选项,而是让它默认为一个进程。任何使用 'processes' 选项,即使对于一个进程将看到 'wsgi.multiprocess' 设置为 True。

    我建议您使用以下简单的测试程序进行测试,而不是使用您实际的 WSGI 应用程序。
    import cStringIO
    import os

    def application(environ, start_response):
    headers = []
    headers.append(('Content-Type', 'text/plain'))
    write = start_response('200 OK', headers)

    input = environ['wsgi.input']
    output = cStringIO.StringIO()

    print >> output, "PID: %s" % os.getpid()
    print >> output

    keys = environ.keys()
    keys.sort()
    for key in keys:
    print >> output, '%s: %s' % (key, repr(environ[key]))
    print >> output

    output.write(input.read(int(environ.get('CONTENT_LENGTH', '0'))))

    return [output.getvalue()]

    在其输出中,PID 值应始终相同。 wsgi.multiprocess 标志应该是 False。 mod_wsgi.process_group 值应该是您所说的守护进程组。 mod_wsgi.application_group 应该是一个空字符串。

    如果这不是您所看到的,请确保您在进行配置更改后实际重新启动了 Apache。还添加:
    LogLevel debug

    到 VirtualHost 的 Apache 配置。这样做会导致 mod_wsgi 在 Apache 错误日志中记录更多关于进程创建和脚本加载的消息,包括进程组和正在发生的应用程序组的详细信息。

    有关调试的其他信息,请参阅:

    http://code.google.com/p/modwsgi/wiki/DebuggingTechniques

    如果仍然有问题,建议您访问 Google Groups 上的 mod_wsgi 邮件列表。

    关于apache - 分享 Apache Prefork/WSGI 中的 Python 解释器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1339050/

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