LBS-查找附近的人-redis命令实现

前面介绍了地理坐标定位相关的基础知识和查找附近人的MySQL版实现,本则主要介绍redis版的实现。

在redis的3.2版本开始支持geo的功能,这个功能可以将用户给定的地理位置信息储存起来, 并对这些信息进行操作。

本文环境

MACOS10.13.4+8G内存+2.6GHz+redis4.0.2

命令

redis的geo命令一共是6个,redis-geo在没有被集成到redis中只是一个附属模块的时候有更多的命令,在集成到redis中后被精简到了6个。我们先通过redis的命令熟悉这六条命令,然后再通过spring-data-redis集成到项目中,实现我们要做的查找附近的人。

注意:上一篇讲的mysql版本的Point(纬度,经度),纬度再前,经度在后。而在redis中是经度在前,维度在后。

中文显示乱码解决方案:./redis-cli -a redis-pass --raw,就是在命令后加 --raw, 加了 --raw 之后放回结果就没有格式化了,看起来比较不友好。项目中最好不要使用中文, 避免出现一些莫名其妙的问题。

GEOADD

GEOADD key longitude latitude member [longitude latitude member ...]

添加一个或多个地理空间位置到sorted set

单一添加,返回值:如果成员是新的,则返回 1 ;如果成员被更新,则返回 0。

127.0.0.1:6379> geoadd geo_test 120.1384162903 30.2532102251 "杭州香格里拉大酒店"
1

多添加,返回值:提交成员的数量。

127.0.0.1:6379> geoadd geo_test 120.1333737373 30.2535809303 "华北饭店" 120.1258850098 30.2592154766 "杭州玉泉饭店" 120.1365065575 30.2637377076 "浙江图书馆" 120.1337170601 30.2659987449 "黄龙体育馆" 120.1510977745 30.2673701685 "弥陀寺公园"
5

浏览底层zset

127.0.0.1:6379> zrange geo_test 0 -1
华北饭店
杭州香格里拉大酒店
杭州玉泉饭店
浙江图书馆
黄龙体育馆
弥陀寺公园

GEOHASH

GEOHASH key member [member ...]

返回一个标准的地理空间的Geohash字符串。

127.0.0.1:6379> GEOHASH geo_test "华北饭店" "杭州香格里拉大酒店"
wtmkjeqryk0
wtmkjg6jsp0

GEOPOS

GEOPOS key member [member ...]

返回地理空间的经纬度。当给定的位置元素不存在时,对应的数组项为空值。

127.0.0.1:6379> GEOPOS geo_test "华北饭店" "杭州香格里拉大酒店" NonExisting
120.13337105512619019
30.25358135892076206
120.13841897249221802
30.2532112896315013

GEODIST

GEODIST key member1 member2 [unit]

返回两个地理空间之间的距离。如果两个位置之间的其中一个不存在,那么命令返回空值。

指定单位的参数 unit 必须是以下单位的其中一个:

  • m 表示单位为米。
  • km 表示单位为千米。
  • mi 表示单位为英里。
  • ft 表示单位为英尺。

如果用户没有显式地指定单位参数, 那么 GEODIST 默认使用米作为单位。
GEODIST 命令在计算距离时会假设地球为完美的球形, 在极限情况下, 这一假设最大会造成 0.5% 的误差。

127.0.0.1:6379> GEODIST geo_test "华北饭店" "杭州香格里拉大酒店"
486.7369
127.0.0.1:6379> GEODIST geo_test "华北饭店" "杭州香格里拉大酒店" km
0.4867

GEORADIUS

GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count]

查询指定半径内所有的地理空间元素的集合。

以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。

范围可以使用以下其中一个单位:

  • m 表示单位为米。
  • km 表示单位为千米。
  • mi 表示单位为英里。
  • ft 表示单位为英尺。

在给定以下可选项时, 命令会返回额外的信息:

  • WITHDIST: 在返回位置元素的同时, 将位置元素与中心之间的距离也一并返回。 距离的单位和用户给定的范围单位保持一致。
  • WITHCOORD: 将位置元素的经度和维度也一并返回。
  • WITHHASH: 以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大。

命令默认返回未排序的位置元素。 通过以下两个参数, 用户可以指定被返回位置元素的排序方式:

  • ASC: 根据中心的位置, 按照从近到远的方式返回位置元素。
  • DESC: 根据中心的位置, 按照从远到近的方式返回位置元素。

在默认情况下,GEORADIUS 命令会返回所有匹配的位置元素。 虽然用户可以使用 COUNT <count> 选项去获取前 N 个匹配元素, 但是因为命令在内部可能会需要对所有被匹配的元素进行处理,所以在对一个非常大的区域进行搜索时,即使只使用 COUNT 选项去获取少量元素,命令的执行速度也可能会非常慢。但是从另一方面来说,使用 COUNT 选项去减少需要返回的元素数量,对于减少带宽来说仍然是非常有用的。

127.0.0.1:6379> GEORADIUS geo_test 120.1333737373 30.2535809303 1000 m WITHDIST WITHCOORD
华北饭店
0.2621
120.13337105512619019
30.25358135892076206
杭州香格里拉大酒店
486.4761
120.13841897249221802
30.2532112896315013
杭州玉泉饭店
954.0041
120.12588769197463989
30.25921604405797183

GEORADIUSBYMEMBER

GEORADIUSBYMEMBER key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count]

查询指定半径内匹配到的最大距离的一个地理空间元素。参数可以参考 GEORADIUS 命令

127.0.0.1:6379> GEORADIUSBYMEMBER geo_test "华北饭店" 1 km
华北饭店
杭州香格里拉大酒店
杭州玉泉饭店

参考 www.redis.cn

请看下篇redis+spring实现。

文章同步发布在博客,LBS-查找附近的人-redis命令实现

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容