0

0

composer怎么安装Elasticsearch客户端_composer引入官方SDK与配置【实操】

尼克

尼克

发布时间:2025-12-27 07:25:27

|

636人浏览过

|

来源于php中文网

原创

能直接装,但需PHP与ES服务端版本匹配:v8.x SDK要求PHP≥8.0且仅兼容ES 8.x,需先用php -v和curl检查版本;实例化必须用ClientBuilder::create()->setHosts(['http://localhost:9200'])->setSSLVerification(false)->build(),不可new Elasticsearch\Client。

composer怎么安装elasticsearch客户端_composer引入官方sdk与配置【实操】

composer require elasticsearch/elasticsearch 能直接装吗

能,但得看 PHP 版本和 Elasticsearch 服务端版本是否匹配。官方 SDK elasticsearch/elasticsearch 的每个大版本只兼容特定范围的 ES 服务端(比如 v8.x SDK 默认只连 ES 8.x,不兼容 7.x),且要求 PHP ≥ 8.0(v8.x SDK)或 ≥ 7.4(v7.x SDK)。
执行前先确认:

  • 运行 php -v 查 PHP 版本
  • 运行 curl -X GET 'http://localhost:9200/' 看 ES 返回的 version.number
再选对应 SDK 版本,否则装完初始化 client 就报 BadMethodCallException 或连接后返回 406 Not Acceptable

如何用 composer 引入并实例化 Elasticsearch 客户端

推荐使用 v8.x SDK(对应 ES 8.x),安装命令:

composer require elasticsearch/elasticsearch:^8.0

PHP 中初始化 client 示例(注意:ES 8.x 默认启用 HTTPS + Basic Auth,本地开发若用 HTTP 且无认证,必须显式关闭 SSL 验证):

$client = \Elasticsearch\ClientBuilder::create()
    ->setHosts(['http://localhost:9200'])
    ->setSSLVerification(false)  // 开发环境必需,否则报 cURL error 60
    ->build();

关键点:

PictoGraphic
PictoGraphic

AI驱动的矢量插图库和插图生成平台

下载
  • setHosts() 必须传数组,即使只有一个地址
  • setSSLVerification(false) 在 HTTP 环境下漏掉会卡在连接阶段
  • 不要手动 new Elasticsearch\Client,必须用 ClientBuilder

为什么 new Client() 报 Class 'Elasticsearch\Client' not found

因为官方 SDK v7.4+ 已移除直接构造 Elasticsearch\Client 的方式,类名已改为 Elasticsearch\ClientBuilder,且整个命名空间结构变了。
常见错误写法:

  • new \Elasticsearch\Client() → 错,类不存在
  • use Elasticsearch\Client; → 错,该类已被删除
  • 没加 require 'vendor/autoload.php'; → 错,自动加载没触发
正确路径只有:引入 autoload → 用 ClientBuilder::create()build()

配置连接超时、重试、日志等实用参数

ClientBuilder 支持链式配置,常用选项有:

$client = \Elasticsearch\ClientBuilder::create()
    ->setHosts(['http://localhost:9200'])
    ->setSSLVerification(false)
    ->setRetries(2)                    // 连接失败时重试 2 次
    ->setConnectionPool(
        \Elasticsearch\ConnectionPool\StaticConnectionPool::class,
        ['connections' => [['host' => 'localhost', 'port' => 9200]]]
    )
    ->setLogger(new \Monolog\Logger('es')) // 需额外 require monolog/monolog
    ->build();

注意:

  • setRetries() 不影响请求级失败(如文档不存在),只对网络层断连有效
  • setLogger() 需提前 composer require monolog/monolog,否则报 class not found
  • 生产环境务必删掉 setSSLVerification(false),改用证书路径或系统 CA
ES 客户端本身不处理索引生命周期或 DSL 语法校验,这些得靠你代码里控制——容易被忽略的是,哪怕最简单的 $client->info() 调用,如果 host 写错或端口不通,也会直接抛出 Exception 而非返回 false。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

152

2023.12.25

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

440

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

178

2023.10.30

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

469

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

13

2025.12.06

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

417

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

418

2023.11.14

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号