Intégration efficace de Elasticsearch et Silex: construire des applications haute performance
Cet article explique comment lire directement les données Elasticsearch en créant une petite application SILEX pour obtenir une intégration efficace des deux. Cela nécessite de définir Silex comme dépendance dans un projet basé sur des compositeurs existants et d'ajouter le SDK PHP Elasticsearch au compositeur.
Points de base:
L'intégration de Drupal 7 et Elasticsearch a été explorée dans l'article précédent, dans le but de combiner ces deux technologies open source pour créer des applications haute performance avec les deux avantages. (Pour le code connexe, veuillez vous référer au lien de référentiel de code )
Ensuite, nous créerons une petite application Silex qui lit et renvoie les données directement à partir d'Elasticsearch.
Construction d'application Silex
Silex est un excellent microframe PHP développé par l'équipe Symfony. La méthode pour construire rapidement une application Silex est la suivante:
<code>"silex/silex": "~1.2",</code>
<code>composer.phar create-project fabpot/silex-skeleton</code>
Elasticsearch PHP SDK est requis pour accéder à Elasticsearch. Ajoutez-le au compositeur:
<code>"elasticsearch/elasticsearch": "~1.0",</code>
Si vous utilisez des brindilles pour produire des données, vous devez également ajouter un composant de pontage à brindilles (ignoré s'il existe déjà):
<code>"symfony/twig-bridge": "~2.3"</code>
Pour utiliser le SDK, nous pouvons l'exposer en tant que service à Pimple (conteneur d'injection de dépendance de Silex). Cela peut être fait à plusieurs emplacements (voir le référentiel de code pour des exemples spécifiques), mais après avoir instancié l'application SILEX, vous pouvez ajouter le code suivant:
$app['elasticsearch'] = function() { return new Client(array()); };
Cela crée un service dans l'application appelée elasticsearch
, instanciant l'objet de classe client Elasticsearch. N'oubliez pas d'aller dans le haut use
la catégorie:
use Elasticsearch\Client;
Maintenant, le client Elasticsearch est accessible n'importe où via $app['elasticsearch']
.
Connectez Elasticsearch
L'article précédent a importé des données de nœud dans l'index node
, et chaque type de nœud correspond à un type de document Elasticsearch. Par exemple, le code suivant renvoie tous les nœuds de article
Type:
<code>http://localhost:9200/node/article/_search</code>
Nous savons déjà comment instancier le client SDK Elasticsearch et maintenant nous pouvons l'utiliser. Une façon consiste à créer un contrôleur:
<code>"silex/silex": "~1.2",</code>
L'emplacement du contrôleur dépend de la façon dont les applications SILEX sont organisées. Dans mon exemple, c'est dans le dossier src/Controller
et est automatiquement chargé par compositeur.
Nous devons également créer un itinéraire pour mapper vers ce contrôleur. Encore une fois, il existe plusieurs façons de gérer cela, dans mon exemple, j'ai un fichier src/
situé dans le dossier routes.php
et introduit dans index.php
:
<code>composer.phar create-project fabpot/silex-skeleton</code>
Dans cet exemple, le contrôleur obtient le client Elasticsearch, construit les paramètres de requête, exécute la requête, vérifie les résultats et utilise le modèle de brindille pour rendre si le nœud est trouvé, sinon il renvoie une erreur 404.
L'utilisation de brindilles nécessite d'enregistrer un fournisseur de services Twig:
<code>"elasticsearch/elasticsearch": "~1.0",</code>
Créez ensuite le fichier de modèle dans le dossier templates/
.
Conclusion
Cet article montre comment créer rapidement une application SILEX et les utiliser pour retourner les données de Elasticsearch. L'objectif n'est pas d'expliquer les détails de ces technologies, mais d'explorer leurs solutions d'intégration. En tant que système de gestion de contenu, Elasticsearch en tant que stockage de données haute performance et Silex en tant que cadre de récupération de données rapide, la combinaison des trois peut créer des applications haute performance.
(Plus de discussions sur la gestion des erreurs, l'optimisation des performances, les politiques de sécurité, etc., ainsi que des exemples de code et des FAQ plus détaillés)
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!