php7使用elasticsearchphp
1、安裝java
官網下載地址:https://www.elastic.co/downloads/elasticsearchmysql
# 解壓到非root目錄,運行時使用非root帳號且必須安裝java環境sql
yum install javaapache
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.2.3.tar.gzjson
tar zxvf elasticsearch-6.2.3.tar.gzapi
useradd elasticsearchphp7
password elasticsearchapp
chown elasticsearch:elasticsearch elasticsearch-6.2.3composer
cd elasticsearch-6.2.3
nohup ./bin/elasticsearch & #設置成常駐進程
# php擴展庫引入 composer.json
{ "require": { // ... "elasticsearch/elasticsearch": "~6.0" // ... } }
# 測試數據導入
create table articles(
id int not null primary key auto_increment,
title varchar(200) not null comment '標題',
content text comment '內容'
);
insert into articles(title, content) values ('Laravel 測試1', '個人寶馬多少馬力'),
('個人寶馬發動機多少', '個人保時捷馬力不錯'),
('Laravel 測試3', '個人寶馬發動機多少');
二、api使用
<?php // +---------------------------------------------------------------------- // | ThinkCMF [ WE CAN DO IT MORE SIMPLE ] // +---------------------------------------------------------------------- // | Copyright (c) 2013-2018 http://www.thinkcmf.com All rights reserved. // +---------------------------------------------------------------------- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) // +---------------------------------------------------------------------- // | Author: 老貓 <zxxjjforever@163.com> // +---------------------------------------------------------------------- namespace app\admin\controller; use cmf\controller\AdminBaseController; use think\Db; use Elasticsearch\ClientBuilder; /* author@zhou * 功能:分詞系統 * return */ class ElasticController extends AdminBaseController { /* author@zhou * 功能:生成索引 * return */ public function index(){ try { $db = new \PDO('mysql:host=127.0.0.1;dbname=thinkcmf5', 'root', 'd1560a683a5e0d82'); $sql = 'select * from articles'; $query = $db->prepare($sql); $query->execute(); $lists = $query->fetchAll(); print_r($lists); } catch (Exception $e) { echo $e->getMessage(); } $client = ClientBuilder::create()->build(); foreach ($lists as $row) { $params = [ 'body' => [ 'id' => $row['id'], 'title' => $row['title'], 'content' => $row['content'] ], 'id' => 'article_' . $row['id'], 'index' => 'articles_index', 'type' => 'articles_type' ]; $client->index($params); } } /* author@zhou * 功能:獲取索引 * return */ public function getIndex(){ $client = ClientBuilder::create()->build(); $params = [ 'index' => 'articles_index', 'type' => 'articles_type', 'id' => 'article_1' ]; $res = $client->get($params); print_r($res); } /* author@zhou * 功能:從索引中刪除文檔 * return */ public function delIndex(){ $client = ClientBuilder::create()->build(); $params = [ 'index' => 'articles_index', 'type' => 'articles_type', 'id' => 'article_1' ]; $res = $client->delete($params); print_r($res); } /* author@zhou * 功能:設置索引 * return */ public function createIndex(){ $client = ClientBuilder::create()->build(); $params['index'] = 'articles_index'; $params['body']['settings']['number_of_shards'] = 2; $params['body']['settings']['number_of_replicas'] = 0; $client->indices()->create($params); } /* author@zhou * 功能:查詢條件 * return */ public function search(){ $client = ClientBuilder::create()->build(); $params = [ 'index' => 'articles_index', 'type' => 'articles_type', ]; //多字段匹配 // $params['body']['query']['multi_match']['query'] = '個人寶馬發動機多少'; // $params['body']['query']['multi_match']['fields'] = ["title","content"]; // $params['body']['query']['multi_match']['type'] ="most_fields"; // most_fields 多字段匹配度更高 best_fields 徹底匹配佔比更高 // // //單個字段匹配 // $params['body']['query']['match']['content'] = '個人寶馬多少馬力'; //徹底匹配 // $params['body']['query']['match_phrase']['content'] = '個人寶馬多少馬力'; //聯合搜索 must,should,must_not $params['body']['query']["bool"]['must']["match"]['content'] = "寶馬"; $params['body']['query']["bool"]['must_not']["match"]['title'] = "寶馬"; $res = $client->search($params); print_r($res); } }