Je reçois une erreur fréquente et intermittente du module Advanced Forum qui provoque une erreur 500 lorsqu'elle se produit (WSOD). En production, cela se produit environ 20 fois par heure, probablement sur 2 à 3% de toutes les charges de pages de forum par heure. Il est toujours intermittent . Localement, je ne peux pas reproduire systématiquement l'erreur, mais elle se produit.
L'erreur est sur
Ligne 232 de sites / all / modules / contrib / advanced_forum / includes / core-overrides.inc`:
Appel à la méthode non définie stdClass :: preview ()
Le problème réside dans la fonction advanced_forum_get_topics ():
function advanced_forum_get_topics($tid, $sortby, $forum_per_page, $sort_form = TRUE) {
$term = taxonomy_term_load($tid);
drupal_add_feed('taxonomy/term/' . $tid . '/feed', 'RSS - ' . check_plain($term->name));
// Views handles this page
$view = views_get_view('advanced_forum_topic_list');
$view->sort_form = $sort_form;
return $view->preview('default', array($tid));
}
Views_get_view () ne parvient pas à trouver la vue et l'objet n'est pas créé comme prévu sur la ligne de retour. Le problème semble donc résider avec les vues qui ne savent pas parfois que la vue existe. Cela me fait penser que c'est un problème de crochet.
Là où ça commence à devenir étrange, ce sont les implémentations de hook_views_default_views () et hook_views_plugins (). Selon views.api.php, hook_views_default_views () devrait être dans un fichier appelé MODULENAME.views_default.inc et hook_views_plugins () devrait être dans un fichier appelé MODULENAME.views.inc. Cependant, les deux fichiers se trouvent dans le fichier MODULENAME.views.inc.
De views.api.php:
hook_views_plugins()
Ce crochet doit être placé dans MODULENAME.views.inc et il sera automatiquement chargé.
MODULENAME.views.inc doit se trouver dans le répertoire spécifié par la clé 'path' retournée par MODULENAME_views_api (), ou le même répertoire que le fichier .module, si 'path' n'est pas spécifié.hook_views_default_views()
Ce crochet doit être placé dans MODULENAME.views_default.inc et il sera automatiquement chargé. MODULENAME.views_default.inc doit se trouver dans le répertoire spécifié par la clé 'path' renvoyée par MODULENAME_views_api (), ou le même répertoire que le fichier .module, si 'path' n'est pas spécifié.
J'ai essayé de diviser ces routines en fichiers apparemment corrects. Cela a amené Views à rechercher systématiquement la vue Advanced Forum (comme indiqué qu'il apparaissait dans la liste GUI Views) mais ne voyait pas le plug-in. Les pages de Advanced Forum se sont bien déroulées, mais les vues étaient vides car elles faisaient référence à un plug-in de style fourni par Advanced Forum que Views ne voyait plus.
Je suppose que je manque quelque chose sur les crochets Views, mais je suis totalement perplexe.
- Pile: Drupal 7, vues (7.x-3.3), CTools (7.x-1.0), forum avancé (7.x-2.0)
- PHP FPM, APC, nginx, Redis
- Je n'ai rien trouvé d'utile dans ce problème
MISE À JOUR 1 : Bien que je n'aie pas résolu la cause première, il semble que la désactivation de Redis et le retour au mécanisme de stockage par cache basé sur la base de données par défaut de Drupal empêchent le problème de se produire.
MISE À JOUR 2 : Je peux répliquer le problème de manière fiable sur local en faisant un flushall
dans Redis. La première page chargée de regarder une liste de forum sera fatale. Le deuxième chargement de page (et tous les suivants) fonctionne correctement . MISE À JOUR: Je dois frapper la page de liste des vues d'administration pour effacer l'erreur.
MISE À JOUR 3 : Lors d'un dépannage plus poussé, le problème semble être dû au fait que le cache des vues n'est pas correctement reconstruit après un effacement du cache, uniquement lors de l'utilisation de Redis. Le problème ne se produit pas lors du retour au cache Drupal standard. Lorsque le problème se produit, seules 2 à 4 entrées de cache existent pour les vues, par opposition à 100+ lorsque le cache est correctement créé. La visite de la page de liste des vues d'administration entraîne la création complète du cache et le problème ne se produit pas. Je dois vérifier si le fait de frapper une page de vue Afficher à l'origine du problème, ou simplement la vue avancée du forum.
MISE À JOUR 4 : Un utilisateur utile sur IRC a suggéré que cela pourrait être un problème lié aux problèmes de condition de concurrence du cache de vues: 853864 , 1102252