web-dev-qa-db-fra.com

Est-ce bien si la première réponse est privée avec AppCache (Symfony2)?

J'essaie d'utiliser la mise en cache http. Dans mon contrôleur, je définis une réponse comme suit:

$response->setPublic();
$response->setMaxAge(120);
$response->setSharedMaxAge(120);
$response->setLastModified($lastModifiedAt);

mode dev

Dans un environnement de développement, la première réponse est un 200 avec les en-têtes suivants:

cache-control:max-age=120, public, s-maxage=120
last-modified:Wed, 29 Feb 2012 19:00:00 GMT

Pour les 2 prochaines minutes, chaque réponse est un 304 avec les en-têtes suivants:

cache-control:max-age=120, public, s-maxage=120

C'est essentiellement ce que j'attends.

mode prod

En mode prod, les en-têtes de réponse sont différents. Notez que dans app.php j'encapsule le noyau dans AppCache.

La première réponse est un 200 avec les en-têtes suivants:

cache-control:must-revalidate, no-cache, private
last-modified:Thu, 01 Mar 2012 11:17:35 GMT

Il s'agit donc d'une réponse privée sans cache.

Chaque prochaine demande est à peu près ce à quoi je m'attendrais; un 304 avec les en-têtes suivants:

cache-control:max-age=120, public, s-maxage=120

Dois-je m'en inquiéter? Est-ce un comportement attendu?

Que se passera-t-il si je place le serveur Varnish ou Akamai devant lui?

J'ai fait un peu de débogage et je me suis dit que la réponse était privée à cause de l'en-tête modifié en dernier. Noyau HttpCache tilise EsiResponseCacheStrategy pour mettre à jour la réponse mise en cache ( méthode HttpCache :: handle () ).

if (HttpKernelInterface::MASTER_REQUEST === $type) {
    $this->esiCacheStrategy->update($response);
}

EsiResponseCacheStrategy transforme une réponse en non cacheable si elle utilise Last-Response ou ETag ( méthode EsiResponseCacheStrategy :: add () ):

if ($response->isValidateable()) {
    $this->cacheable = false;
} else {
    // ... 
}

Response :: isValidateable () renvoie vrai si l'en-tête Last-Response ou ETag est présent.

Il en résulte écrasement de l'en-tête Cache-Control ( méthode EsiResponseCacheStrategy :: update () ):

if (!$this->cacheable) {
    $response->headers->set('Cache-Control', 'no-cache, must-revalidate');

    return;
}

J'ai posé cette question sur le groupe d'utilisateurs Symfony2 mais je n'ai pas obtenu de réponse jusqu'à présent: https://groups.google.com/d/topic/symfony2/6lpln11POq8/discussion

Mise à jour.

Comme je n'ai plus accès au code d'origine, j'ai essayé de reproduire le scénario avec la dernière édition standard de Symfony .

Les en-têtes de réponse sont désormais plus cohérents, mais semblent toujours faux.

Dès que j'ai défini un Last-Modified en-tête sur la réponse, la première réponse faite par un navigateur a:

Cache-Control:must-revalidate, no-cache, private

Une deuxième réponse attendue:

Cache-Control:max-age=120, public, s-maxage=120

Si j'évite d'envoyer If-Modified-Since en-tête, chaque demande renvoie must-revalidate, no-cache, private.

Peu importe si la demande a été faite dans un environnement prod ou dev.

140
Jakub Zalas

J'ai rencontré le même problème. J'ai dû fournir des en-têtes "publics" à mon cdn. Par défaut, lorsque la mise en cache de la passerelle est activée en mode prod, elle renvoie 200 OK avec privé, nocache doit valider les en-têtes.

J'ai résolu le problème de cette façon.

Dans app.php, avant d'envoyer une réponse à l'utilisateur ($ respond-> send), j'ai écrasé l'en-tête de contrôle du cache en blanc et défini les en-têtes de cache sur public et max age (une certaine valeur).

// extrait de code depuis app.php

    $response = $kernel->handle($request);
    $response->headers->set('Cache-Control', '');
    $response->setPublic();
    $response->setMaxAge(86400);
    $response->send();        
9
srikanthsatturi