Heim >Backend-Entwicklung >PHP-Tutorial >Integrieren Sie Elasticsearch in Silex
Effiziente Integration von Elasticsearch und Silex: Aufbau Hochleistungsanwendungen
In diesem Artikel wird erläutert, wie Elasticsearch -Daten direkt gelesen werden, indem eine kleine Silex -Anwendung erstellt wird, um eine effiziente Integration der beiden zu erreichen. Dies erfordert, dass Silex als Abhängigkeit in einem vorhandenen Komponisten-basierten Projekt festgelegt wird und das Elasticsearch-PHP-SDK zum Komponisten hinzugefügt wird.
Kernpunkte:
Die Integration von Drupal 7 und Elasticsearch wurde im vorherigen Artikel untersucht, mit dem Ziel, diese beiden Open-Source-Technologien zum Aufbau leistungsstarker Anwendungen mit beiden Vorteilen zu kombinieren. (Für den zugehörigen Code finden Sie den Link Code -Repository )
Als nächstes erstellen wir eine kleine Silex -App, die Daten direkt von Elasticsearch liest und zurückgibt.
Silex Application Construction
silex ist ein ausgezeichnetes Php -Mikroframewerk, das vom Symfony -Team entwickelt wurde. Die Methode, um schnell eine Silex -Anwendung zu erstellen, lautet wie folgt:
<code>"silex/silex": "~1.2",</code>
<code>composer.phar create-project fabpot/silex-skeleton</code>
Ereignis von Elasticsearch PHP SDK ist für den Zugriff auf Elasticsearch erforderlich. Fügen Sie es dem Komponisten hinzu:
<code>"elasticsearch/elasticsearch": "~1.0",</code>
Wenn Sie Twig zum Ausgabe von Daten verwenden, müssen Sie auch eine Zweig -Brückenkomponente hinzufügen (ignoriert, wenn sie bereits existiert):
<code>"symfony/twig-bridge": "~2.3"</code>
Um den SDK zu verwenden, können wir ihn als Dienst für Pickel (Silex 'Abhängigkeitsinjektionsbehälter) aussetzen. Dies kann an mehreren Stellen erfolgen (siehe Code -Repository für bestimmte Beispiele). Nach dem Instanziieren der Silex -Anwendung können Sie jedoch den folgenden Code hinzufügen:
<code class="language-php">$app['elasticsearch'] = function() { return new Client(array()); };</code>
Dies schafft einen Dienst in der Anwendung namens elasticsearch
, wobei das Elasticsearch Client -Class -Objekt instanziiert. Vergessen Sie nicht, in die Kategorie zu gehen: use
<code class="language-php">use Elasticsearch\Client;</code>Jetzt kann der Elasticsearch -Client über
überall zugegriffen werden. $app['elasticsearch']
Verbinden Sie Elasticsearch
Der vorherige Artikel hat Knotendaten in den -Endex importiert, und jeder Knotentyp entspricht einem Elasticsearch -Dokumenttyp. Zum Beispiel gibt der folgende Code alle Knoten von node
Typ: article
zurück
<code>http://localhost:9200/node/article/_search</code>Wir wissen bereits, wie der Elasticsearch -SDK -Client instanziiert und jetzt können wir ihn verwenden. Eine Möglichkeit besteht darin, einen Controller zu erstellen:
<code>"silex/silex": "~1.2",</code>
Controller -Standort hängt davon ab, wie Silex -Anwendungen organisiert sind. In meinem Beispiel befindet sich es im Ordner src/Controller
und wird automatisch vom Komponisten geladen.
Wir müssen auch eine Route erstellen, um diesem Controller zuzuordnen. Auch hier gibt es mehrere Möglichkeiten, damit umzugehen. In meinem Beispiel habe ich eine src/
-Datei im Ordner routes.php
und in index.php
:
<code>composer.phar create-project fabpot/silex-skeleton</code>
In diesem Beispiel erhält der Controller den Elasticsearch -Client, erstellt die Abfrageparameter, führt die Abfrage aus, überprüft die Ergebnisse und verwendet die Twig -Vorlage, um zu rendern, wenn der Knoten gefunden wird, andernfalls gibt er einen 404 -Fehler zurück.
Verwenden von Twig erfordert die Registrierung eines Twig -Dienstanbieters:
<code>"elasticsearch/elasticsearch": "~1.0",</code>
Erstellen Sie dann die Vorlagendatei im Ordner templates/
.
Schlussfolgerung
Dieser Artikel zeigt, wie schnell eine Silex -Anwendung erstellt und Daten aus Elasticsearch zurückgegeben werden können. Ziel ist es nicht, die Details dieser Technologien zu erklären, sondern ihre Integrationslösungen zu untersuchen. Als Content-Management-System, Elasticsearch als Hochleistungsdatenspeicherung und Silex als schnelles Rahmen für Datenabrufe kann die Kombination der drei leistungsstarken Anwendungen erstellen.
(Weitere Diskussionen über Fehlerbehandlung, Leistungsoptimierung, Sicherheitsrichtlinien usw. sowie detailliertere Code -Beispiele und FAQs)
Das obige ist der detaillierte Inhalt vonIntegrieren Sie Elasticsearch in Silex. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!