0、引言
最近公司相关业务碰到瓶颈,只依赖基于Redis + Mysql的架构,不能满足业务需求,结合Elasticsearch重新设计。奈何相关文档搜索起来很是费力,很是分散,所以自己把开发过程中遇到的问题,总结一下,共同学习。
1、开发环境
- MacOS
- PHP 7.4
- Elasticsearch 7.4.0(阿里云)
- Elasticsearch-PHP 7.6
- Laravel 7.4.0
因为服务是直接购置阿里云的,所以就没有本地搭建Elasticsearch。
不啰嗦了,直接跳过Elasticsearch安装 和 Composer安装和教程
2、安装 Elasticsearch-PHP
2.1 新项目,创建/找到composer.json,并加入以下代码,运行composer install
{
"require": {
"elasticsearch/elasticsearch"
}
}
2.2 已有项目,直接运行 composer require elasticsearch/elasticsearch
这个步骤有可能报错,权限问题比较常见。
3、配置
3.1 配置信息
require 'vendor/autoload.php';
use Elasticsearch\ClientBuilder;
$hosts = [
'192.168.1.1:9200', // IP + 端口
'192.168.1.2', // 仅 IP
'mydomain.server.com:9201', // 域名 + 端口
'mydomain2.server.com', // 仅域名
'https://localhost', // 对 localhost 使用 SSL
'https://192.168.1.3:9200' // 对 IP + 端口 使用 SSL
];
$client = ClientBuilder::create() // 实例化 ClientBuilder
->setHosts($hosts) // 设置主机信息
->build(); // 构建客户端对象
//实际配置并不会使用到这么多,
//1,IP/域名 + 端口 是必须的
//2,如果你的实例访问地址开启了https验证就是 对 IP/域名 + 端口 使用 SSL
$hosts = ['URL:PORT'];
//3,如果你的实例需要进行账号和密码验证则使用这种格式
$hosts = ['USER:PASSWORD@URL:PORT'];
$hosts = ['admin:123456@192.168.1.1:9200'];
3.2 常见问题
a. missing authentication credentials for REST request
没有添加验证
解决方法 : 使用这种方式初始化 USER:PASSWORD@URL:PORT
4、调试
//创建一个索引
$hosts = ['USER:PASSWORD@URL:PORT'];
$client = ClientBuilder::create()->setHosts($hosts)->build();
$params = [
'index' => 'my_index'
];
// Create the index
$response = $client->indices()->create($params);
5、其他的具体方法及详解会慢慢更新