Docker三分钟部署ElasticSearch平替MeiliSearch轻量级搜索引擎

👩🏽‍💻个人主页:阿木木AEcru (更多精彩内容可进入主页观看)

🔥 系列专栏:《Docker容器化部署系列》 《Java每日面筋》

💹每一次技术突破,都是对自我能力的挑战和超越。

目录

一、 什么是MeiliSearch?

MeiliSearch作为轻量级搜索引擎的解决方案,相比于Elasticsearch,它更适用于中小型项目,提供快速、高精度、易用且支持中文搜索的特点。MeiliSearch拥有定制化API和多语言支持,尤其适合数据量不大但对速度和易用性有要求的场景。

二、对比ElasticSearch有什么好处?

Meilisearch以其轻量级和高性能的特点,为需要快速、简单搜索解决方案的开发者和中小型项目提供了理想选择。与Elasticsearch相比,Meilisearch的资源占用更少,部署过程更为简便,无需复杂的集群配置即可快速启动服务。

Meilisearch的搜索响应时间极短,通常在50毫秒以内,为用户提供了接近即时的搜索体验。它内置了智能搜索功能,如错字容忍和同义词识别,这些功能开箱即用,无需额外配置,大大简化了开发流程。

支持多语言SDK是Meilisearch的另一大优势,无论是在Python、Java还是Go等流行编程语言中,开发者都能轻松集成Meilisearch,享受到它带来的便利。Meilisearch的API设计直观易用,即便是编程新手也能快速掌握。

Meilisearch的社区活跃,文档详尽,为用户在使用过程中遇到的问题提供了丰富的解答和指导。此外,Meilisearch对中文搜索的原生支持,为中文内容的搜索提供了极大的便利,无需额外的语言处理配置。

尽管Meilisearch在处理大规模数据集和复杂查询方面可能不如Elasticsearch强大,但其在成本效益、易用性和快速响应方面的优势,使其成为许多现代应用的理想搜索解决方案。随着技术的不断发展,Meilisearch有望在搜索引擎领域扮演更加重要的角色,为用户带来更加高效和智能的搜索体验。

三、使用场景有哪些?

  1. 电子商务网站:通过实时搜索建议和个性化搜索结果来提升用户体验。
  2. 内容管理系统:快速检索文档、博客文章、新闻等,提高内容查找效率。
  3. 企业内部搜索:为员工提供快速访问公司内部数据和知识库的能力。
  4. 初创公司和小型项目:由于资源和成本限制,需要一个易于部署和维护的搜索解决方案。
  5. 个人开发者:为个人项目提供快速、简单的搜索功能,无需复杂的设置。
  6. 管理后台搜索:在管理后台提供高效的数据检索,简化操作流程。
  7. 小程序搜索:为小程序用户提供快速响应的搜索体验。
  8. 网站搜索功能:为各种网站提供站内搜索能力,增强用户交互。
  9. 文档搜索:在大量文档中快速定位所需信息。
  10. 商品搜索:在电商平台上提供商品搜索,提升购物体验。

四、docker部署MeiliSearch

4.1 创建数据持久化文件夹

sudo mkdir -p /usr/local/meiliData

4.2 拉取镜像

 docker pull getmeili/meilisearch:v1.8

这里需要注意的是,我在服务器是是拉不到的(需要魔法上网),我就在本地安装了DockerDesktop ,再使用魔法上网然后拉取下来的镜像,然后再打包成tar包上传到服务器运行。

4.3 运行容器

sudo docker run -it \
--privileged=true \
-d --restart=always \
-p 7700:7700 \
-e MEILI_MASTER_KEY='V24oN6ZyG810XEvczp' \
-v /usr/local/meiliData:/meili_data \
--name meilisearch \
getmeili/meilisearch:v1.8
1. `sudo docker run -it`:以管理员权限启动一个新的Docker容器,并与它交互。
2. `--privileged=true`:给予容器特权,使其具有更多权限。
3. `-d`:让容器在后台运行。
4. `--restart=always`:设置容器退出后自动重启。
5. `-p 7700:7700`:将宿主机的7700端口映射到容器的7700端口。
6. `-e MEILI_MASTER_KEY='V24oN6ZyG810XEvczp'`:设置环境变量,用于Meilisearch的API访问密钥。
7. `-v /usr/local/meiliData:/meili_data`:将宿主机的目录挂载到容器内,用于数据持久化。
8. `--name meilisearch`:给容器命名为`meilisearch`。
9. `getmeili/meilisearch:v1.8`:指定要使用的Meilisearch镜像及其版本。

如果开启了防火墙还需要开放一下防火墙的7700端口(如果防火墙没有开启就跳过这一步即可)

firewall-cmd --zone=public --add-port=7700/tcp --permanent
systemctl restart firewalld.service

如果是云服务器,还需要开放一下安全组的7700端口

五、访问测试

5.1 访问

使用 ip:7700 的方式访问即可需要输入再部署时指定的密钥

5.2 下载测试文件

wget https://www.meilisearch.com/movies.json

5.3 导入测试文件

curl \
  -X POST 'http://localhost:7700/indexes/movies/documents?primaryKey=id' \
  -H 'Content-Type: application/json' \
  -H 'Authorization: Bearer V24oN6ZyG810XEvczp' \
  --data-binary @movies.json
响应回来这样的信息就表示成功
{"taskUid":0,"indexUid":"movies","status":"enqueued","type":"documentAdditionOrUpdate","enqueuedAt":"2024-06-26T03:08:48.646164654Z"}

需要注意的是 Authorization: Bearer <部署时候填入的密钥> , 这时再回去访问一下 meilisearch ,发现已经是有内容了

还可以进行搜索,搜素的词会有高亮显示。

六、结尾

接下来将推出 SpringBoot 整合 MeiliSearch , 感兴趣的小伙伴可以关注一下,谢谢!

感谢观看至此,希望该文章能够帮助到您提升知识和技能。如果您喜欢我的内容,请不要忘记点赞和分享哦!👍

相关推荐
喝醉酒的小白4 分钟前
ES 集群 A 和 ES 集群 B 数据流通
大数据·elasticsearch·搜索引擎
炭烤玛卡巴卡8 分钟前
初学elasticsearch
大数据·学习·elasticsearch·搜索引擎
it噩梦10 分钟前
es 中使用update 、create 、index的区别
大数据·elasticsearch
椰椰椰耶1 小时前
【文档搜索引擎】搜索模块的完整实现
java·搜索引擎
一勺菠萝丶2 小时前
MongoDB 常用操作指南(Docker 环境下)
数据库·mongodb·docker
Mitch3112 小时前
【漏洞复现】CVE-2015-3337 Arbitrary File Reading
elasticsearch·网络安全·docker·漏洞复现
Mitch3112 小时前
【漏洞复现】CVE-2015-5531 Arbitrary File Reading
web安全·elasticsearch·网络安全·docker·漏洞复现
我自飞扬临天下3 小时前
Docker常用命令
docker
喝醉酒的小白4 小时前
Elasticsearch(ES)监控、巡检及异常指标处理指南
大数据·elasticsearch·搜索引擎
码农土豆6 小时前
PaddlePaddle飞桨Linux系统Docker版安装
linux·docker·paddlepaddle