除了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. Linux运维比较常用的一些脚本

    目录 一.根据PID过滤进程所有信息 二.根据进程名过滤进程信息 三.根据用户名查询该用户的相关信息 四.加固系统的一些配置 五:实现磁盘分区的 六.使用一整块硬盘创建逻辑卷 七.将一块硬盘分区,然后 ...

  2. 曾经我认为C语言就是个弟弟

    本文所有代码,均上传至github,如果你想直接看源代码,请到github下载,下载地址:https://github.com/vitalitylee/TextEditor "C语言只能写有 ...

  3. JavaWeb——JDBC

    内容索引 1. JDBC基本概念 2. 快速入门 3. 对JDBC中各个接口和类详解 JDBC: 1. 概念:Java DataBase Connectivity Java 数据库连接, Java语言 ...

  4. 从0开始fastjson漏洞分析

    关于fastjson漏洞利用参考:https://www.cnblogs.com/piaomiaohongchen/p/10799466.html fastjson这个漏洞出来了很久,一直没时间分析, ...

  5. webpack解析(1)

    webpack是为现代js程序准备的静态模块打包工具 一:关于对webpack的理解 可以将其认为是一个电脑主板,由于使用js作为源码,因而其可以默认编译js代码(别种类型的文件可以依靠loaders ...

  6. [bug] Python AttributeError: module 'web' has no attribute 'application'

    原因 文件名是web.py,与包名web冲突 解决 重命名文件,再运行

  7. [刷题] 198 House Robber

    要求 你是一个小偷,每个房子中有价值不同的宝物,但若偷连续的两栋房子,就会触发报警系统,求最多可偷价值多少的宝物 示例 [3,4,1,2],返回6[3,(4),1,(2)] [4,3,1,2],返回6 ...

  8. 性能工具 stream 最新版本5.10 The STREAM benchmark

    官网下载最新性能工具 stream 最新版本5.10 https://github.com/jeffhammond/STREAM 官网下载最新性能工具 stream 最新版本5.10   http:/ ...

  9. CentOS 7.3 安装指南 作者: Matei Cezar 译者: LCTT geekpi

    CentOS 7.3 安装指南 作者: Matei Cezar 译者: LCTT geekpi | 2016-12-20 09:12   评论: 11 收藏: 4 分享: 1 基于 Red Hat 企 ...

  10. Linux 如何查看系统负载

    Linux 如何查看系统负载 310 博客 /  Linux/ 4个月前/  534 /  0   操作系统的负载状态,反映了应用程序的资源使用情况,从中能找出应用程序优化的瓶颈所在. 系统平均负载, ...