Назад | Перейти на главную страницу

IIS 10 случайных 500 ошибок - возможно, из-за перезаписи URL

Это производственный веб-сервер 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}&amp;method={R:2}&amp;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}&amp;method={R:2}" />
            </rule>
        </rules>
    </rewrite>

Они приходят и уходят, казалось бы, наугад. Мы не нашли ничего, что могло бы гарантировать ответ 500. У нас есть идентичный промежуточный сервер, который не выдал 500 ошибок. Я только что включил отслеживание неудачных запросов на этом сайте, но до сих пор не зафиксировал ошибку 500.