Elasticsearch 安装及PHP使用详解编程语言

本文章主要介绍了Elasticsearch 安装及PHP使用,具有不错的的参考价值,希望对您有所帮助,如解说有误或未考虑完全的地方,请您留言指出,谢谢!

ElasticSearch需要基于Java下运行,故首先保证已安装java

此处 mac 使用brew

brew cask install java

安装ElasticSearch

brew 安装 

brew install ElasticSearch

终端输入elasticsearch 运行, 浏览器访问127.0.0.1:9200,出现下图,OK安装完成

Elasticsearch 安装及PHP使用详解编程语言

composer 安装引用 elasticsearch

composer.json  require中 加入

"elasticsearch/elasticsearch": "~6.0"

PHP 实现elasticsearch基本操作类

<?php 
use Elasticsearch/ClientBuilder; 
class ES { 
private $client; 
public function __construct(){ 
$ci = get_instance(); 
$params = array( 
'127.0.0.1:9200' 
); 
$this->client = ClientBuilder::create()->setHosts($params)->build(); 
} 
//创建索引 
function createIndex($index_name = 'aki'){ 
$params = [ 
'index' => $index_name, 
'body' => [ 
'settings' => [ 
'number_of_shards' => 5, 
'number_of_replicas' => 0 
] 
] 
]; 
return $this->client->indices()->create($params); 
} 
// 删除索引 
public function delIndex($index_name = 'aki') { 
$params = ['index' => $index_name]; 
return $this->client->indices()->delete($params); 
} 
// 添加文档 
public function addDoc($id,$doc,$index_name = 'aki',$type_name = 'form') { 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'id' => $id, 
'body' => $doc 
]; 
return $this->client->index($params); 
} 
// 判断文档存在 
public function existsDoc($id = 1,$index_name = 'aki',$type_name = 'form') { 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'id' => $id 
]; 
return $this->client->exists($params); 
} 
// 获取文档 
public function getDoc($id = 1,$index_name = 'aki',$type_name = 'form') { 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'id' => $id 
]; 
return $this->client->get($params); 
} 
// 更新文档 
public function updateDoc($id,$doc,$index_name = 'aki',$type_name = 'form') { 
// 可以灵活添加新字段,最好不要乱添加 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'id' => $id, 
'body' => [ 
'doc' =>$doc 
] 
]; 
return $this->client->update($params); 
} 
// 删除文档 
public function delDoc($id,$index_name = 'aki',$type_name = 'form') { 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'id' => $id 
]; 
return $this->client->delete($params); 
}// 查询文档 (分页,排序,权重,过滤) 
public function searchDoc($keywords = "竞赛",$index_name = "aki",$type_name = "form",$sort = [],$from = 0,$size = 10) { 
$params = [ 
'index' => $index_name, 
'type' => $type_name, 
'body' => [ 
'query' => [ 
'bool' => [ 
'should' => [ 
[ 'match' => [ 'title' => [ 
'query' => $keywords, 
'boost' => 3, // 权重大 
]]], 
[ 'match' => [ 'content' => [ 
'query' => $keywords, 
'boost' => 2, 
]]], 
], 
], 
], 
'sort' => ['price'=>['order'=>'desc']] 
, 'from' => $from, 'size' => $size 
] 
]; 
$results = $this->client->search($params); 
//        $maxScore  = $results['hits']['max_score']; 
//        $score = $results['hits']['hits'][0]['_score']; 
//        $doc   = $results['hits']['hits'][0]['_source']; 
return $results['hits']['hits']; 
} 
}

测试使用:

     ll('es');//加载ES类 
$r = $this->es->delIndex(); 
$r = $this->es->createIndex(); 
print_r($r); 
$docs = []; 
$docs[] = ['id'=>1,'title'=>'李白','content'=>'酒仙刺客','price'=>100]; 
$docs[] = ['id'=>2,'title'=>'孙悟空','content'=>'腾云驾雾的辜负了紫霞的刺客。','price'=>300]; 
$docs[] = ['id'=>3,'title'=>'胡歌','content'=>'尽职励志,不错哦。','price'=>1000000]; 
$docs[] = ['id'=>4,'title'=>'王者荣耀','content'=>'游戏就玩王者荣耀。','price'=>998]; 
$docs[] = ['id'=>5,'title'=>'鲁班','content'=>'小短腿,谁都想灭。','price'=>98]; 
$docs[] = ['id'=>6,'title'=>'妲己','content'=>'祸国殃民。','price'=>998]; 
$docs[] = ['id'=>7,'title'=>'吕布','content'=>'方天画戟,后手放大','price'=>2998]; 
$docs[] = ['id'=>8,'title'=>'水晶','content'=>'保护我方水晶,进攻地方水晶。','price'=>19999]; 
foreach ($docs as $k => $v) { 
$this->es->addDoc($v['id'],$v); 
}
     
     $r = $this->es->searchDoc("李白 歌 水");
    
     echo "<pre>";
     print_r($r);
 

输出结果:

Elasticsearch 安装及PHP使用详解编程语言

linux 

java jdk: yum install java-1.8.0-openjdk-devel.x86_64

安装 es  IT虾米网  

注意修改  /etc/security/limits.conf,追加以下内容;
* soft nofile 65536
* hard nofile 65536 后退出终端重新登录

守护进程启动  加  -d  

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/228231.html

(0)
上一篇 2022年1月11日 15:28
下一篇 2022年1月11日 15:28

相关推荐

发表回复

登录后才能评论