当前位置: 首页 > news >正文

【ElasticSearch】使用docker compose,通过编写yml安装es8.15和kibana可视化界面操作,go连接es

使用 Docker 安装 Elasticsearch

Docker 搭建 Elasticsearch + Kibana 环境,并在过程中标注常见问题和解决方案。


1. 准备工作

在开始之前,请确认你本地已经安装了:

工具版本建议检查方式
Docker≥ 20.xdocker -v
Docker Compose≥ 2.xdocker compose version

常见问题:

  • 版本过低:老版本 Docker 对内存管理、网络有兼容性问题,建议升级到最新。
  • Windows 用户:建议使用 WSL2 + Docker Desktop,不要用 Hyper-V。

2. 选择 Elasticsearch 版本

建议选择 8.x 稳定版本(例如 8.15.0),因为:

  • 7.x 之后安全功能(TLS、认证)逐渐成为默认配置
  • 新手学习时如果用最新版本,文档和功能对齐度更高

建议镜像:docker.elastic.co/elasticsearch/elasticsearch:8.15.0
官方镜像在 Elastic 仓库,不在 DockerHub。


3. 创建 Docker Compose 配置

新建一个目录,例如 es-docker,然后创建 docker-compose.yml

version: "3.8"
services:elasticsearch:image: docker.elastic.co/elasticsearch/elasticsearch:8.15.0container_name: es01environment:- node.name=es01- cluster.name=es-docker-cluster- discovery.type=single-node- bootstrap.memory_lock=true- ES_JAVA_OPTS=-Xms1g -Xmx1g- xpack.security.enabled=false   # 学习环境可以先关闭安全认证ulimits:memlock:soft: -1hard: -1volumes:- es_data:/usr/share/elasticsearch/data# 将容器内分词器配置同步到宿主机,方便修改保存- ./ik-config:/usr/share/elasticsearch/config/analysis-ikports:- 9200:9200- 9300:9300kibana:image: docker.elastic.co/kibana/kibana:8.15.0container_name: kib01environment:- ELASTICSEARCH_HOSTS=http://es01:9200ports:- 5601:5601depends_on:- elasticsearchvolumes:es_data:driver: local

4. 配置详解

配置项作用注意事项
discovery.type=single-node单节点模式必须加,否则容器会一直等待集群发现
bootstrap.memory_lock=true锁定内存避免 swap 导致性能下降
ES_JAVA_OPTS=-Xms1g -Xmx1gJVM 内存初学者建议 1g,不要设置超过 Docker 可用内存
xpack.security.enabled=false关闭安全认证学习时可关掉,否则要处理证书和密码

常见问题:

  1. 内存不足容器无法启动

    • 解决:在 Docker Desktop 设置里调大内存(至少 2GB 给 ES)
  2. 安全认证卡住(出现 bootstrap check failure

    • 解决:确认已加 xpack.security.enabled=false
  3. Kibana 无法连上 ES

    • 解决:确认 ELASTICSEARCH_HOSTS=http://es01:9200 配置正确

5. 启动服务

es-docker 目录执行:

docker compose up -d

检查容器状态:

docker ps

看到类似输出说明启动成功:

CONTAINER ID   IMAGE                                                  COMMAND                  STATUS          PORTS
abc123         docker.elastic.co/elasticsearch/elasticsearch:8.15.0   "/bin/tini -- /usr/l…"   Up 2 minutes    0.0.0.0:9200->9200/tcp
def456         docker.elastic.co/kibana/kibana:8.15.0                 "/bin/tini -- /usr/l…"   Up 2 minutes    0.0.0.0:5601->5601/tcp

6. 验证 Elasticsearch

在浏览器访问:

  • Elasticsearch: http://localhost:9200
    你应该看到类似:

    {"name" : "es01","cluster_name" : "es-docker-cluster","cluster_uuid" : "xxxx","version" : {"number" : "8.15.0"},"tagline" : "You Know, for Search"
    }
    
  • Kibana: http://localhost:5601

如果 Kibana 页面空白或报错:等 1-2 分钟,它需要时间初始化。


7. 学习建议

安装好之后,你可以:

  1. 基础操作

    curl -X GET "localhost:9200/_cat/indices?v"
    curl -X PUT "localhost:9200/test_index"
    curl -X POST "localhost:9200/test_index/_doc/1" -H 'Content-Type: application/json' -d '{"name":"Alice"}'
    curl -X GET "localhost:9200/test_index/_search?q=name:Alice"
    
  2. 使用 Kibana Dev Tools

    • 打开 http://localhost:5601/app/dev_tools#/console
    • 在左侧输入 DSL 查询,右侧返回结果,体验比 curl 友好。

8. 常见问题汇总(FAQ)

问题原因解决办法
容器一直重启内存不足调大 Docker 内存
max virtual memory areas vm.max_map_count [65530] is too lowLinux 内核参数限制sudo sysctl -w vm.max_map_count=262144
Kibana 502 错误ES 未启动好先等 1-2 分钟,确认 ES 9200 可访问
Windows 下访问不了WSL2 网络配置访问 localhost 而不是虚拟机 IP

Go 语言连接 Docker 中的 Elasticsearch

1. 安装依赖

Elastic 官方提供 Go 客户端:
github.com/elastic/go-elasticsearch/v8

执行:

go get github.com/elastic/go-elasticsearch/v8

2. 编写示例代码

新建一个文件 main.go

package mainimport ("bytes""context""encoding/json""fmt""log""strings"elasticsearch "github.com/elastic/go-elasticsearch/v8"
)// 定义一个简单的文档结构
type User struct {Name string `json:"name"`Age  int    `json:"age"`
}func main() {// 1. 配置 ES 客户端cfg := elasticsearch.Config{Addresses: []string{"http://192.168.132.131:9200", // 连接 Docker 里的 ES},// 如果你开启了 xpack.security.enabled=true,需要在这里配置用户名密码// Username: "elastic",// Password: "your_password",}es, err := elasticsearch.NewClient(cfg)if err != nil {log.Fatalf("创建客户端失败: %s", err)}// 2. Ping 一下,确认连接成功res, err := es.Info()if err != nil {log.Fatalf("连接 ES 失败: %s", err)}defer res.Body.Close()fmt.Println("已连接到 Elasticsearch:", res)// 3. 插入一条文档user := User{Name: "Alice", Age: 25}doc, _ := json.Marshal(user)res, err = es.Index("users",                           // 索引名(如果不存在会自动创建)bytes.NewReader(doc),              // 文档内容es.Index.WithDocumentID("1"),      // 指定 ID = 1es.Index.WithContext(context.Background()),)if err != nil {log.Fatalf("写入文档失败: %s", err)}defer res.Body.Close()fmt.Println("文档写入成功")// 4. 搜索文档query := `{"query": {"match": {"name": "Alice"}}}`res, err = es.Search(es.Search.WithContext(context.Background()),es.Search.WithIndex("users"),              // 查询的索引es.Search.WithBody(strings.NewReader(query)),es.Search.WithPretty(),)if err != nil {log.Fatalf("搜索失败: %s", err)}defer res.Body.Close()var result map[string]interface{}if err := json.NewDecoder(res.Body).Decode(&result); err != nil {log.Fatalf("解析响应失败: %s", err)}// 打印搜索结果fmt.Println("搜索结果:")hits := result["hits"].(map[string]interface{})["hits"].([]interface{})for _, hit := range hits {doc := hit.(map[string]interface{})source := doc["_source"].(map[string]interface{})fmt.Printf("ID=%s, Name=%s, Age=%.0f\n", doc["_id"], source["name"], source["age"])}
}

3. 运行测试

确保 Docker 里的 Elasticsearch 已经启动 (9200 端口可访问)。
然后运行:

go run main.go

你应该能看到类似输出:

已连接到 Elasticsearch: ...
文档写入成功
搜索结果:
ID=1, Name=Alice, Age=25

4. 常见问题(Go 端)

问题原因解决方法
connection refusedDocker 里的 ES 没启动 / 端口没映射检查 docker ps,确认 9200 端口暴露出来
security_exception你没关闭安全认证在 docker-compose 里加 xpack.security.enabled=false 或配置用户名密码
index_not_found_exception查询的索引不存在先写入文档,ES 会自动创建索引

http://www.dtcms.com/a/343693.html

相关文章:

  • 为什么需要关注Flink并行度?
  • 使用 Apache Flink CDC 3.0 实现 MySQL 到 Elasticsearch 的数据同步
  • 回归测试的重要性与实践指南
  • 十年磨一剑!Apache Hive 性能优化演进全史(2013 - )
  • Ubuntu部署K8S集群
  • unistd.h 常用函数速查表
  • 论文精读(三)|智能合约漏洞检测技术综述
  • 《WINDOWS 环境下32位汇编语言程序设计》第7章 图形操作(1)
  • Redis内存架构解析与性能优化实战
  • 通用的嵌入式 Linux 系统镜像制作流程
  • STM32F103RC的USB上拉电阻1.5K
  • MongoDB 从入门到实践:全面掌握文档型 NoSQL 数据库核心操作
  • 基于Node.js服务端的社区报修管理系统/基于express的在线报修管理系统
  • (论文速读)RandAR:突破传统限制的随机顺序图像自回归生成模型
  • 基于C#的宠物医院管理系统/基于asp.net的宠物医院管理系统
  • 开源 python 应用 开发(十)音频压缩
  • AI时代的“双刃剑”:效率革命与人文焦虑的碰撞
  • week3-[二维数组]小方块
  • 靶机 - SAR
  • UVa1472/LA4980 Hanging Hats
  • C++的指针和引用:
  • C++部署Yolov5模型流程记录
  • flutter geolocator Android国内定位失败问题解决
  • Redis事务全解析:从秒杀案例看原子操作实现
  • C#_接口设计:角色与契约的分离
  • 【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day10
  • 树莓派采集、计算机推理:基于GStreamer的YOLOv5实现方案
  • Codeforces Round 1043 (Div.3)
  • AI生成技术报告:GaussDB与openGauss的HTAP功能全面对比
  • Vue 插槽(Slots)全解析2