
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像基于OpenSearch官方镜像构建,预装了analysis-icu插件,专注于提供国际化文本分析能力。analysis-icu插件基于ICU(International Components for Unicode)库开发,支持多语言分词、字符规范化、Unicode文本处理等高级功能,适用于需要处理多语言内容的搜索场景,可直接部署使用,无需额外手动安装插件。
快速启动容器
bashdocker run -d \ --name opensearch-icu \ -p 9200:9200 \ -p 9600:9600 \ -e "discovery.type=single-node" \ -e "OPENSEARCH_JAVA_OPTS=-Xms512m -Xmx512m" \ opensearchproject/opensearch:latest
说明:默认情况下,容器会自动加载
analysis-icu插件,无需额外配置
验证插件安装
容器启动后,可通过以下命令验证analysis-icu插件是否加载成功:
bashcurl -X GET "http://localhost:9200/_cat/plugins?v"
预期输出应包含analysis-icu插件信息,例如:
name component version opensearch-node-1 analysis-icu 2.11.0
通过环境变量自定义配置
支持通过环境变量配置OpenSearch核心参数,常用环境变量:
| 环境变量 | 说明 | 默认值 |
|---|---|---|
discovery.type | 节点发现类型 | multi-node |
cluster.name | 集群名称 | docker-cluster |
node.name | 节点名称 | 容器ID |
OPENSEARCH_JAVA_OPTS | JVM参数配置 | -Xms1g -Xmx1g |
network.host | 网络绑定地址 | 0.0.0.0 |
示例:配置单节点模式与自定义JVM内存
bashdocker run -d \ --name opensearch-icu \ -p 9200:9200 \ -p 9600:9600 \ -e "discovery.type=single-node" \ -e "OPENSEARCH_JAVA_OPTS=-Xms2g -Xmx2g" \ -e "cluster.name=multilingual-search" \ opensearchproject/opensearch:latest
挂载自定义配置文件
如需自定义OpenSearch配置(如自定义分词器),可通过挂载配置文件实现:
./config/opensearch.yml):yamlcluster.name: multilingual-search node.name: opensearch-icu-node-1 discovery.type: single-node plugins: analysis: icu: enabled: true # 确保插件启用(默认已启用)
bashdocker run -d \ --name opensearch-icu \ -p 9200:9200 \ -p 9600:9600 \ -v $(pwd)/config/opensearch.yml:/usr/share/opensearch/config/opensearch.yml \ opensearchproject/opensearch:latest
单节点部署配置
yamlversion: '3.8' services: opensearch-icu: image: opensearchproject/opensearch:latest container_name: opensearch-icu environment: - discovery.type=single-node - OPENSEARCH_JAVA_OPTS=-Xms1g -Xmx1g - cluster.name=multilingual-cluster ports: - "9200:9200" # REST API端口 - "9600:9600" # 性能分析端口 volumes: - opensearch-data:/usr/share/opensearch/data # 数据持久化 networks: - opensearch-net volumes: opensearch-data: networks: opensearch-net:
通过OpenSearch API创建使用analysis-icu插件的自定义索引:
bashcurl -X PUT "http://localhost:9200/multilingual-index" -H "Content-Type: application/json" -d ' { "settings": { "analysis": { "analyzer": { "icu_custom_analyzer": { "type": "custom", "tokenizer": "icu_tokenizer", # 使用ICU分词器 "filter": ["icu_folding", "lowercase"] # 使用ICU折叠过滤器和小写过滤器 } } } }, "mappings": { "properties": { "content": { "type": "text", "analyzer": "icu_custom_analyzer" # 字段使用自定义分析器 } } } }'
OPENSEARCH_SECURITY_ENABLED=true开启OPENSEARCH_JAVA_OPTS),建议最小2GBopensearch-data)以防止数据丢失2.11.0、latest等)注:具体版本信息可通过镜像标签指定,如
opensearchproject/opensearch:2.11.0表示基于OpenSearch 2.11.0构建的镜像
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务