Wie verwende ich die Elasticsearch-Technologie in PHP?
Mit dem Aufkommen von Webanwendungen sind Suchmaschinen zu einem wesentlichen Bestandteil moderner Anwendungen geworden. In der Vergangenheit haben wir SQL-Abfragen zum Durchsuchen von Daten verwendet, SQL wurde jedoch nicht speziell für die Suche entwickelt. Um diesen Mangel auszugleichen, wurden Volltextsuchmaschinen wie Apache Solr, Elasticsearch usw. entwickelt.
Elasticsearch ist eine beliebte Lucene-basierte Volltextsuchmaschine, die sofort einsatzbereite verteilte Such- und Analysefunktionen für Echtzeit-Datenanalysen und Suchmaschinen bietet. Im Vergleich zu herkömmlichen relationalen Datenbanken kann Elasticsearch Abfragen schneller durchführen, hochdynamische Datenstrukturen besser verarbeiten und umfangreichere Abfragesprachen unterstützen.
In diesem Artikel stellen wir vor, wie man Elasticsearch in PHP-Anwendungen verwendet.
Umgebungsvorbereitung
Zuerst müssen wir Elasticsearch in der lokalen Umgebung oder auf dem Remote-Server installieren. Elasticsearch unterstützt alle gängigen Betriebssysteme, einschließlich Windows, macOS und Linux. Sie können verschiedene Versionen des Installationsprogramms auf der offiziellen Website herunterladen oder es mit dem Paketmanager installieren.
Um die Elasticsearch-Client-Bibliothek von PHP nutzen zu können, müssen wir auch die Elasticsearch-Client-Erweiterung von PHP installieren. Es kann über PECL oder manuell heruntergeladen, kompiliert und installiert werden. Hier ist ein Beispiel für die Verwendung von PECL:
pecl install elasticsearch
Fügen Sie dann die folgende Zeile in php.ini hinzu:
extension=elasticsearch.so
Nach Abschluss der Installation können wir PHP verwenden, um Elasticsearch zu betreiben.
Elasticsearch in PHP verwenden
Die Verwendung von Elasticsearch in PHP erfordert die Verwendung einer Elasticsearch-Clientklasse oder -Bibliothek. Derzeit sind viele PHP-Elasticsearch-Client-Bibliotheken verfügbar, darunter unter anderem Elasticsearch-PHP, Elasticsearch-DSL und Elastica.
In diesem Artikel werden wir die Elasticsearch-PHP-Bibliothek verwenden, um die Verwendung von Elasticsearch zu demonstrieren.
Zuerst müssen wir ein Elasticsearch-Clientobjekt erstellen:
$client = ElasticsearchClientBuilder::create()->build();
Jetzt können wir dieses Clientobjekt verwenden, um eine Verbindung mit Elasticsearch herzustellen und verschiedene Vorgänge auszuführen.
Dokumente indizieren und durchsuchen
In Elasticsearch beziehen sich Dokumente auf Daten im JSON-Format. Mit der PHP-Elasticsearch-Clientbibliothek können wir PHP-Arrays einfach in das JSON-Format konvertieren und sie in Elasticsearch indizieren. Zuerst müssen wir einen Index auswählen (ähnlich einer Tabelle in einer relationalen Datenbank) und dann Daten zu diesem Index hinzufügen.
$params = [ 'index' => 'my_index', 'type' => 'my_type', 'id' => '1', 'body' => ['title' => 'My first document', 'content' => 'Hello World'] ]; $response = $client->index($params);
Im obigen Code haben wir die Methode index
verwendet, um das Dokument zu indizieren. Die index
-Methode erfordert ein Parameterarray, das mindestens die folgenden Schlüssel enthält: index
方法来索引文档。index
方法需要一个参数数组,它至少包含以下键:
index
:索引的名称type
:文档的类型id
:文档的唯一标识符body
:包含文档数据的数组或JSON格式字符串
上述代码示例创建了一个名为 my_index
的索引,类型为my_type
,文档唯一标识符为1,并包含一个 title
和 content
字段。一旦文档被索引并储存到Elasticsearch中,我们就可以搜索它们了。
$params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'match' => [ 'title' => 'My first document' ] ] ] ]; $response = $client->search($params);
在上面的代码中,我们使用 search
方法搜索文档。search
方法需要一个参数数组,它至少包含以下键:
index
:要搜索的索引的名称type
:要搜索的文档类型body
:包含实际搜索查询的数组
上述代码示例搜索了 my_index
索引中,类型为 my_type
且 title
包含 My first document
的文档。搜索结果是一个JSON格式的响应,其中包含匹配查询的文档。
分页和排序
当搜索结果集很大时,我们可能希望对结果进行分页或排序。我们可以使用Elasticsearch提供的参数来实现这两个功能。
$params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'match' => [ 'title' => 'document' ] ] ], 'size' => 10, 'from' => 0, 'sort' => ['title' => ['order' => 'asc']] ]; $response = $client->search($params);
在上面的代码中,我们添加了以下额外的参数:
size
:每页文档的数量from
:起始文档的位置,用于分页sort
:按title
字段进行升序排序
以上示例获取了前10个匹配 document
的文档,并按 title
字段升序排序。
聚合搜索
Elasticsearch还支持聚合搜索,这是一种在搜索结果集上执行各种分析的技术。例如,我们可以从搜索结果中提取所有 author
字段的唯一值。
$params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'aggs' => [ 'unique_authors' => [ 'terms' => [ 'field' => 'author.keyword', 'size' => 10 ] ] ] ] ]; $response = $client->search($params);
在上面的代码中,我们使用 aggs
作为参数数组中的新键,并在其中定义了一个名称为 unique_authors
的聚合搜索。 terms
表示我们将按照 author
字段的值进行分组聚合。field
键用于指定要聚合的字段,size
-
index
: der Name des Index -
type
: Typ des Dokuments -
id
: Eindeutige Kennung des Dokuments -
body
: Array mit Dokumentdaten oder JSON-Formatzeichenfolge
my_index
, der Typ ist my_type
und die eindeutige Kennung des Dokuments ist 1 und enthält die Felder title
und content
. Sobald die Dokumente in Elasticsearch indiziert und gespeichert sind, können wir sie durchsuchen. rrreee
Im obigen Code verwenden wir die Methodesearch
, um nach Dokumenten zu suchen. Die search
-Methode erfordert ein Argumentarray, das mindestens die folgenden Schlüssel enthält: 🎜-
index
: Der Name des zu durchsuchenden Index - type: Der Typ des zu durchsuchenden Dokuments
-
body
: Ein Array, das die eigentliche Suchabfrage enthält
my_type
, dessen title
My first document
im code>my_index-Index enthält. Das Suchergebnis ist eine JSON-formatierte Antwort, die Dokumente enthält, die der Abfrage entsprechen. 🎜🎜Paging und Sortieren🎜🎜Wenn die Suchergebnismenge groß ist, möchten wir die Ergebnisse möglicherweise paginieren oder sortieren. Wir können die von Elasticsearch bereitgestellten Parameter verwenden, um diese beiden Funktionen zu erreichen. 🎜rrreee🎜Im obigen Code haben wir die folgenden zusätzlichen Parameter hinzugefügt: 🎜-
size
: die Anzahl der Dokumente pro Seite von code>: Die Position des Startdokuments, die zum Blättern verwendet wird
-
sort
: Sortiert in aufsteigender Reihenfolge nach dem Feldtitle
ul> 🎜Das obige Beispiel ruft die ersten 10 Dokumente ab, die mit
document
übereinstimmen, und sortiert sie in aufsteigender Reihenfolge nach dem Feld title
. 🎜🎜Aggregationssuche🎜🎜Elasticsearch unterstützt auch die Aggregationssuche, eine Technik, die verschiedene Analysen an Suchergebnisseiten durchführt. Beispielsweise können wir alle eindeutigen Werte für das Feld author
aus den Suchergebnissen extrahieren. 🎜rrreee🎜Im obigen Code verwenden wir aggs
als neuen Schlüssel im Parameter-Array und definieren darin eine aggregierte Suche mit dem Namen unique_authors
. terms
bedeutet, dass wir basierend auf dem Wert des Felds author
gruppieren und aggregieren. Der Schlüssel field
wird verwendet, um das zu aggregierende Feld anzugeben, und der Schlüssel size
gibt die Größenbeschränkung der Aggregationsgruppe an. 🎜🎜Fazit🎜Elasticsearch ist eine leistungsstarke Volltextsuchmaschine, die aus vielen modernen Webanwendungen nicht mehr wegzudenken ist. Sie kann uns helfen, Daten besser zu verarbeiten und Echtzeitsuchen durchzuführen. In diesem Artikel wird erläutert, wie Sie Elasticsearch in PHP verwenden und wie Sie Dokumente indizieren, durchsuchen, paginieren und sortieren. Darüber hinaus wird auch die Verwendung von Elasticsearch für die aggregierte Suche vorgestellt. Jetzt haben Sie gelernt, wie Sie mit Elasticsearch effiziente und schnelle Suchvorgänge in Ihren PHP-Anwendungen implementieren.
Das obige ist der detaillierte Inhalt vonWie verwende ich die Elasticsearch-Technologie in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Wenn Sie ein erfahrener PHP-Entwickler sind, haben Sie möglicherweise das Gefühl, dass Sie dort waren und dies bereits getan haben. Sie haben eine beträchtliche Anzahl von Anwendungen entwickelt, Millionen von Codezeilen debuggt und eine Reihe von Skripten optimiert, um op zu erreichen

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Dieses Tutorial zeigt, wie XML -Dokumente mit PHP effizient verarbeitet werden. XML (Extensible Markup-Sprache) ist eine vielseitige textbasierte Markup-Sprache, die sowohl für die Lesbarkeit des Menschen als auch für die Analyse von Maschinen entwickelt wurde. Es wird üblicherweise für die Datenspeicherung ein verwendet und wird häufig verwendet

Eine Zeichenfolge ist eine Folge von Zeichen, einschließlich Buchstaben, Zahlen und Symbolen. In diesem Tutorial wird lernen, wie Sie die Anzahl der Vokale in einer bestimmten Zeichenfolge in PHP unter Verwendung verschiedener Methoden berechnen. Die Vokale auf Englisch sind a, e, i, o, u und sie können Großbuchstaben oder Kleinbuchstaben sein. Was ist ein Vokal? Vokale sind alphabetische Zeichen, die eine spezifische Aussprache darstellen. Es gibt fünf Vokale in Englisch, einschließlich Großbuchstaben und Kleinbuchstaben: a, e, ich, o, u Beispiel 1 Eingabe: String = "TutorialPoint" Ausgabe: 6 erklären Die Vokale in der String "TutorialPoint" sind u, o, i, a, o, ich. Insgesamt gibt es 6 Yuan

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.

Was sind die magischen Methoden von PHP? Zu den magischen Methoden von PHP gehören: 1. \ _ \ _ Konstrukt, verwendet, um Objekte zu initialisieren; 2. \ _ \ _ Destruct, verwendet zur Reinigung von Ressourcen; 3. \ _ \ _ Call, behandeln Sie nicht existierende Methodenaufrufe; 4. \ _ \ _ GET, Implementieren Sie den dynamischen Attributzugriff; 5. \ _ \ _ Setzen Sie dynamische Attributeinstellungen. Diese Methoden werden in bestimmten Situationen automatisch aufgerufen, wodurch die Code -Flexibilität und -Effizienz verbessert werden.
