除了Bitmaps和HyperLogLog,Redis还提供了关于地理空间的相关操作,主要是经纬度。Redis提供的地理信息操作是有误差的,最大误差可能会达到5%。Redis提供的Geo的操作如下:

  • geoadd

完整命令参数为geoadd key longitude latitude member [longitude latitude member ...]

将指定的地理空间位置(纬度、经度、名称)添加到指定的key中。下面的例子是把广州塔(113.324553,23.106414)和中山纪念堂(113.264692,23.13286)添加到guangzhou这个key中

127.0.0.1:6379> geoadd guangzhoudibiao 113.324553 23.106414 guangzhouta 113.264692 23.13286 zhongshanjiniantang

在线获取地点的经纬度可以到高德地图网站查看。

  • geopos

完整命令参数为geopos key member [member ...]

获取key中指定位置的经纬度。比如获取广州塔的经纬度

127.0.0.1:6379> geopos guangzhoudibiao guangzhouta
1) 1) "113.3245512843132019"
2) "23.10641289760576456"

也可以一次性指定多个位置

127.0.0.1:6379> geopos guangzhoudibiao guangzhouta zhongshanjiniantang
1) 1) "113.3245512843132019"
2) "23.10641289760576456"
2) 1) "113.26468974351882935"
2) "23.13286017818230533"

结果会以列表的形式显示,每个位置中的1)是经度,2)是维度。

  • geodist

完整命令参数为geodist key member1 member2 [unit]

返回地址member1和member2的距离,unit是单位,可以是下面几种

m:米

km:千米

mi:英里

ft:英尺

默认单位是米

比如看一下广州塔与中山纪念堂之间的距离

127.0.0.1:6379> geodist guangzhoudibiao guangzhouta zhongshanjiniantang km
"6.7934"

显示是6.79公里,注意这是直线距离,不是路线。有兴趣的可以在高德地图或者百度地图用测距的功能对比一下。

  • georadius

完整命令参数为georadius key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC|DESC] [STORE key] [STOREDIST key]

这个命令比较有意思,它返回的是以经纬度(longitude, latitude)为中心,radius为半径范围内key中符合的位置。其中m|km|ft|mi是半径的单位,含义和geodist相同。它有几个可选参数:

WITHCOORD:将位置的经纬度也一并返回

WITHDIST:将位置与中心的距离返回,单位与指定的半径的单位相同。

WITHHASH:以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大。

count:指定返回的个数,用法和MySQL的Limit类似。

ASC|DESC:默认情况下返回的数据不会排序,可以指定ASC升序或者DESC降序。这里的升序降序的排序规则是位置到中心点的距离。

以下的例子先多增加几个位置,然后计算某个地址的指定范围的其它位置

127.0.0.1:6379> geoadd guangzhoudibiao 113.264499 23.130061 guangzhoushizhengfu
(integer) 1
127.0.0.1:6379> geoadd guangzhoudibiao 113.326336 23.11475 guangdongbowuguan
(integer) 1
127.0.0.1:6379> geoadd guangzhoudibiao 113.298415 23.096714 zhongshandaxue
(integer) 1
127.0.0.1:6379> georadius guangzhoudibiao 113.264499 23.130061 5 km withdist
1) 1) "guangzhoushizhengfu"
2) "0.0003"
2) 1) "zhongshanjiniantang"
2) "0.3120"

上面的例子先增加了广州市政府、广东博物馆、中山大学3个位置,然后以广州市政府为中心,查找所有5km之内的位置,最后找到了自身和中山纪念堂。

我们使用的美团、大众点评等应用会在列表中的店显示与你当前距离,这种场景下用georadius 命令就很有用了,另外很多IM应用的附近的人也可以用这个命令来实现。

  • georadiusbymember

完整命令参数为georadiusbymember key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC|DESC] [STORE key] [STOREDIST key]

在上面的georadius你可能发现了一个问题,就是我们在实际使用的时候往往更加关心某个位置附近的其它位置,这里的位置是一个具体的地点,比如广州市政府,我们根本不关心广州市政府的经纬度是什么,所以这个命令是通过位置名称来查找的,它与georadius命令唯一的不同就是,它指定的是位置名称,而georadius指定的是经纬度

比如我们还是查找广州市政府附近5km的其它位置

127.0.0.1:6379> georadiusbymember guangzhoudibiao guangzhoushizhengfu 5 km withdist
1) 1) "guangzhoushizhengfu"
2) "0.0000"
2) 1) "zhongshanjiniantang"
2) "0.3119"

Redis系列(四):地理信息的更多相关文章

  1. Redis系列(四):Redis的复制机制(主从复制)

    本篇博客是Redis系列的第4篇,主要讲解下Redis的主从复制机制. 本系列的前3篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安装 Redis系列(二):Redis的5种数据 ...

  2. Redis系列四之复制

    一.复制基本配置与演示 为了避免单点故障,Redis提供了复制功能,可以实现自动同步的过程. 1.配置 同步后的数据分为两类:一类是主数据库(master),一类是从数据库(slave).主数据库可以 ...

  3. Redis系列四:redis支持的数据类型

    一.字符串<String> 1. 字符串类型:实际上可以是字符串(包括XML JSON),还有数字(整形 浮点数),二进制(图片 音频 视频),最大不能超过512MB 2. 设值命令: s ...

  4. Redis系列四 Redis常见配置

    redis.conf常见配置 参数说明redis.conf 配置项说明如下:1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程  daemonize no2. ...

  5. Redis系列四 - 分布式锁的实现方式

    前言 分布式锁一般有3中实现方式: 数据库乐观锁: 基于Redis的分布式锁: 基于ZooKeeper的分布式锁. 以下将详细介绍如何正确地实现Redis分布式锁. 可靠性 首先,为了确保分布式锁的可 ...

  6. Redis系列(四)-低成本高可用方案设计

    关于Redis高可用方案,看到较多的是keepalived.zookeeper方案. keepalived是主备模式,意味着总有一台浪费着.zookeeper工作量成本偏高. 本文主要介绍下使用官方s ...

  7. Redis系列四(keepalived+lvs搭建负载均衡)

    1.安装Keepalived(主备服务器都要安装) 10.8.80.218  主服务器 10.8.80.217  备服务器 10.8.80.200  虚拟IP $ wget http://www.ke ...

  8. Redis系列(四)--持久化

    持久化就是将数据的更新异步的保存到磁盘中 持久化方式: 1.快照:某个时间点数据的备份 MySQL dump.Redis RDB 2.写日志:MySQL BinLog.HBASE Hlog.Redis ...

  9. Redis系列(五):Redis的过期键删除策略

    本篇博客是Redis系列的第5篇,主要讲解下Redis的过期键删除策略. 本系列的前4篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安装 Redis系列(二):Redis的5种数 ...

  10. Redis系列(六):设置/移除键的过期时间

    本篇博客是Redis系列的第6篇,主要讲解以下内容: 数据库数量 切换目标数据库 设置键的过期时间 移除键的过期时间 本系列的前5篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安 ...

随机推荐

  1. hdu4302 set或者线段树

    题意:       一条蛇生活在一个管子里,然后管子上面的某些位置会一次出现食物,每次蛇都会吃最近的食物,吃完之后就原地不动,等待下一次吃食物,如果有两个食物距离蛇一样远并且都是最近的,那么蛇不会掉头 ...

  2. [CTF]摩斯电码

    摩尔斯电码 -----------转载 https://morse.supfree.net/ 摩尔斯电码定义了包括:英文字母A-Z(无大小写区分)十进制数字0-9,以及"?"&qu ...

  3. Day001 Typora Markdown语法学习

    # Markdown语法 ## 标题 ### 三级标题 #### 四级标题 注:最多支持到六级标题 ## 字体 **hello,world!** *hello,world!* ***hello,wor ...

  4. MySQL 8.0配置文件my.ini文件位置

    文件位置 C:\ProgramData\MySQL\MySQL Server 8.0 如果看不到ProgramData文件夹,可能是被隐藏了.打开显示隐藏文件夹选项即可

  5. SpringBoot JPA + 分页 + 单元测试SpringBoot JPA条件查询

    application.properties 新增数据库链接必须的参数 spring.jpa.properties.hibernate.hbm2ddl.auto=update 表示会自动更新表结构,所 ...

  6. PHP解压压缩包文件到指定目录的实现

    $src_file为文件路径,上传文件返回压缩包路径即可 public function unzip($src_file, $dest_dir=false, $create_zip_name_dir= ...

  7. Junit单元测试&反射&注解

    内容索引 1. Junit单元测试 2. 反射 3. 注解 Junit单元测试: * 测试分类: 1. 黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2. 白盒测试:需要写代码的.关 ...

  8. GDI编程基础

    窗口和视口 视口是基于设备的采用的是设备坐标(单位:像素),窗口是基于程序的采用的是逻辑坐标(单位:像素/毫米/厘米等). 在默认的映射模式下,视口是与窗口等同的.但是如果改变其映射模式,则其对应的单 ...

  9. GPUImage移植总结

    项目github地址: aoce 我是去年年底才知道有GPUImage这个项目,以前也一直没有在移动平台开发过,但是我在win平台有编写一个类似的项目oeip(不要关注了,所有功能都移植或快移植到ao ...

  10. Linux是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的性能稳定的操作系统,可免费使用并自由传播。

    Linux是一个基于POSIX和Unix的多用户.多任务.支持多线程和多CPU的性能稳定的操作系统,可免费使用并自由传播. Linux是众多操作系统之一 , 目前流行的服务器和 PC 端操作系统有 L ...