RediSearch-Redis的高性能全文搜索

2024-08-21 15:20

本文主要是介绍RediSearch-Redis的高性能全文搜索,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 什么是RediSearch
  • 能解决什么问题
  • 加入RediSearch模块有什么好处
  • 如何部署
  • 命令行如何使用
  • Redisson如何使用

什么是RediSearch

RediSearch是Redis Labs开发的一个模块,它为Redis添加了高性能的全文搜索功能。

能解决什么问题

RediSearch 的出现给 Redis 带来比较大热度。我们通常使用文档查询最为常见的就是 Elasticsearch,它的搜索开始的很早,风很大,企业实践也是如雨后春笋。

Redis 作为缓存介的霸主,已经开始不满足于局限的业务范畴,RediSearch的出现极大地扩展了Redis的功能边界,使其不仅仅是一个简单的键值存储系统,而是成为了一个可以用于多种应用场景的强大平台。

加入RediSearch模块有什么好处

1、增强搜索能力:
RediSearch使Redis具备了全文搜索的能力,这对于需要在大量文本数据中进行高效搜索的应用非常有用。它支持复杂的查询语法,例如布尔查询、短语匹配、模糊匹配等,这使得Redis成为一个更加强大的数据处理工具。

2、简化架构:
对于需要搜索功能的应用程序,使用RediSearch可以减少对额外搜索服务(如Elasticsearch或Solr)的依赖,从而简化整体架构并降低运维成本。

3、灵活性和扩展性:
RediSearch支持在Redis集群环境中使用,这意味着它可以随着数据量的增长而水平扩展。它还可以与其他Redis模块结合使用,比如RedisJSON,以提供更复杂的数据处理和搜索功能。

如何部署

部署的方式有很多,就是源代码编译、预编译文件、docker方式

非常快速的试用方式就是docker部署一个包含search功能的redis,生产环境就编译模块后加入。

  • Redis Stack 大礼包
$ docker run -p 6379:6379 redis/redis-stack-server:latest

redislabs/redisearch 的镜像已经过期,老版本和老demo中还有使用这个镜像,但是新更新不会再继续,需要下载 redis-stack 的docker镜像。

  • 连接客户端
ProjectLanguage
jedis⁠Java
redis-py⁠ Python
node-redis⁠ Node.js
nredisstack⁠ .NET
redis-om⁠ Python
lettusearch⁠ Java
spring-redisearch⁠ Java
redis-om-spring⁠ Java
redisearch-go⁠ Go
rueidis⁠ Go
Redis-om⁠JavaScript
Redis.OM⁠ .NET
redisearch-php⁠ PHP
php-redisearch⁠ PHP
redisearch-api-rs⁠Rust
redi_search_rails⁠ Ruby
redisearch-rb⁠ Ruby
redi_search⁠ Ruby

命令行如何使用

  • 创建索引
> FT.CREATE idx:movie ON hash PREFIX 1 "movie:" SCHEMA title TEXT SORTABLE release_year NUMERIC SORTABLE rating NUMERIC SORTABLE genre TAG SORTABLEOK
  • 查看索引
> FT.INFO idx:movie1) index_name2) idx:movie
... 
46) 1) global_idle2) (integer) 0
...
  • 修改索引
> HSET "movie:11005" title "Star Wars: Episode VI - Return of the Jedi"  plot "The Rebels destroy the Empire's Death Star." release_year 1983 genre "Action" rating 8.3 votes 906260 (integer) 6
  • 删除索引
> EXPIRE "movie:11002" 15(integer) 1
  • 查询索引(多种迷糊搜索的方式)
> FT.SEARCH idx:movie "war" RETURN 3 title release_year rating1) (integer) 1
2) "movie:11002"
3) 1) "title"1) "Star Wars: Episode V - The Empire Strikes Back"2) "release_year"3) "1980"4) "rating"5) "8.7"> FT.SEARCH idx:movie "@title:war" RETURN 3 title release_year rating> FT.SEARCH idx:movie "emp*" RETURN 3 title release_year rating> FT.SEARCH idx:movie "%gdfather%" RETURN 3 title release_year rating> FT.SEARCH idx:movie "war |  %gdfather% " RETURN 3 title release_year rating> FT.SEARCH idx:movie "@genre:{Drama}" RETURN 3 title release_year rating1) (integer) 1
2) "movie:11003"
3) 1) "title"2) "The Godfather"3) "release_year"4) "1972"5) "rating"6) "9.2"

所有的指令参考官方文档

Redisson 中如何使用

构建client

Config config = new Config();
config.useSingleServer().setAddress("redis://" + address);
RedissonClient client = Redisson.create(config);

构建查询内容,并根据文本内容搜索,并获取结果

RMap<String, SimpleObject> m = client.getMap("doc:1", new CompositeCodec(StringCodec.INSTANCE, client.getConfig().getCodec()));
m.put("v1", new SimpleObject("name1"));
m.put("v2", new SimpleObject("name2"));
RMap<String, SimpleObject> m2 = client.getMap("doc:2", new CompositeCodec(StringCodec.INSTANCE, client.getConfig().getCodec()));
m2.put("v1", new SimpleObject("name3"));m2.put("v2", new SimpleObject("name4"));RSearch s = client.getSearch();
s.createIndex("idx", IndexOptions.defaults().on(IndexType.HASH).prefix(Arrays.asList("doc:")),FieldIndex.text("v1"),FieldIndex.text("v2"));SearchResult r1 = s.search("idx", "*", QueryOptions.defaults().returnAttributes(new ReturnAttribute("v1"), new ReturnAttribute("v2")));SearchResult r2 = s.search("idx", "*", QueryOptions.defaults().filters(QueryFilter.geo("field").from(1, 1).radius(10, GeoUnit.FEET)));

删除索引

s.dropIndex("idx");

修改配置

Map<String, String> cfg = s.getConfig("TIMEOUT");
s.setConfig("TIMEOUT", "42");

Redisson官方也给到一些样例: 包括普通查询、对象查询、索引查询和语法校验

  • 完整官方说明文档

The end

虽然这个组件目前迭代更新是很快,但是在国内实践并不算多,毕竟Elasticsearch的选型,多年已经在人们的内心根深蒂固,如果不是RediSearch足够好或者外部动力催生,还是比较难铺开市场的。

此外,企业对于选型Elasticsearch 也不是单纯只做一个搜索,还结合日志、技术栈、数据库等多方面的考虑。

希望这个组件能够继续持续迸发活力,我们也有一天能选型用上这样的功能。

这篇关于RediSearch-Redis的高性能全文搜索的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

hdu1240、hdu1253(三维搜索题)

1、从后往前输入,(x,y,z); 2、从下往上输入,(y , z, x); 3、从左往右输入,(z,x,y); hdu1240代码如下: #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#inc

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

hdu 4517 floyd+记忆化搜索

题意: 有n(100)个景点,m(1000)条路,时间限制为t(300),起点s,终点e。 访问每个景点需要时间cost_i,每个景点的访问价值为value_i。 点与点之间行走需要花费的时间为g[ i ] [ j ] 。注意点间可能有多条边。 走到一个点时可以选择访问或者不访问,并且当前点的访问价值应该严格大于前一个访问的点。 现在求,从起点出发,到达终点,在时间限制内,能得到的最大

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

hdu4277搜索

给你n个有长度的线段,问如果用上所有的线段来拼1个三角形,最多能拼出多少种不同的? import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因

构建高性能WEB之HTTP首部优化

0x00 前言 在讨论浏览器优化之前,首先我们先分析下从客户端发起一个HTTP请求到用户接收到响应之间,都发生了什么?知己知彼,才能百战不殆。这也是作为一个WEB开发者,为什么一定要深入学习TCP/IP等网络知识。 0x01 到底发生什么了? 当用户发起一个HTTP请求时,首先客户端将与服务端之间建立TCP连接,成功建立连接后,服务端将对请求进行处理,并对客户端做出响应,响应内容一般包括响应