除了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. LNMP环境搭建Wordpress博客

    目录 LNMP架构工作原理 yum源安装 网站源包安装 LNMP是Linux Nginx MySQL/MariaDB  Php/perl/python 的简称,是近些年才逐渐发展起来的构架,发展非常迅 ...

  2. Day009 二维数组

    多维数组 多维数组是数组的嵌套(数组的元素是数组,数组的数组元素的元素是数组...),比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组. 二维数组 int a[][]=new int ...

  3. Day007 递归

    递归 定义 ​ A方法调A方法!就是自己调自己 作用 ​ 利用递归可以用简单的程序来解决一些复杂的问题.它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程 ...

  4. Codeforces Round #687 (Div. 2, based on Technocup 2021 Elimination Round 2)

    A. Prison Break 题意:就是在一个n*m的矩阵中,以(1,1)为起点(n,m)为终点,每个点以每个单位1s的速度移动,问总共至少需要多少秒,所有的矩阵点就能够全部移动到(r,c)中 思路 ...

  5. Codeforces Round #688 (Div. 2)

    A. Cancel the Trains 题意:给定两个数组,找出这两个数组中有多少重复元素,然后输出 思路:直接找 代码: 1 #include<iostream> 2 #include ...

  6. C++ primer plus读书笔记——第12章 类和动态内存分配

    第12章 类和动态内存分配 1. 静态数据成员在类声明中声明,在包含类方法的文件中初始化.初始化时使用作用域运算符来指出静态成员所属的类.但如果静态成员是整形或枚举型const,则可以在类声明中初始化 ...

  7. NABCD-name not found

    项目 内容 课程 2020春季计算机学院软件工程(罗杰 任健) 作业要求 团队项目选择 项目名称 FOTT 项目内容 在OCR-Form-Tools开源项目的基础上,扩展功能,支持演示更多的API,例 ...

  8. TypeScript 中 Optional Chaining 和 Nullish Coalescing

    Optional Chaining 解决的问题是重复且无意义的判空,之所以说无意义,是对业务来说它不是必需的,但不判空,程序直接就挂了,比如: let x = foo.bar.baz();   这里的 ...

  9. 登陆框select绕过

    0x00 原理   思路来自美团杯2021,本来说出题人已经把select通过正则过滤了,就不该总是往用select进行查询那方面想-> select id from users where u ...

  10. java基础——if和Swith的应用

    顺序结构 java的基本结构就是顺序结构,除非特别说明,否则就按照一句一句的执行 它是任何一个算法都离不开的基本算法结构 选择结构 if单选择 if双选择 if多选择 嵌套的if结构 switch多选 ...