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

亲爱的圣诞老人,这里有一点小小的帮助,献给圣诞节

作者:来自 Elastic Laurent_Saint-Felix

每一年, Santa Claus 都会遇到同样的扩展性问题:数十亿的孩子,一个神奇的投递时间窗口,零容错空间

几个世纪以来,他一直用羊皮纸卷轴、羽毛笔,以及一个极度过度工作的精灵来运行一切。但今年, Santa 彻底现代化了他的 Naughty-and-Nice 运营技术栈。

  • 再见卷轴
  • 再见建立在希望和糖果拐杖之上的单体 North Pole 数据库。
  • 你好 Elasticsearch 。

而强大的集群,也带来了对……命令行的强烈需求。

幸运的是,精灵们在 GitHub 上发现了一个很有前途的 CLI ,并把它直接构建进了雪橇的车载计算机中:escli-rs

为什么 Santa 需要一个真正的 CLI

Kibana 仪表板很棒,除非你正以 Mach 8 的速度飞越 Tokyo ,而且真的不应该戴着厚重的手套去点击菜单按钮。

Santa 需要的是:

  • 快速
  • 可脚本化
  • 适合戴手套操作

于是escli登场了,这是一个 Elasticsearch CLI 的 概念验证 ,支持多个版本、安全认证、真正的 shell 自动补全,以及足够的便捷性来拯救圣诞节。

精灵们为 Santa 配置了他的 .env :

ESCLI_URL=https://northpole.elasticsearch.cluster ESCLI_API_KEY=ho-ho-ho-secret

一个充满孩子的 Cluster

现在已经建立了对 Cluster 的访问,精灵们开始向其中添加一些孩子。

{"index": {"_index": "children-of-the-world", "_id": "zoe-8yo-france"}} {"name": "Zoe", "age": 8, "nice_score": 0.92, "gift_preference": "Lego Friends", "cookie_offerings": 5, "sibling_conflicts": 1} {"index": {"_index": "children-of-the-world", "_id": "jai-10yo-india"}} {"name": "Jai", "age": 10, "nice_score": 0.75, "gift_preference": "Cricket bat", "cookie_offerings": 2, "sibling_conflicts": 4} {"index": {"_index": "children-of-the-world", "_id": "mia-6yo-canada"}} {"name": "Mia", "age": 6, "nice_score": 0.98, "gift_preference": "Stuffed bear", "cookie_offerings": 10, "sibling_conflicts": 0} {"index": {"_index": "children-of-the-world", "_id": "lucas-11yo-usa"}} {"name": "Lucas", "age": 11, "nice_score": 0.33, "gift_preference": "RC car", "cookie_offerings": 1, "sibling_conflicts": 7} {"index": {"_index": "children-of-the-world", "_id": "sofia-9yo-spain"}} {"name": "Sofia", "age": 9, "nice_score": 0.87, "gift_preference": "Art supplies", "cookie_offerings": 4, "sibling_conflicts": 2}
escli bulk --refresh wait_for --input children_of_the_world.ndjson

Santa 的 Elasticsearch 配置已经就绪,包含关键要素:

  • Index : children-of-the-world
  • Fields : name, age, nice_score, gift_preference, cookie_offerings, sibling_conflicts

现在,多亏了 escli , Santa 可以在地球上的任何地方查询它。甚至在飞行途中。

Santa 实际使用的真实命令

获取单个孩子的文档

escli get children-of-the-world "zoe-8yo-france"

搜索真正乖巧的孩子

echo '{ "query": { "range": { "nice_score": {"gte": 0.9} } } }' | escli search \ --index children-of-the-world | jq

将淘气名单导出为 CSV 文件

echo '{ "query": "FROM children-of-the-world | WHERE nice_score < 0.2" }' | escli esql query --format csv

为了防止手动导出 Naughty List 打断他们的 December stand-up 会议,精灵们最终将这个过程自动化了。

幸运的是,今年名单是空的,因为每个人都很乖。

自动补全: Santa 的新宠功能

escli 中最酷的功能之一就是 shell 自动补全。

安装自动补全:

eval "$(COMPLETE=bash ./escli)"

现在他可以输入:

eval "$(COMPLETE=bash ./escli)"

然后他的终端会智能地补全为:

escli esql query

连驯鹿都印象深刻。

圣诞节被 --help 拯救

Santa 在庞大的物流网络中,需要记住几乎无限的 API 选项,有时会忘记一两个 flag 。他并不感到羞愧。他高兴地使用 --help flag 来快速回忆。

escli --help
  • 有文档的命令。
  • 结构一致。
  • 没有意外。

精灵们甚至抵制住了添加 ASCII 艺术的冲动(在一次小小的 “terminal meltdown incident” 之后)。

Santa 滚动查看帮助输出,微笑着低声说:“这太有用了!” 并按时送出了数十亿份礼物。

如果它对 Santa 足够好……

……那么也许对你的 Elasticsearch cluster 也足够好了。

今天就从 escli-rs 仓库下载最新的预发布版本并尝试吧。

我们很想听到你的反馈:在 GitHub 上打开一个 issue,让我们知道你的想法!

原文:https://discuss.elastic.co/t/dec-1st-2025-en-dear-santa-here-s-a-little-help-for-christmas/383561

http://www.gsyq.cn/news/105133.html

相关文章:

  • 【高端图形渲染必修课】:掌握4种专业级抗锯齿算法核心原理
  • 【金融风险管理实战】:手把手教你用R语言计算VaR的5种核心方法
  • 基于VDLL的矢量型GPS信号跟踪算法MATLAB仿真,包括程序+word设计文档
  • 【渲染的纹理:从入门到精通】:掌握GPU纹理映射核心技术的7大关键步骤
  • 两种方法实现循环温度的边界条件设置及复杂的温度变化
  • 【PHP扩展性能优化秘籍】:基于Rust的函数调试与内存泄漏排查指南
  • 【GraphQL性能优化指南】:利用PHP字段别名提升接口响应速度300%
  • 【DOTS物理系统深度解析】:掌握高性能物理模拟的5大核心技巧
  • 错过将后悔!R量子模拟中不可不知的门序列设计原则
  • 【Flutter x 鸿蒙】第四篇:双向通信——Flutter调用鸿蒙原生能力 - 青青子衿-
  • Java毕设项目:基于springboot工资管理系统(源码+文档,讲解、调试运行,定制等)
  • 【R Shiny多模态数据导入终极指南】:掌握5种高效组件实现无缝数据集成
  • 医疗数据泄露风险激增?,紧急应对PHP脱敏新规调整
  • 一文详解「全面向加密货币转型」的 Robinhood 最新基本面及收入来源
  • Java毕设项目:基于SpringBoot+Vue高校奖学金评定管理系统设计与实现基于springboot高校学生奖学金评定系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • 汇川H5U标准化编程模板!! 逻辑非常清晰,对规范化编程很有参考价值!!! 1.注释详细,功能齐全,逻辑严谨 2.软元件命名,地址规划规范 3.启停、报警总结、光电检测程序完整 4.气缸、轴控功能块编
  • 【企业数字化转型新引擎】:量子服务集成带来的4倍效能提升秘诀
  • 蚂蚁“灵光”实测测评:这款号称“让复杂变简单”的AI工具到底好不好用?
  • Dify智能体平台条件分支调用Qwen-Image场景设计
  • 揭秘医疗系统PHP数据备份难题:3步实现安全可靠备份
  • NVIDIA GeForce GTX 1060 支持4K吗
  • 泛型实例化陷阱频发?资深架构师总结的6大避坑法则
  • BEATOZ在香港独立非执行董事协会年度大会上提出Web3与AI治理解决方案
  • 免训练开放词汇分割范式突破!将 SAM 3 零微调适配遥感图像分析领域,17个数据集上刷新SOTA
  • Laravel 13多模态事件监听实战:如何实现高响应性应用架构?
  • QDK API文档精读实战:快速定位接口问题的黄金法则
  • 【Q#编程入门指南】:掌握量子计算的5个核心示例与实战技巧
  • Alpha版本测试报告
  • 我在小米推了两年的方向,字节用豆包手机助手做出来了
  • 掌握这4种初始化模式,轻松玩转R量子计算模拟包