3、Laravel5 之搜索引擎elasticsearch扩展Scout

原创
2019/02/13 20:27
阅读数 420

此篇文章来源于网络,和其他laravel使用es的教程一致,自己在某些地方做了备注而已。

 

一、安装Scout

(1)首先,使用 composer 包管理器来安装 Scout,如果没有安装 composer 包管理器,要先安装;接着进入laravel项目的根目录使用composer 命令安装

composer require laravel/scout

 

(2)接下来,你需要将 ScoutServiceProvider 添加到你的 config/app.php 配置文件的 providers 数组中:

Laravel\Scout\ScoutServiceProvider::class,

 

(3)注册好 Scout 的服务提供者之后,你可以使用 vendor:publish Artisan 命令生成 Scout 的配置文件。这个命令会在你的 config 目录下生成 scout.php 配置文件:

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

 

(4)使用 composer安装scout的es驱动:

composer require tamayo/laravel-scout-elastic

备注:安装了次扩展后,会默认安装所需要的依赖扩展,包括elasticsearch官方的php sdk

 

(5)安装完驱动之后,修改config\scout.php配合文件,将驱动修改为elasticsearch

'driver' => env('SCOUT_DRIVER', 'elasticsearch'),

并在下方添加驱动:

'elasticsearch' => [ //laravel54是项目名,可以自定义 
   'index' => env('ELASTICSEARCH_INDEX', 'laravel54'), 
   'hosts' => [ 
       env('ELASTICSEARCH_HOST', 'http://127.0.0.1:9200'), 
   ], 
],

二、创建command命令

(1)使用php artisan创建command命令

php artisan make:command ESInit

 

(2)执行完命令后会创建app\Console\Command\ESInit.php文件,修改ESInit.php

//使用什么命令启动脚本 
protected $signature = 'es:init'; 
//描述 
protected $description = 'init laravel es for post';

 

(3)在app\Console\Kernel.php中挂载

protected $commands = [ \App\Console\Commands\ESInit::class ];

完成之后使用php artisan命令查看命令是否挂载成功

php artisan es:init

 

三、安装guzzlehttp/guzzle 扩展

composer require guzzlehttp/guzzle

配置

(1)修改app\Console\Command\ESInit.php

public function handle()
    {
        //创建template
        $client=new Client();

        $url=config('scout.elasticsearch.hosts')[0]. '/_template/tmp';
        //$client->delete($url);

        $param = [
            'json'=>[
                'template' => config('scout.elasticsearch.index'),
                'mappings' => [
                    '_default_' => [
                        'dynamic_templates' => [
                            [
                                'strings' => [
                                    'match_mapping_type' => 'string',
                                    'mapping' => [
                                        'type' => 'text',
                                        'analyzer' => 'ik_smart',
                                        'fields' => [
                                            'keyword' => [
                                                'type' => 'keyword'
                                            ]
                                        ]
                                    ]
                                ]
                            ]
                        ]
                    ]
                ],
            ],
        ];
        $client->put($url,$param);

        //记录
        $this->info("=======创建模板成功=======");

        //创建index
        $url = config('scout.elasticsearch.hosts')[0] . '/' . config('scout.elasticsearch.index');
        //$client->delete($url);
        $param=[
            'json' => [
                'settings' => [
                    'refresh_interval' => '5s',
                    //'number_of_shards' => 3,  //分片未3个
                    //'number_of_replicas' => 1, //副本为1个
                ],
                'mappings' => [
                    '_default_' => [
                        '_all' => [
                            'enabled' => false
                        ]
                    ]
                ]
            ]
        ];

        $client->put($url,$param);

        //记录
        $this->info("=========创建索引成功=========");
    }

(2)在我的项目中我使用文章数据表来搜索,因此需要修改post.php,也就是posts数据对于的数据模型

use Searchable;

    //定义索引里面的type
    public function searchableAs()
    {
        return "post";
    }

    //定义有哪些字段需要搜索
    public function toSearchableArray()
    {
        return [
            'title'=>$this->title,
            'content'=>$this->content,
        ];
    }

 

四、导入数据

使用php artisan命令导入数据

php artisan scout:import "\App\Post"

导入成功之后我们在浏览器地址输栏入:127.0.0.1:9200/laravel54/post/23(laravel54是elasticsearch驱动定义的项目名,post对象的是我项目的post数据模型,23是某条数据的ID )

五、备注

以上内容来源于其他网友编写,我这里直接copy了过来,使用以上教程是可以正常安装并且使用的,当时存在以下问题:

1、以上方式安装的扩展只适合es6以下(不包括6)的版本,因为es6(及以上)的版本只支持创建一个类型和映射,es7已经完全移除类型和映射概念。

2、scout的功能其实相对简单,扩展性不是很强,但是对于普通业务还是够用了

 

针对上面的情况,我们根据实际情况对这个扩展做了修改,以此来适应我们目前的业务情况,es扩展地址:https://gitee.com/ken.yang/elasticsearch6-for-laravel5,供大家参考学习交流

 

虽然这个修改过的版本,满足了一些业务场景,我们在其他项目中已经抛弃这样的实现方式,而是对es给出的php sdk做自己的封装,因为业务场景的复杂度越来越高,我们需要更多的功能,和更优的实现方式来满足我们的业务。所以每个人应该根据项目的业务复杂度来觉得是不是应该使用第三方扩展,还是直接使用es官方的sdk。甚至使用java,更深入的使用es。

 

3、因为scout默认使用的是同步,当然也可以修改为异步队列(laravel自身),但是某些场景下面其实不会使用laravel的那一套,而是使用我们自己的消息队列系统。

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
0 评论
0 收藏
0
分享
返回顶部
顶部