解决coreseek 数据更新 却索引不到的问题

2024-01-09 19:38

本文主要是介绍解决coreseek 数据更新 却索引不到的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目前做的是:每1分钟执行一次增量索引,每五分钟执行一次索引合并,每天1:30重建索引。

这样可以很好的模拟新建数据时候的实时索引。

但是很快测试部门就报告了一个bug,当我修改了一项数据的时候,搜索修改的内容却搜索不到,但是搜索没修改之前的内容却可以。

例如:我有一项数据的值为"我叫刘帅",搜索“刘帅”是可以搜索到的。

现在讲这样数据的值修改为:“我叫孙悟空”,这时搜索“孙悟空”却搜索不到,但是搜索“刘帅”能搜索到。

造成这个问题的原因是:数据库中的值更新了,但是coreseek索引文档中的值并没有更新,这时重建索引发现就可以搜索到了。

解决办法是:

将要修改的数据在数据库中delete掉,重新插入一下新的数据。这样便会将修改的数据踢到每1分钟执行一次的增量索引中了。

下面还需要将原来索引当中的要修改的数据delete掉,否则coreseek中会有两条这样的数据导致数据不够准确。针对这个的解决办法是

在建立索引文档的时候添加一个属性is_del默认值是0,再配合spi中的UpdateAttributes(),将刚才修改的数据的索引文档的is_del属性修改为1。

查询的时候使用SetFilter() 将删除的数据过滤掉

这样就行了。

大概原理就是将修改的数据踢到增量索引中去,由于增量索引1分钟就会更新,所以这个最多会有1分钟的误差,再用UpdateAttributes 和SetFilter配合将以前索引中错误的数据过滤掉。

如果还觉得延时长那么可以这样做:

当数据库更新完数据之后直接使用php的system()函数执行增量索引的命令这样就实时了。不过要判断一下这个命令是否已经在执行,可以走一个文件锁,命令执行的时候生产文件锁,执行结束删除就行。

http://www.xuebuyuan.com/1050302.html?mobile=0

这篇关于解决coreseek 数据更新 却索引不到的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588214

相关文章

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法

《Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法》本文解析Spring框架中BeanCreationExce... 目录引言一、问题描述1.1 报错示例假设我们有一个简单的Java类,代表一个用户信息的实体类:然后,

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到

MySQL磁盘空间不足问题解决

《MySQL磁盘空间不足问题解决》本文介绍查看空间使用情况的方式,以及各种空间问题的原因和解决方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录查看空间使用情况Binlog日志文件占用过多表上的索引太多导致空间不足大字段导致空间不足表空间碎片太多导致空间不足临时表空间