Сегодня сервер подвергся атаке CC, из-за чего сайт на IIS завис, и после перезагрузки он снова завис, проверьте журнал ошибок сайта следующим образом:
System.Data.Entity.Core.EntityCommandExecutionException: 执行命令定义时出错。有关详细信息,请参阅内部异常。 ---> System.Data.SqlClient.SqlException: 执行超时已过期。完成操作之前已超时或服务器未响应。 ---> System.ComponentModel.Win32Exception: 等待的操作过时。
Большое количество исключений с тайм-аутом запросов приводит к зависанию сайта, а все SQL-операторы тайм-аута запроса создаются методом получения случайных данных, код выглядит следующим образом:
Код примерно означает: 10 элементов данных выбираются случайным образом из базы данных, если они не дублируют текущий идентификатор.
То, что казалось простым требованием, заставило сервер положить трубку! Оператор SQL, сгенерированный вышеуказанным кодом, выглядит следующим образом:
План реализации следующий:
Если в базе данных 1 миллион единиц данных, разве она не возьмёт сначала 999 999 единиц, а затем 10 данных из этих 999 999 данных?
Спросите большого парня из группы DBA и получите ответ: "ДаО боже, это, наверное, медленно, и вам нужно много раз повторять это sql-утверждение.
Сначала я думал, что это проблема с EF,На самом деле, если вы пишете напрямую в SQL, хорошего решения нет。
Если да, пожалуйста, научите меня!
|