Это производственный веб-сервер IIS, который уже месяц работает нормально. На сервере 6 сайтов, и на прошлой неделе один из них начал выдавать 500 случайных ошибок. Это был один из двух сайтов, использующих перезапись URL. Мы провели около 2,5 часов с хорошо осведомленным консультантом, который не мог дать однозначного ответа. Правило перезаписи было:
<httpErrors existingResponse="PassThrough" />
<rewrite>
<rules>
<rule name="Redirect .cfm extension" stopProcessing="false">
<match url="^(.*).cfm$" ignoreCase="true" />
<conditions logicalGrouping="MatchAny">
<add input="{URL}" pattern="(.*).cfm$" ignoreCase="false" />
</conditions>
<action type="Redirect" url="{R:1}" redirectType="Permanent" />
</rule>
<rule name="hide .cfm extension" stopProcessing="true">
<match url="^(.*)$" ignoreCase="true" />
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
<add input="{REQUEST_FILENAME}.cfm" matchType="IsFile" />
</conditions>
<action type="Rewrite" url="{R:0}.cfm" />
</rule>
</rules>
Неудачный след показал
Мы удалили это правило, с тех пор без проблем.
Теперь другой сайт, использующий URL Rewrite, выдает случайные ошибки, но этот немного сложнее исправить, поскольку он или API.
<httpErrors existingResponse="PassThrough" />
<rewrite>
<rules>
<rule name="ApiWithControllerAndId" stopProcessing="true">
<match url="^([^/]+)/([^/]+)/([^/]+)/?$" />
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
</conditions>
<action type="Rewrite" url="index.cfm?controller={R:1}&method={R:2}&id={R:3}" />
</rule>
<rule name="ApiWithController" stopProcessing="true">
<match url="^([^/]+)/([^/]+)/?$" />
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
</conditions>
<action type="Rewrite" url="index.cfm?controller={R:1}&method={R:2}" />
</rule>
</rules>
</rewrite>
Они приходят и уходят, казалось бы, наугад. Мы не нашли ничего, что могло бы гарантировать ответ 500. У нас есть идентичный промежуточный сервер, который не выдал 500 ошибок. Я только что включил отслеживание неудачных запросов на этом сайте, но до сих пор не зафиксировал ошибку 500.