Redis geo之我想找最近的美食

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 又是Redis这个家伙,到底还有什么是Redis不能做的。没错,就是它,今天小马来聊聊Redis geo这个数据结构在LBS上的运用。现在都是线上线下的模式了,出现了很多业务基于LBS,即基于位置的服务(Location Based Services,LBS)。比如附近的商家,附近的骑手,微信摇一摇,附近的滴滴类似于的距离计算等等。那要怎么实现呢?

又是Redis这个家伙,到底还有什么是Redis不能做的。没错,就是它,今天小马来聊聊Redis geo这个数据结构在LBS上的运用。现在都是线上线下的模式了,出现了很多业务基于LBS,即基于位置的服务(Location Based Services,LBS)。比如附近的商家,附近的骑手,微信摇一摇,附近的滴滴类似于的距离计算等等。那要怎么实现呢?

类似于附近的商家这种业务场景该如何实现呢?小马整理了了一些解决方案供参考:ElasticSearch,redis geo,mongodb geo索引,mysql geo索引(point字段类型,SPATIAL KEY索引),mysql自定义函数(数据量大时必然存在性能问题),地图API接口支持等等。今天就来讲redis geo。

​什么是Redis geo

redis的geo特性在Redis3.2版本发布,这个功能可以将用户给定的地理位置信息储存起来,并对这些信息进行操作。可以理解为记录经纬度,然后会直接计算距离,得出各种根据距离计算的需求,比如查询最近的商家并排序,查询方圆五百里内的美食等等。geo也是利用有序列表zset来实现的,其以坐标的hash值作为member的score。

geo相关命令

geoadd key longitude latitude member [longitude latitude member……]

​将给定的空间元素(经度、纬度、名字)添加到指定的键里面。

geopos key member [member……]

从键里面返回所有给定位置元素的位置(经度和纬度)。

geodist key member1 member2 [unit]

返回两个给定位置之间的距离,指定单位的参数unit必须是一下单位的其中一个:(默认m,km,mi,ft)。

georadius key longitude latitude radius m|km|gt|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]

以给定的经纬度为中心,返回键包含的位置元素当中,与中心的距离不超过给定最大距离的而所有位置元素。后面的参数说明如下。
image.png

georadiusbymemeber key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]

​这个命令和georadius命令一样,只是中心点直接是一个成员位置而不是给定的经纬度。这个似乎会更适用于我们的业务场景。

zrem key member

删除key中的member。

实战例子

话不多说,我们来玩一下。我们先找到地理位置经纬度来登记一下。

莆田 118.99472,25.41878;福州 119.27345,26.04769;北京 116.23128,40.22077;上海 121.48941,31.40527;武汉 114.02919,30.58203;福州台江 119.31414,26.0527。

好了,我们来登记一下这些位置。这里把fuzhou手误拼成fuhzou了,抱歉。
image.png

登记完,我们来输出一下莆田和福州之间的距离,以及分别输出福州方圆100公里内的地址和方圆1000公里内的地址有哪些。结果如下,我们看到结果是非常诚实的,距离福州方圆100公里内是莆田,福州台江;1000公里内是莆田,福州台江,武汉,上海。这里的几行报错是因为key写错了找不到对应key导致的,知道真相后的小马眼泪流下来。
image.png

最后我们来算一个最亲切的,算出1000公里内离福州最近的地址,并按距离由近到远排序。结果如下,由近到远顺序为福州台江,莆田,上海,武汉。
image.png

所以,当你拿起软件查找最近的美食商家的时候,知道它的实现了吗?

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
8月前
|
存储 NoSQL 定位技术
Redis Geo:掌握地理空间数据的艺术
Redis Geo:掌握地理空间数据的艺术
540 0
|
存储 NoSQL Java
|
3月前
|
存储 NoSQL 定位技术
Redis GEO
10月更文挑战第19天
47 1
|
6月前
|
存储 NoSQL 定位技术
如何在Redis中快速推算两地之间的距离?——Geo篇
Redis 3.2 引入Geo类型,支持地理位置数据存储和计算,如距离和范围查询。使用`GEOADD`将城市经纬度添加至`zset`中,通过`GEOPOS`获取坐标,`GEODIST`计算距离,`GEORADIUS`查找指定范围内的城市。Redis的Geo功能适用于快速的地理位置服务,如附近搜索和配送范围分析。利用`ZSET`操作可增删位置数据,简化地理空间应用开发。
98 0
|
8月前
|
SQL NoSQL Java
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
66 0
|
8月前
|
存储 NoSQL API
Redis入门到通关之GEO实现附近的人功能
Redis入门到通关之GEO实现附近的人功能
69 0
|
8月前
|
存储 NoSQL 定位技术
Redis Geo:解锁地理位置数据的新可能性
Redis Geo:解锁地理位置数据的新可能性
240 0
|
8月前
|
NoSQL Java Redis
Spring Boot和Redis Geo实现附近的人【redis实战 三】
Spring Boot和Redis Geo实现附近的人【redis实战 三】
246 0
|
8月前
|
存储 NoSQL Redis
【Redis】Redis 高级数据类型Bitmaps、HyperLogLog、GEO
【Redis】Redis 高级数据类型Bitmaps、HyperLogLog、GEO
79 0
【Redis】Redis 高级数据类型Bitmaps、HyperLogLog、GEO
|
8月前
|
存储 NoSQL 关系型数据库
Redis系列-8.Redis案例实战之Bitmap、Hyperloglog、GEO(下)
Redis系列-8.Redis案例实战之Bitmap、Hyperloglog、GEO
89 0