为了账号安全,请及时绑定邮箱和手机立即绑定

全文搜索的设计or实现思路是怎么样的?

全文搜索的设计or实现思路是怎么样的?

慕标琳琳 2018-08-07 11:10:55
打算用的是ElasticSearch, 分词用IK. 比如博客园的搜索文章, 搜索的Field: 博客标题、博客内容、博客标签我现在的想法是:  1. 我只会第一次接入elastic同步一次数据库数据到 elastic-server。  2. 以后新增or更新 博客, 通过新增代码逻辑, 每次发送请求给 elastic-server,    大致"_source":{"articleId":"...", "articleTitle":"...","articleConent":"...","articleTag":"..."};  在elastic-server返回success才保存博客到database,  否则回滚事物. (不知道这有没有更好的实现)  3. 搜索时: 搜索出符合的结果, 然后用articleId去走正常的 查看博客逻辑.    包括搜索列表展示, 比如每页10条, 我都会用这10个articleId去组装列表数据(因为是app的搜索)  4. 删除: 我会根据articleId去删除 elastic-server中的数据(document)我不知道以上的思路是不是可以,或有哪些地方可优化? 求做过的指点一下.
查看完整描述

1 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

思路大致没什么问题

1 关于数据同步

  不过博客的存储引擎现在大部分都是mongodb这类的,这种数据库跟Elasticsearch有专门的同步工具,不需要你手动维护。
2 关于结果展现

  搜索结果的展现最好直接用搜索的结果来做,不要重新查数据库,再组织结果。

  因为这样即会丢失关键字高亮的信息,效率也不高。


查看完整回答
反对 回复 2018-08-24
  • 1 回答
  • 0 关注
  • 740 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信