Integrasi PHP dan Elasticsearch
Dengan pembangunan data besar dan perlombongan data, enjin carian telah menjadi alat yang sangat diperlukan dalam kehidupan kita. Elasticsearch ialah enjin carian dan analisis yang pantas, terbuka dan berskala yang boleh melaksanakan pengambilan teks penuh, analisis data dan penyimpanan dan pertanyaan data masa nyata dengan mudah. Jadi bagaimana untuk mengintegrasikan dengan Elasticsearch menggunakan PHP?
1. Pasang Elasticsearch
Mula-mula, kita perlu memasang Elasticsearch. Anda boleh pergi ke laman web rasmi Elasticsearch untuk memuat turun pakej pemasangan versi yang sepadan, dan kemudian nyahzipnya ke lokasi yang anda mahukan. Anda boleh melihat perintah elasticsearch.bat (Windows)/elasticsearch (Linux) dalam direktori bin Elasticsearch.
Laksanakan perintah elasticsearch.bat/ untuk memulakan Elasticsearch. Jika semuanya berjalan lancar, anda kini telah memulakan nod Elasticsearch. Gunakan alamat http://localhost:9200/ untuk mengakses API RESTful yang disediakan oleh Elasticsearch.
2. Pasang dan konfigurasikan klien Elasticsearch untuk PHP
Kami perlu memuat turun dan memasang klien Elasticsearch untuk PHP, seperti Elasticsearch-PHP atau perpustakaan Elasticsearch rasmi php-elasticsearch (Elasticsearch 7. + perlu dipasang) Versi). Perpustakaan ini semuanya sangat berguna dan mempunyai dokumentasi dan contoh yang lengkap. Mari kita ambil klien Elasticsearch-PHP sebagai contoh:
1 Pemasangan
Anda boleh menggunakan komposer untuk memasang klien Elasticsearch-PHP. Beralih ke direktori akar projek php anda dan laksanakan arahan berikut:
komposer memerlukan elasticsearch/elasticsearch
2. Gunakan
untuk memperkenalkan pemuat automatik, dan kemudian segerakan klien disambungkan ke objek Elasticsearch End:
memerlukan 'vendor/autoload.php';
$client = ElasticsearchClientBuilder::create()->build();
Di sini kita membina dalam PHP Pelanggan Elasticsearch. Seterusnya, anda boleh melakukan operasi CRUD pada data Elasticsearch.
3. Operasi Elasticsearch
1 Cipta indeks
Indeks ialah salah satu konsep yang paling penting dalam Elasticsearch Kami perlu mencipta indeks yang berbeza untuk keperluan perniagaan yang berbeza. Indeks bernama my_index boleh dibuat menggunakan kod berikut:
$params = [
'index' => 'my_index', 'body' => [ 'settings' => [ 'number_of_shards' => 3, 'number_of_replicas' => 2 ] ]
];
$response = $client->indeks()->create ( $params);
Dalam kod di atas, kami menentukan nama indeks yang akan dibina dan atribut tetapan (bilangan serpihan dan replika) sepadan dengan indeks. Dalam penggunaan sebenar, adalah disyorkan untuk mengkonfigurasi atribut tetapan yang lebih terperinci mengikut keperluan perniagaan.
2. Masukkan dokumen
Gunakan kaedah pukal untuk memasukkan berbilang dokumen:
$params = [
'body' => [ ['index' => ['_id' => 1]], ['name' => 'product1', 'price' => 10.0, 'description' => 'description of product1'], ['index' => ['_id' => 2]], ['name' => 'product2', 'price' => 20.0, 'description' => 'description of product2'], ['index' => ['_id' => 3]], ['name' => 'product3', 'price' => 30.0, 'description' => 'description of product3'], ['index' => ['_id' => 4]], ['name' => 'product4', 'price' => 40.0, 'description' => 'description of product4'], ], 'index' => 'my_index', 'type' => 'my_type'
];
$response = $ klien->bulk($params);
3 Dokumen pertanyaan
Gunakan kaedah carian untuk menanyakan dokumen:
$params = [
'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'match' => [ 'name' => 'product1' ] ] ]
] ;
$response = $client->search($params);
4 Padamkan indeks
Untuk memadamkan indeks, anda boleh menggunakan kaedah padam: <. 🎜>
$params = ['index' => 'my_index'
$respons = $client->indeks()->delete($params);
Atas ialah kandungan terperinci Integrasi PHP dan Elasticsearch. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!