Правильность кэша

Правильность кэша. Правильный кэш должен отвечать на запрос наиболее современным ответом, соответствующим запросу, из хранимых кэшем который удовлетворяет одному из следующих условий 1. Он был проверен на эквивалентность ответу, который возвратил первоначальный сервер, повторно подтверждая достоверность 2. Он достаточно свеж fresh enough. По умолчанию это означает, что он удовлетворяет наименьшему из ограничительных требований свежести клиента, сервера и кэша если так определено первоначальным сервером, то это - требование свежести единственно первоначального сервера. 3. Он включает предупреждение, если свежесть запрошена клиентом или первоначальный сервер нарушен. 4. Он соответствует сообщению ответа с кодом состояния 304 не модифицирован, Not Modified , 305 используйте прокси-сервер, Use Proxy, или ошибочному ответу 4xsx или 5xx. Если кэш не может связаться с первоначальным сервером, то правильному кэшу следует отвечать как описано выше, если ответ может быть правильно обслужен из кэша иначе необходимо возвратить ошибку или предупредить о том, что имеется отказ связи. Если кэш получает ответ либо весь ответ, либо ответ с кодом состояния 304 не модифицирован, Not Modified, который может быть нормально передан запрашивающему клиенту, и полученный ответ устарел, то кэшу следует переслать его запрашивающему клиенту не добавляя нового заголовка Warning Предупреждение но не удаляя существующие заголовки Warning. Кэшу не следует пытаться повторно проверить достоверность ответа просто потому, что тот ответ устарел при передаче это могло бы привести к бесконечному циклу.

Агент пользователя, который получает просроченный ответ без Warning может показать пользователю предупреждение. 13.1.2 Предупреждения. Всякий раз, когда кэш возвращает ответ, который не является ни непосредственным first-hand, ни достаточно свежим в смысле условия 2 раздела 13.1.1 , он должен присоединить предупреждение об этом, используя заголовок ответа Warning.

Это предупреждение позволяет клиентам предпринимать соответствующие действия.

Предупреждения могут использоваться для других целей, как связанных с кэшированием, так и не связанных.

Использование предупреждений, а не ошибочных кодов состояния, отличает эти ответы от истинных отказов.

Предупреждения кэшируемы всегда, так как не ослабляют прозрачность ответа.

Это означает, что предупреждения могут быть переданы HTTP 1.0 кэшам без опасений такие кэши просто передадут предупреждение дальше как заголовок объекта в ответе. Предупреждения - это предопределенные числа от 0 до 99. Эта спецификация определяет коды, и значения каждого определенного в настоящее время предупреждения, позволяя клиенту или кэшу предпринимать самостоятельные действия в некоторых но не во всех случаях.

Предупреждения также содержат текст предупреждения. Текст может быть на любом соответствующем естественном языке возможно на основании заголовков Accept клиента, и включать опциональную индикацию используемого набора символов. К ответу могут быть присоединены несколько предупреждений как первоначальным сервером, так и кэшем, включая несколько предупреждений с одиннаковыми кодовыми номерами.

Например, сервер может добавлять одно и тоже предупреждение как к английским текстам, так и к баскским. Если к ответу присоединено несколько предупреждений, то может быть практически не целесообразно или не приемлемо показать все из них пользователю. Эта версия HTTP не определяет строгих приоритетных правил для определения, какие из предупреждений отображать и в каком порядке, но предлагает некоторую эвристику. 13.1.3