2017-09-06 106 views
0

我需要设置:关闭WSGIRestrictSignal,因为一旦调用了正常关机,我必须在我的python代码中执行一些操作。基于Docker的环境配置中的Apache与mod_wsgi

从文档:

甲表现良好的Python WSGI应用程序不应该在一般注册它自己的使用signal.signal的任何信号处理程序()。原因是,托管WSGI应用程序的Web服务器将更有可能注册自己的信号处理程序。如果WSGI应用程序要覆盖这样的信号处理程序,它可能会干扰Web服务器的操作,从而阻止诸如服务器关闭和重新启动等操作。

你知道如何在Docker中更改配置文件吗?
我应该只覆盖现有的文件吗?

这是我Dockerfile:

FROM grahamdumpleton/mod-wsgi-docker:python-2.7 
ADD requirements.txt requirements.txt 
RUN ["pip", "install", "-r", "requirements.txt"] 

WORKDIR /app 
COPY src/main/scripts/app.wsgi /app/app.wsgi 

ENTRYPOINT [ "mod_wsgi-docker-start" ] 

CMD [ "app.wsgi", "--processes", "1", "--port", "5000" ] 

应我把这样的事情?

ADD "httpd.conf" /tmp/mod_wsgi-localhost:5000:0/httpd.conf 

至于我得到了mod_wsgi的-泊坞窗开始默认”被选择执行的一切‘’配置。

由于该WSGIRestrictSignal设置为这样的事实,‘默认’是不可能的如果提出捕获信号:

Server URL   : http://localhost:5000/ 
Server Root  : /tmp/mod_wsgi-localhost:5000:0 
Server Conf  : /tmp/mod_wsgi-localhost:5000:0/httpd.conf 
Error Log File  : /dev/stderr (warn) 
Startup Log File : /dev/stderr 
Request Capacity : 5 (1 process * 5 threads) 
Request Timeout : 60 (seconds) 
Startup Timeout : 15 (seconds) 
Queue Backlog  : 100 (connections) 
Queue Timeout  : 45 (seconds) 
Server Capacity : 20 (event/worker), 20 (prefork) 
Server Backlog  : 500 (connections) 
Locale Setting  : en_US.UTF-8 
[Wed Sep 06 09:37:32.673894 2017] [mpm_event:notice] [pid 14:tid 140686654945024] AH00489: Apache/2.4.25 (Unix) mod_wsgi/4.5.7 Python/2.7 configured -- resuming normal operations 
[Wed Sep 06 09:37:32.674133 2017] [core:notice] [pid 14:tid 140686654945024] AH00094: Command line: 'httpd (mod_wsgi-express) -f /tmp/mod_wsgi-localhost:5000:0/httpd.conf -E /dev/stderr -D MOD_WSGI_MULTIPROCESS -D MOD_WSGI_MPM_ENABLE_EVENT_MODULE -D MOD_WSGI_MPM_EXISTS_EVENT_MODULE -D MOD_WSGI_MPM_EXISTS_WORKER_MODULE -D MOD_WSGI_MPM_EXISTS_PREFORK_MODULE -D FOREGROUND' 
^C[Wed Sep 06 09:37:33.106471 2017] [mpm_event:notice] [pid 14:tid 140686654945024] AH00491: caught SIGTERM, shutting down 
[Wed Sep 06 09:37:33.254507 2017] [wsgi:warn] [pid 16:tid 140686654945024] mod_wsgi (pid=16): Callback registration for signal 28 ignored. 
[Wed Sep 06 09:37:33.256509 2017] [wsgi:warn] [pid 16:tid 140686654945024] File "/tmp/mod_wsgi-localhost:5000:0/handler.wsgi", line 94, in <module> 
[Wed Sep 06 09:37:33.256546 2017] [wsgi:warn] [pid 16:tid 140686654945024]  recorder_directory=recorder_directory) 
[Wed Sep 06 09:37:33.256563 2017] [wsgi:warn] [pid 16:tid 140686654945024] File "/usr/local/python/lib/python2.7/site-packages/mod_wsgi/server/__init__.py", line 1355, in __init__ 
[Wed Sep 06 09:37:33.256642 2017] [wsgi:warn] [pid 16:tid 140686654945024]  exec(code, self.module.__dict__) 
[Wed Sep 06 09:37:33.256720 2017] [wsgi:warn] [pid 16:tid 140686654945024] File "/app/myapp.py", line 325, in <module> 
[Wed Sep 06 09:37:33.256770 2017] [wsgi:warn] [pid 16:tid 140686654945024]  signal.signal(signal.SIGWINCH, on_exit) 

即使我解决下面的官方文档拍摄信息的问题困扰着我:

请注意,如果启用了注册信号处理程序的能力,例如 ,则注册只能从 的代码中可靠地完成,该代码实施为导入由WSGIImportScript指令标识的脚本文件的副作用。这是因为信号处理程序 只能在主要Python解释器线程中注册,而 请求处理程序在使用嵌入模式时和多线程Apache通常会从辅助线程执行。同样,当 使用守护进程模式时,请求处理程序将从辅助 线程执行。只有作为WSGIImportScript的副作用运行的代码是 保证在主Python解释器线程中执行。

回答

0

请勿使用信号。使用Python中的atexit模块注册回调。当进程正在关闭时,该回调将被调用。