博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Laravel中利用Scout集成Elasticsearch搜索引擎
阅读量:4293 次
发布时间:2019-05-27

本文共 2329 字,大约阅读时间需要 7 分钟。

写在前面

Elasticsearch(以下简称es)是一个实时的分布式搜索和分析引擎。

在搜索引擎方面,不仅仅有Elasticsearch,像另一篇提到的Algolia,还有sphinx、Solr等等,这里不做评价和比较,本篇主要介绍laravel中如何使用Elasticsearch。

首选必须安装有Elasticsearch,请参考  。

本文基于laravel5.5,其他版本大同小异。

准备工作

通过composer安装依赖包

composer require laravel/scoutcomposer require tamayo/laravel-scout-elastic

基本配置

在config/app.php文件中的providers数组中加入服务提供者

// config/app.php'providers' => [    // ...    Laravel\Scout\ScoutServiceProvider::class,    // ...    ScoutEngines\Elasticsearch\ElasticsearchProvider::class,],

使用以下命令生成scout配置文件

php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"

在config/scout.php中加入elasticsearch的配置

'elasticsearch' => [        'index' => env('ELASTICSEARCH_INDEX', 'laravel'),        'hosts' => [            env('ELASTICSEARCH_HOST', 'http://localhost:9200'),        ],    ],

然后我们打开.env文件,加入scout和elasticsearch的配置

# scout配置SCOUT_DRIVER=elasticsearchSCOUT_PREFIX=# elasticsearch 配置ELASTICSEARCH_INDEX=esdemo# elasticsearch 地址ELASTICSEARCH_HOST=http://172.30.6.1:9200

创建索引

创建模型并填充数据

创建模型app/Student.php,为方便后续测试,请先建表和填充数据,可以手动使用sql语句添加数据,也使用laravel自动的数据迁移和填充,可以参考 

toArray(); // Customize array... return $array; }}

把所有现有记录导入到搜索索引里

php artisan scout:import "App\Student"

是不是导入成功了呢?

php artisan scout:import "App\Student"Imported [App\Student] models up to ID: 500Imported [App\Student] models up to ID: 1000Imported [App\Student] models up to ID: 1500Imported [App\Student] models up to ID: 2000Imported [App\Student] models up to ID: 2500Imported [App\Student] models up to ID: 3000Imported [App\Student] models up to ID: 3500Imported [App\Student] models up to ID: 4000Imported [App\Student] models up to ID: 4500Imported [App\Student] models up to ID: 5000Imported [App\Student] models up to ID: 5500Imported [App\Student] models up to ID: 6000Imported [App\Student] models up to ID: 6500Imported [App\Student] models up to ID: 7000Imported [App\Student] models up to ID: 7500Imported [App\Student] models up to ID: 8000Imported [App\Student] models up to ID: 8500Imported [App\Student] models up to ID: 9000Imported [App\Student] models up to ID: 9500Imported [App\Student] models up to ID: 10000All [App\Student] records have been imported.

我们访问es,

是不是已经有了刚刚导入的students_index索引数据

大功告成

$studens = App\Student::search('成燕')->get();dd($studens);

可以填充个百万条数据试试,检索速度,是不是比直接查询数据库要快很多呢?

转载地址:http://dmuws.baihongyu.com/

你可能感兴趣的文章
ES相关度评分
查看>>
我们一起做一个可以商用的springboot脚手架
查看>>
idea在搭建ssm框架时mybatis整合问题 无法找到mapper
查看>>
java设计基本原则----单一职责原则
查看>>
HashMap的实现
查看>>
互斥锁 synchronized分析
查看>>
java等待-通知机制 synchronized和waity()的使用实践
查看>>
win10 Docke安装mysql8.0
查看>>
docker 启动已经停止的容器
查看>>
order by 排序原理及性能优化
查看>>
Lock重入锁
查看>>
docker安装 rabbitMq
查看>>
git 常用命令 入门
查看>>
linux安装docker
查看>>
关闭selinx nginx无法使用代理
查看>>
shell 脚本部署项目
查看>>
spring cloud zuul网关上传大文件
查看>>
springboot+mybatis日志显示SQL
查看>>
工作流中文乱码问题解决
查看>>
maven打包本地依赖包
查看>>