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

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

image.png

SDK生态(部分)

image.png

文档架构

image.png

安全性

image.png

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

image.png

上手

事实上,官方文档里也有QuickStart,大伙完全可以参照官方文档里的介绍自己试一下。我这里就是结合实际的操作,简单镜像一下官网的操作,也算是非官方的汉化一下吧,仅供参考~
这部分我是在本地的WSL(Ubuntu 22.04)环境和腾讯云的Debain系统上分别测试,均可以正常安装,机器丝滑,这里以WSL的安装过程为例

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

image.png

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

image.png

  • 准备测试数据

官网提供了一个movics.json(https://www.meilisearch.com/movies.json)的测试数据,可以直接下载,并上传到meilisearch的相同路径下
image.png
然后,另起一个命令窗口,执行以下命令,导入数据

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

完成后会看到如下结果
image.png

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

image.png

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

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

  • 集成界面(类似Kibana)

当我们在执行一系列操作的时候,最初运行meilisearch的窗口会实时的打印一些日志情况,就像这样👇
image.png
那meilisearch也提供了一个集成好的界面环境,默认使用了7700端口,可以直接使用,访问http://localhost:7700/
image.png
在这个窗口检索,就友好多了,而且速度也很快,对于想要接入检索系统来优化自己的日志管理的团队来说,是非常好的选择,我觉得,这甚至可以集成到相关的正式业务当中,直接面向用户也是ok的。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

为自己_带盐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值