在Web開發中,數據存儲與搜索是非常重要的一部分。ElasticSearch是一個開源的分布式搜索引擎,被廣泛應用于數據搜索和分析。它能夠處理大量數據并提供高效的搜索和聚合功能。Workerman是一款高性能的PHP socket框架,適用于開發實時通信、在線游戲和高并發Web服務等應用。在本文中,我們將介紹如何在Workerman中使用ElasticSearch進行數據存儲與搜索。
- ElasticSearch安裝與配置
在開始之前,我們需要先安裝和配置ElasticSearch。可以在ElasticSearch的官方網站https://www.elastic.co/downloads/elasticsearch下載最新的安裝包,根據操作系統類型進行安裝。安裝完成后,可以通過以下命令來啟動ElasticSearch:
$ cd elasticsearch/bin $ ./elasticsearch
登錄后復制
同時,我們還可以在config/elasticsearch.yml文件中進行ElasticSearch的配置,比如設置監聽端口、集群名稱和數據存儲路徑等。
- Workerman的安裝與配置
在使用Workerman之前,我們需要先安裝和配置它。可以通過在終端中輸入以下命令來安裝Workerman:
$ composer require workerman/workerman
登錄后復制
安裝完成后,我們需要創建一個PHP腳本文件,并在其中引入Workerman的Autoloader類,并添加以下代碼來啟動Workerman:
require_once __DIR__ . '/vendor/autoload.php';
use WorkermanWorker;
$worker = new Worker();
$worker->count = 4;
$worker->onWorkerStart = function($worker){
// do something
};
Worker::runAll();
登錄后復制
在上述代碼中,我們創建了一個Worker對象,并設置了進程數為4。同時,我們還通過onWorkerStart回調函數來定義了Worker進程啟動時的行為。
- ElasticSearch中數據的增刪查改
在Workerman中使用ElasticSearch進行數據存儲與搜索,我們需要掌握ElasticSearch中數據的增刪查改操作,具體操作如下所示:
a. 數據的創建
在ElasticSearch中,數據的創建是通過對指定索引和文檔類型的HTTP PUT請求完成的,可以使用以下代碼來創建數據:
curl -XPUT http://localhost:9200/{index}/{type}/{id} -d '{
"title":"ElasticSearch tutorial",
"tags":["search","elasticsearch"],
"body":"ElasticSearch is a powerful search engine."
}'
登錄后復制
當然,我們也可以使用PHP代碼來完成數據的創建:
$client = ElasticsearchClientBuilder::create()->build();
$params = [
'index' => 'my_index',
'type' => 'my_type',
'id' => 'my_id',
'body' => [
'title' => 'ElasticSearch tutorial',
'tags' => ['search', 'elasticsearch'],
'body' => 'ElasticSearch is a powerful search engine.'
]
];
$response = $client->index($params);
登錄后復制
b. 數據的查詢
在ElasticSearch中,數據的查詢分為精確查詢和模糊查詢兩種方式。其中,精確查詢是指通過指定字段和值來查找數據,而模糊查詢是指通過模糊匹配來查找數據。可以使用以下代碼來完成數據的查詢:
// 精確查詢
$client = ElasticsearchClientBuilder::create()->build();
$params = [
'index' => 'my_index',
'type' => 'my_type',
'body' => [
'query' => [
'match' => [
'title' => 'ElasticSearch tutorial'
]
]
]
];
$response = $client->search($params);
// 模糊查詢
$client = ElasticsearchClientBuilder::create()->build();
$params = [
'index' => 'my_index',
'type' => 'my_type',
'body' => [
'query' => [
'wildcard' => [
'title' => '*search*'
]
]
]
];
$response = $client->search($params);
登錄后復制
c. 數據的更新
在ElasticSearch中,數據的更新操作是通過對指定索引和文檔類型的HTTP POST請求完成的,可以使用以下代碼來更新數據:
curl -XPOST http://localhost:9200/{index}/{type}/{id}/_update -d '{
"doc":{
"title":"New ElasticSearch tutorial"
}
}'
登錄后復制
當然,我們也可以使用PHP代碼來完成數據的更新:
$client = ElasticsearchClientBuilder::create()->build();
$params = [
'index' => 'my_index',
'type' => 'my_type',
'id' => 'my_id',
'body' => [
'doc' => [
'title' => 'New ElasticSearch tutorial'
]
]
];
$response = $client->update($params);
登錄后復制
d. 數據的刪除
在ElasticSearch中,數據的刪除操作是通過對指定索引和文檔類型的HTTP DELETE請求完成的,可以使用以下代碼來刪除數據:
curl -XDELETE http://localhost:9200/{index}/{type}/{id}
登錄后復制
當然,我們也可以使用PHP代碼來完成數據的刪除:
$client = ElasticsearchClientBuilder::create()->build();
$params = [
'index' => 'my_index',
'type' => 'my_type',
'id' => 'my_id'
];
$response = $client->delete($params);
登錄后復制
- Workerman中的ElasticSearch示例
通過上述操作,我們已經掌握了在ElasticSearch中進行數據存儲與搜索的基本操作。接下來,我們將在Workerman中實現一個使用ElasticSearch進行數據存儲與搜索的示例,具體代碼如下所示:
require_once __DIR__ . '/vendor/autoload.php';
use WorkermanWorker;
use ElasticsearchClientBuilder;
// 創建一個Worker對象
$worker = new Worker();
$worker->count = 4;
// 啟動一個ElasticSearch客戶端
$client = ClientBuilder::create()->build();
// 處理連接請求
$worker->onConnect = function($connection) {
echo "New connection from " . $connection->getRemoteIp() . PHP_EOL;
};
// 處理數據請求
$worker->onMessage = function($connection, $data) use($client) {
$params = [
'index' => 'my_index',
'type' => 'my_type',
'body' => [
'query' => [
'wildcard' => [
'title' => '*' . $data . '*'
]
]
]
];
// 從ElasticSearch檢索數據
$response = $client->search($params);
// 處理檢索結果
$hits = $response['hits']['hits'];
if(count($hits) > 0) {
$result = 'Results:' . PHP_EOL;
foreach($hits as $hit) {
$result .= $hit['_source']['title'] . PHP_EOL;
}
} else {
$result = 'No results found.' . PHP_EOL;
}
// 發送結果給客戶端
$connection->send($result);
};
Worker::runAll();
登錄后復制
在上述代碼中,我們首先啟動一個ElasticSearch客戶端,并創建一個Worker對象來處理連接和數據請求。當有客戶端連接進來后,在接收到數據請求時,我們從ElasticSearch中檢索數據,并將結果發送給客戶端。
- 總結
本文介紹了如何在Workerman中使用ElasticSearch進行數據存儲與搜索。通過掌握ElasticSearch中數據的增刪查改操作,我們可以快速地在Web應用中進行數據的存儲和搜索。同時,我們也在Workerman中實現了一個簡單的ElasticSearch應用,以便更好地理解和運用上述操作。






