我正在windows服务器2019上使用Django和IIS 10 web服务创建一个web应用程序。我在配置在wfastcgi中的web.config日志文件中有问题。日志的内容:
2021-12-10 16:26:35.568572: Unhandled exception in wfastcgi.py: Traceback (most recent call last):
File "c:\python37\lib\site-packages\wfastcgi.py", line 774, in main
record = read_fastcgi_record(fcgi_stream)
File "c:\python37\lib\site-packages\wfastcgi.py", line 158, in read_fastcgi_record
data = stream.read(8) # read record
OSError: [Errno 22] Invalid argument
2021-12-10 16:26:35.615397: Running on_exit tasks
2021-12-10 16:26:35.646693: wfastcgi.py 3.0.0 closed
2021-12-10 16:59:42.309400: wfastcgi.py will restart when files in C:\inetpub\wwwroot\ are changed: .*((\.py)|(\.config))$
2021-12-10 16:59:42.340650: wfastcgi.py 3.0.0 initialized每小时启动OSError: [Error 22]并运行退出任务,分钟后再次重新启动。我在web.config中添加了以下一行,但没有任何影响:
<add key="SCRIPT_NAME" value="/Music_backend" />整个web.config文本如下:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
</system.webServer>
<appSettings>
<add key="PYTHONPATH" value="C:\inetpub\wwwroot\Music_backend" />
<add key="WSGI_HANDLER" value="Music_backend.wsgi.application" />
<add key="DJANGO_SETTINGS_MODULE" value="Music_backend.settings" />
<add key="SCRIPT_NAME" value="/Music_backend" />
<add key="WSGI_LOG" value="c:\wfastcgi.log"/>
</appSettings>
<location path="" overrideMode="Deny">
<system.webServer>
</system.webServer>
</location>
<location path="" overrideMode="Allow">
<system.webServer>
<handlers>
<add name="Python FastCGI" path="*" verb="*" modules="FastCgiModule" scriptProcessor="c:\python37\python.exe|c:\python37\lib\site-packages\wfastcgi.py" resourceType="Unspecified" requireAccess="Script" />
</handlers>
</system.webServer>
</location>
</configuration>此外,我激活了Django.server、Django.request、Django.db.Backend、LOGGING选项,但在所有日志文件中没有任何证据。我知道这个问题可能存在于没有"r"前缀的包含路径的字符串中,但是没有任何日志文件可用于检测问题。非常感谢您的帮助!
发布于 2022-11-11 14:49:28
同样的情况发生在我将服务器升级到IIS 10 (从7.5升级到IIS 10)时。我认为这只是两个IIS版本之间行为的改变,IIS 10以不同于以前的方式向工作人员关闭管道,从而导致错误(而不是简单地返回空的EOF)。
为此,我将函数的第一行改为:
def read_fastcgi_record(stream):
"""reads the main fast cgi record"""
try:
data = stream.read(8) # read record
except OSError as ex:
if (ex.errno != 22): # "Invalid argument".
raise
data = None我没有看到修改过的代码有任何问题,并且日志中没有跟踪。
https://stackoverflow.com/questions/70305734
复制相似问题