Maison >développement back-end >tutoriel php >Installer et intégrer Elasticsearch à Drupal
Tiration d'Elasticsearch pour les applications Drupal 7 de haute performance: un tutoriel en deux parties
Ce tutoriel explore l'utilisation de Drupal 7 comme CMS pour les applications haute performance, intégrant Elasticsearch et le SILEX PHP Microframework. L'objectif est une preuve de concept démontrant leurs capacités combinées. Le référentiel GIT qui l'accompagne fournit du code complet (voir le lien ci-dessous). La familiarité avec Drupal, Elasticsearch et Silex est recommandée.
Le tutoriel est divisé en deux parties:
Partie 1: Elasticsearch and Drupal Intégration
Cette section couvre la configuration d'Elasticsearch et la création d'un module Drupal personnalisé pour gérer les données de nœud dans Elasticsearch.
Configuration Elasticsearch: Installer Elasticsearch (des instructions Linux sont fournies). Surtout, configurez Elasticsearch pour la sécurité en définissant network.bind_host: localhost
et script.disable_dynamic: true
dans le fichier de configuration pour restreindre l'accès externe et désactiver les scripts dynamiques.
Intégration Drupal avec le module du connecteur ElasticSearch: Installez et activez le module Drupal du connecteur Elasticsearch. Cela fournit un emballage d'objet client ElasticSearch accessible dans votre module personnalisé:
<code class="language-php">$client = elastic_connector_get_client_by_id('my_cluster_id');</code>
Remplacer 'my_cluster_id'
par le nom de la machine Drupal de votre cluster (trouvé sur Admin / Config / Elasticsearch-Connector / Clusters).
Insertion de données (hook_node_insert): un module personnalisé (par exemple, "Elastic") avec hook_node_insert()
enregistre de nouveaux nœuds sur Elasticsearch. L'exemple ci-dessous utilise une fonction d'assistance _elastic_prepare_node()
pour formater les données du nœud:
<code class="language-php">function elastic_node_insert($node) { $client = elasticsearch_connector_get_client_by_id('my_cluster_id'); $params = _elastic_prepare_node($node); // ... (error handling and indexing logic) ... }</code>
Mise à jour des données (hook_node_update): hook_node_update()
s'assure qu'ElasticSearch reflète les changements de nœud. Il utilise _elastic_perform_node_search_by_id()
pour localiser le nœud avant de mettre à jour, en tirant parti de la version du document pour le contrôle de concurrence:
<code class="language-php">function elastic_node_update($node) { // ... (logic to update node in Elasticsearch) ... }</code>
Suppression de données (hook_node_delete): hook_node_delete()
supprime les nœuds d'Elasticsearch lorsqu'il est supprimé dans Drupal. Il utilise _elastic_perform_node_search_by_id()
pour trouver et supprimer le document correspondant:
<code class="language-php">function elastic_node_delete($node) { // ... (logic to delete node from Elasticsearch) ... }</code>
Vérification: Autoriser temporairement l'accès à distance (pour le développement local uniquement!) Pour tester la population Elasticsearch en faisant des demandes HTTP directement à partir de votre navigateur (par exemple, http://localhost:9200/node/_search
). N'oubliez pas de réactiver les restrictions de sécurité par la suite.
Partie 2: Application Silex (à couvert dans la partie suivante du tutoriel)
Cette section détaillera la création d'une application Silex pour récupérer et afficher les données directement à partir d'Elasticsearch, en contournant Drupal.
GIT Repository: [Insérez le lien de référentiel GIT ici]
Questions fréquemment posées (FAQ):
(Les FAQ restent largement inchangées à partir de l'entrée d'origine, de l'abandon de dépannage, de la compatibilité avec les versions drupales plus anciennes, de l'optimisation des performances, de la sécurité, de la prise en charge multisite, de l'indexation de champ personnalisée, de la recherche en facettes, de l'intégration du commerce Drupal, de la surveillance des performances et du contenu multilingue manipulation.)
Cette sortie révisée maintient la signification du contenu d'origine tout en restructurant le texte pour une clarté et un flux améliorés. Il utilise également des phrases et des titres plus concises. L'image reste dans son format et son emplacement d'origine.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!