Ubuntu22.04搭建PHP与Elasticsearch教程
想要在Ubuntu 22.04上集成PHP与Elasticsearch?本教程为你提供详细步骤,助你轻松配置。首先,我们将安装并启动Elasticsearch,配置必要的网络参数,并通过curl命令验证服务是否正常运行。紧接着,我们将搭建PHP环境,包括安装Apache2、PHP及常用扩展,确保PHP能够正常解析。然后,我们将使用Composer安装Elasticsearch PHP客户端库,简化与Elasticsearch集群的交互。最后,我们将编写PHP脚本,连接Elasticsearch并获取集群信息,验证配置是否成功。此外,我们还将介绍如何启用密码认证,增强Elasticsearch实例的安全性。无论你遇到连接问题还是搜索请求失败,本文都能为你提供清晰的指导,助你成功完成PHP与Elasticsearch的集成。
首先安装并启动Elasticsearch,再配置PHP环境与客户端库,最后通过PHP脚本测试连接。具体步骤:1. 更新系统并安装OpenJDK;2. 导入Elasticsearch GPG密钥并添加官方仓库;3. 安装Elasticsearch并配置network.host和http.port;4. 启动服务并用curl测试;5. 安装Apache2、PHP及扩展;6. 重启Apache并验证PHP页面;7. 在网站根目录使用Composer安装elasticsearch/elasticsearch包;8. 创建test_es.php文件,引入autoload并实例化ClientBuilder连接本地ES;9. 浏览器访问该文件,输出集群信息即表示成功;10. 可选启用密码认证并更新PHP连接参数包含用户名密码。

如果您尝试在Ubuntu 22.04上配置PHP与Elasticsearch集成,但无法建立连接或执行搜索请求,则可能是由于环境未正确安装或服务未启用。以下是完成此集成的详细步骤:
一、安装并配置Elasticsearch
Elasticsearch 是一个基于 Lucene 的分布式搜索和分析引擎,需先在系统中正确安装并运行。
1、更新系统包列表以确保获取最新版本信息:sudo apt update。
2、安装 Java OpenJDK,因为 Elasticsearch 依赖于 Java 运行环境:sudo apt install openjdk-17-jre -y。
3、导入 Elasticsearch GPG 密钥以验证软件包真实性:wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo gpg --dearmor -o /usr/share/keyrings/elasticsearch-keyring.gpg。
4、添加 Elasticsearch 官方 APT 仓库到系统源列表:echo "deb [signed-by=/usr/share/keyrings/elasticsearch-keyring.gpg] https://artifacts.elastic.co/packages/8.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elastic-8.x.list。
5、再次更新包管理器缓存:sudo apt update。
6、安装 Elasticsearch 服务:sudo apt install elasticsearch -y。
7、编辑主配置文件以设置网络访问权限:sudo nano /etc/elasticsearch/elasticsearch.yml,确保包含以下两行:
network.host: 0.0.0.0
http.port: 9200
8、启动 Elasticsearch 服务并设置开机自启:sudo systemctl start elasticsearch && sudo systemctl enable elasticsearch。
9、等待一分钟让服务初始化后,通过命令测试是否正常运行:curl -X GET "http://localhost:9200/",应返回包含 cluster_name 和 version 信息的 JSON 响应。
二、安装并配置PHP环境
PHP 是用于开发 Web 应用的脚本语言,需要搭配 Web 服务器和扩展支持才能与 Elasticsearch 通信。
1、安装 Apache2 作为 Web 服务器:sudo apt install apache2 -y。
2、安装 PHP 及常用扩展,包括 cURL(用于 HTTP 请求):sudo apt install php libapache2-mod-php php-curl -y。
3、重启 Apache 服务以加载 PHP 模块:sudo systemctl restart apache2。
4、创建测试页面验证 PHP 是否工作:echo "" | sudo tee /var/www/html/info.php。
5、在浏览器中访问 http://your_server_ip/info.php,确认 PHP 信息页面成功显示。
三、安装PHP客户端库(Elasticsearch PHP SDK)
使用官方提供的 PHP 客户端可以简化与 Elasticsearch 集群的交互过程。
1、切换到网站根目录准备下载依赖:cd /var/www/html。
2、确保已安装 Composer(PHP 的依赖管理工具):sudo apt install composer -y。
3、在当前目录下初始化项目并添加 elasticsearch/elasticsearch 包:sudo composer require elasticsearch/elasticsearch。
4、检查 vendor 目录是否存在且包含 autoload.php 文件,该文件将用于引入客户端类。
四、编写PHP代码连接Elasticsearch
通过 PHP 脚本实例化客户端并发送请求,验证与 Elasticsearch 的连通性。
1、创建一个新的 PHP 文件用于测试连接:sudo nano /var/www/html/test_es.php。
2、插入以下内容,注意替换实际的主机地址:
require 'vendor/autoload.php';
use Elasticsearch\ClientBuilder;
$hosts = ['http://localhost:9200']; // 可添加多个节点
$client = ClientBuilder::create()->setHosts($hosts)->build();
$params = [];
$response = $client->info($params);
print_r($response);
?>
3、保存文件并在终端赋予适当权限:sudo chown www-data:www-data /var/www/html/test_es.php。
4、在浏览器中访问 http://your_server_ip/test_es.php,若输出包含 cluster_name、version 等字段,则表示连接成功。
五、配置安全认证(可选但推荐)
为防止未授权访问,建议启用身份验证机制保护 Elasticsearch 实例。
1、运行内置工具设置内置用户密码:sudo /usr/share/elasticsearch/bin/elasticsearch-setup-passwords auto 或手动模式 interactive。
2、记录生成的 elastic 用户密码,后续将在 PHP 中使用。
3、修改 PHP 客户端连接参数以包含用户名和密码:
$client = ClientBuilder::create()
->setHosts(['http://localhost:9200'])
->setBasicAuthentication('elastic', 'your_password_here')
->build();
4、重新运行 test_es.php 脚本,确认仍能正常获取集群信息。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
Win8屏幕保护设置方法详解
- 上一篇
- Win8屏幕保护设置方法详解
- 下一篇
- 花瓣测速怎么测视频速度?在线诊断教程
-
- 文章 · php教程 | 19小时前 | 面向对象 · PHP · PHP8.4 · Property Hooks · 代码重构 · PHP教程 Getter PHP 8.4 Property Hooks setter
- PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里
- 464浏览 收藏
-
- 文章 · php教程 | 1星期前 | WEB开发 · 登录状态 · Cookie · PHP · session · session_start · php cookie session session_start PHPSESSID 登录态丢失
- PHP Session 登录态突然丢失怎么办:从 Cookie 到 session_start 一步步排查
- 196浏览 收藏
-
- 文章 · php教程 | 1星期前 | PHP · MD5 · 登录安全 · password_hash · password_verify · password_hash password_verify 登录安全 PHP密码迁移 MD5迁移
- PHP 旧 MD5 密码如何平滑迁移到 password_hash:兼容登录与自动升级完整流程
- 174浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 2573次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 2379次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 2320次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2529次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2510次使用
-
- 宝塔配置Ruby环境:RVM+Nginx反代教程
- 2026-05-29 501浏览
-
- unset函数作用范围详解
- 2026-05-29 501浏览
-
- VS Code配置Xdebug教程:PHP调试技巧全解析
- 2026-05-13 501浏览
-
- PHPEnv安装PhpMyAdmin教程详解
- 2026-05-07 501浏览
-
- TelegramBotWebApp数据验证技巧
- 2026-05-06 501浏览

