Docker启动Coco AI Server后,如何访问内置Easysearch?

使用 Docker 启动 Coco AI 的时候会自带一个 Easysearch,我们使用连接器连接外部数据源的时候,就会把这个数据解析到 Easysearch 里。

但是默认的话,容器不会把这个 Easysearch 的端口映射出来,那就需要我们自己做些小的技巧:在官网的命令上修改一下,把 9200 端口先映射出来。

启动命令如下:

bash 复制代码
docker run -d --name cocoserver \
  -p 9000:9000 \
  -p 9200:9200 \
  -v coco_data_vol:/app/easysearch/data \
  -v coco_config_vol:/app/easysearch/config \
  -v coco_logs_vol:/app/easysearch/logs \
  infinilabs/coco:0.10.0-2678

启动之后,可以使用 netstat 看到容器端口的情况。换句话说,这个自带的 Easysearch 把 92009300 的端口确实启动起来了,但默认只绑定在 127.0.0.1 上,所以外部访问不到------即使你已经加了 -p 9200 也不行。

bash 复制代码
docker exec -it cocoserver sh -lc "netstat -lnt | egrep ':9000|:9200|:9300' || true"
text 复制代码
tcp6       0      0 127.0.0.1:9200          :::*                    LISTEN     
tcp6       0      0 127.0.0.1:9300          :::*                    LISTEN     
tcp6       0      0 :::9000                 :::*                    LISTEN     

因为这部分是 easysearch.yml 控制的,所以我们可以直接通过命令更改,就使用 sed 替换吧。使用之前最好确认 Coco Server 进程已经起来了,防止不必要的问题。

bash 复制代码
docker exec -it cocoserver bash -lc '
CFG=/app/easysearch/config/easysearch.yml
cp -a "$CFG" "$CFG.bak.$(date +%Y%m%d%H%M%S)"
sed -i "s/^network\.host:\s*127\.0\.0\.1/network.host: 0.0.0.0/" "$CFG"
grep -n "^network\.host:" "$CFG"
'

然后重启服务,就能通过 https://IP:9200 的方式访问 cocoserver 自带的 Easysearch 了。

bash 复制代码
docker restart cocoserver

这个时候我们再看端口的占用情况,已经开了外网访问(9200/9300 不再是 127.0.0.1,而是对外监听了)。

bash 复制代码
(base) lzcbox-029c588e ~ # docker exec -it cocoserver sh -lc "netstat -lnt | egrep ':9000|:9200|:9300' || true"
text 复制代码
tcp6       0      0 :::9300                 :::*                    LISTEN     
tcp6       0      0 :::9200                 :::*                    LISTEN     
tcp6       0      0 :::9000                 :::*                    LISTEN    

Easysearch 的进程会先起来,Coco Sever 会慢一些。这时候可以通过 http://ip:9000 访问 Coco Server,也可以通过 https://IP:9200 访问 Easysearch 和 Easysearch 的 UI。密码还是老样子去 log 里找。

可以直接从 log 里把 curl 示例过滤出来,一般会直接告诉你默认账号密码:

bash 复制代码
pg-docker logs cocoserver 2>&1 | egrep -i "curl" | tail -n 50

输出里会有类似这一行(账号通常是 admin,密码就是那串 Coco-Server-xxxx==):

bash 复制代码
curl -ku 'admin:Coco-Server-6dsxtGXhD+MUNhPBKf1hug==' https://localhost:9200

如果你是从宿主机访问,把 localhost 换成你的 IP127.0.0.1 就行:

bash 复制代码
curl -k -u 'admin:Coco-Server-6dsxtGXhD+MUNhPBKf1hug==' https://127.0.0.1:9200

然后我们就收获了一台可以在 Coco server 里使用的 Easysearch,可以实时查看数据。

平时用 API 写进去的数据还能被 Coco Server 索引,自带 UI 真的太爽了!

到这里就搞定了:Coco Server 自带的 Easysearch 不仅能正常跑起来,还能把 9200 端口暴露出来给外部访问。

日常用法也很简单:

  • 连接器同步进来的数据会实时写进这台 Easysearch 里;
  • 自己用 API 写进去的数据也会被 Coco Server 索引;
  • 遇到"数据到底进没进、字段长啥样、索引有没有建对"这种问题,直接打开 Easysearch UI 看一眼就能确认,再也不用抓瞎!
相关推荐
不加辣椒28 分钟前
第7章 边界与约束技术:确保输出的准确性与安全性
人工智能
AI悦创Python辅导31 分钟前
Claude Code 越用越乱?Sub-Agents 才是上下文污染的解法
人工智能
Bigfish_coding37 分钟前
前端转agent-【python】-07 长期记忆进阶:用 ChromaDB + 语义搜索给 Agent 装上真正的长期记忆
人工智能
阿黎梨梨43 分钟前
AI Loop:告别“人肉写提示词”,让代码替你“鞭策”AI
javascript·人工智能
甲维斯2 小时前
坦克大战测试全翻车了!豆包,DeepSeek,Qwen,GPT,Claude
前端·人工智能·游戏开发
若丶相见2 小时前
AI 大模型零基础知识扫盲
人工智能
曲幽3 小时前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
猿人谷3 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
说了很好5 小时前
PyTorch从零搭建DDPM:时间嵌入+UNet网络+扩散调度完整复现
人工智能
Bigfish_coding5 小时前
前端转agent-【python】-06 长期记忆(向量数据库 + 嵌入)
人工智能