打算用的是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 关于结果展现:
搜索结果的展现最好直接用搜索的结果来做,不要重新查数据库,再组织结果。
因为这样即会丢失关键字高亮的信息,效率也不高。
- 1 回答
- 0 关注
- 740 浏览
添加回答
举报
0/150
提交
取消