美丽搜索?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

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

picture.image

SDK生态(部分)

picture.image

文档架构

picture.image

安全性

picture.image

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

picture.image

上手

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

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

  • 下载脚本
 curl -L https://install.meilisearch.com | sh

picture.image

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

picture.image

  • 准备测试数据

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

picture.image

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

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

完成后会看到如下结果

picture.image

  • 检查下状态
curl \
  -X GET 'http://localhost:7700/tasks/0' \
  -H 'Authorization: Bearer aSampleMasterKey'

picture.image

  • 试一下在命令行窗口检索
curl \
  -X POST 'http://localhost:7700/indexes/movies/search' \
  -H 'Content-Type: application/json' \
  -H 'Authorization: Bearer aSampleMasterKey' \
  --data-binary '{ "q": "botman" }'

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

  • 集成界面(类似Kibana)

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

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

picture.image

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

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

0
0
0
0
关于作者
相关资源
云原生数仓如何构建高性能向量检索技术
火山引擎ByteHouse团队基于社区 ClickHouse 进行技术演进,提出了全新的向量检索功能设计思路,满足业务对向量检索稳定性与性能方面的需求。
相关产品
评论
未登录
看完啦,登录分享一下感受吧~
暂无评论