写点什么

美丽搜索,MeiliSearch

作者:为自己带盐
  • 2024-06-24
    河北
  • 本文字数:1756 字

    阅读完需:约 6 分钟

美丽搜索,MeiliSearch

好久不更新博客了,其实不是不想更,也确实积攒了很多想聊的话题,只是在等一个契机。

今天发现了一个很好用的工具,上手及其丝滑,而且也的确可以解决很多问题,按捺不住想要分享一下。

背景

检索模块的设计应该是大部分系统架构中一个不可或缺的环节,为啥这么说呢?当下的时代背景,我们开发的系统每天都会产生大量的日志,比如 Nginx 产生的请求日志,系统本身各种类型的日志,按类型分,还可以分成常规日志,异常日志,告警日志等等。

这些日志是系统运行状态的产物,可以帮助我们排查系统运行过程中的问题,是保证服务正常运转的关键参考信息。

因此,可以快速的检索日志数据,便是系统开发过程的一项刚需。

常规做法

在日志搜集,检索,操作相关方面,比较普遍的做法是集成 ElasticStack,比如 ELK,EFK 等等方案,都比较成熟。但对于自动化程度偏弱,开发能力不的团队,部署一套基于 ES 的日志管理服务还是有一点门槛的。

那有没有更友好,更方便,让小团队也可以丝滑接入并集成到系统中的检索构件呢?

或许,可以试试 MeiliSearch!

MeiliSearch

官方介绍

地址:https://www.meilisearch.com/

仓库:https://github.com/meilisearch/meilisearch

这就不多说了~


小 Battle

对于和竞品的对比,MeiliSearch 的官方文档上列了几个对比图,我挑了几个放一下,更具体可以参照这里:https://www.meilisearch.com/docs/learn/what_is_meilisearch/comparison_to_alternatives

关于开源协议(商业友好程度)



SDK 生态(部分)



文档架构



安全性



AI 加持能力(MeiliSearch 几乎拉满)



上手

事实上,官方文档里也有 QuickStart,大伙完全可以参照官方文档里的介绍自己试一下。我这里就是结合实际的操作,简单镜像一下官网的操作,也算是非官方的汉化一下吧,仅供参考~

这部分我是在本地的 WSL(Ubuntu 22.04)环境和腾讯云的 Debain 系统上分别测试,均可以正常安装,非常丝滑,这里以 WSL 的安装过程为例

  • 下载脚本

 curl -L https://install.meilisearch.com | sh
复制代码



  • 安装

# 注意master-key是服务启动密钥,如果启动的时候不传入该参数# 服务会自动生成一个,具体描述可以查看官网介绍./meilisearch --master-key="aSampleMasterKey"
复制代码



  • 准备测试数据

官网提供了一个 movics.json(https://www.meilisearch.com/movies.json)的测试数据,可以直接下载,并上传到 meilisearch 的相同路径下



然后,另起一个命令窗口,执行以下命令,导入数据

curl \  -X POST 'http://localhost:7700/indexes/movies/documents?primaryKey=id' \  -H 'Content-Type: application/json' \  -H 'Authorization: Bearer aSampleMasterKey' \  --data-binary @movies.json
复制代码

完成后会看到如下结果



  • 检查下状态

curl \  -X GET 'http://localhost:7700/tasks/0' \  -H 'Authorization: Bearer aSampleMasterKey'
复制代码



  • 试一下在命令行窗口检索

curl \  -X POST 'http://localhost:7700/indexes/movies/search' \  -H 'Content-Type: application/json' \  -H 'Authorization: Bearer aSampleMasterKey' \  --data-binary '{ "q": "botman" }'
复制代码



这里我的窗口没有格式化 json 数据,大家可以参照官网,或者自己试试看。

  • 集成界面(类似 Kibana)

当我们在执行一系列操作的时候,最初运行 meilisearch 的窗口会实时的打印一些日志情况,就像这样👇



meilisearch 也提供了一个集成好的界面环境,默认使用了 7700 端口,可以直接使用,访问http://localhost:7700/



在这个窗口检索,就友好多了,而且速度也很快,对于想要接入检索系统来优化自己的日志管理的团队来说,是非常好的选择,我觉得,这甚至可以集成到相关的正式业务当中,直接面向用户也是 ok 的。


好了,大概就这些,最后再说两句感想。其实我们做系统开发工作,追求稳定性是无可厚非的,但这要有一个前提,你的软件系统在可用性,可靠性,安全性,性能,易操作性这些质量属性上,是否达到了一定高的标准,是否能满足当下以及未来一段时日的用户需求,是否能提供足够稳定的用户体验,如果不能,那所谓的追求稳定,在我看来不过是偷懒的借口。不破不立,创新就是要不停的折腾,虽然过程可能会让人觉得你做的东西乱七八糟,但当业务全部集成好的那一刻,也许他们都会闭嘴。开发人员,还是要专注自己喜欢的领域,尤其一线的开发人员,更要专注技术,不要参与政治斗争,更不要成为政治斗争的牺牲品,把持好自己,做正确的事,好好苟住。

发布于: 3 小时前阅读数: 8
用户头像

学着写代码 2019-04-11 加入

是一枚,热爱技术,天赋不高,又有点轴,的猿。。

评论

发布
暂无评论
美丽搜索,MeiliSearch_meilisearch_为自己带盐_InfoQ写作社区