Redis GEO

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 关于redis GEO介绍命令可以参考官方文档:http://redis.io/commands/geoadd 主要命令: GEOADD 添加地理位置信息 GEODIST 查询位置距离...

关于redis GEO介绍命令可以参考官方文档:http://redis.io/commands/geoadd
主要命令:
GEOADD 添加地理位置信息
GEODIST 查询位置距离
GEOHASH 查询位置GEOHASH编码
GEOPOS 查询位置的坐标
GEORADIUS 查询某点的附近点
GEORADIUSBYMEMBER 查询某位置距离的附近点
如果要演示redis GEO功能我们需要下载Unstable版本进行编译安装,可以在官网下载:http://redis.io/download或到github去下载最新Unstable版本代码编译:https://github.com/antirez/redis
关于安装请参考:http://blog.csdn.net/zhu_tianwei/article/details/44890579
下面我们来演示一下命令:
1.添加位置信息
[plain] view plain copy print?
192.168.1.90:6379>
192.168.1.90:6379> GEOADD Guangdong-cities 113.2099647 23.593675 Qingyuan
(integer) 1
192.168.1.90:6379> GEOADD Guangdong-cities 113.2278442 23.1255978 Guangzhou 113.106308 23.0088312 Foshan 113.7943267 22.9761989 Dongguan 114.0538788 22.5551603 Shenzhen
(integer) 4
192.168.1.90:6379>
2.查询位置距离
[plain] view plain copy print?
192.168.1.90:6379> GEODIST Guangdong-cities Qingyuan Guangzhou km

192.168.1.90:6379>
3.查询位置GEOHASH编码
[plain] view plain copy print?
192.168.1.90:6379> GEOHASH Guangdong-cities Qingyuan Guangzhou
1) “ws0w0phgp70”
2) “ws0e89curg0”
192.168.1.90:6379>
4.查询位置的坐标
[plain] view plain copy print?
192.168.1.90:6379> GEOPOS Guangdong-cities Qingyuan Guangzhou Foshan
1) 1) “113.20996731519699”
2) “23.593675019671288”
2) 1) “113.22784155607224”
2) “23.125598202060807”
3) 1) “113.10631066560745”
2) “23.008831202413539”
192.168.1.90:6379>
5.查询某点的附近点
[plain] view plain copy print?
192.168.1.90:6379> GEORADIUS Guangdong-cities 113.2278442 23.1255978 50 km asc
1) “Guangzhou”
2) “Foshan”
192.168.1.90:6379>
6.查询某位置距离的附近点
[plain] view plain copy print?
192.168.1.90:6379> GEORADIUSBYMEMBER Guangdong-cities Guangzhou 50 km asc
1) “Guangzhou”
2) “Foshan”
192.168.1.90:6379>
使用redis Java客户端jedis实例;
由于jedis并没有实现redis GEO的命令,测试使用lua脚本来实现:
[java] view plain copy print?
package test;

import java.util.List;

import redis.clients.jedis.Jedis;

public class Test {
private static Jedis jedis = null;
static{
jedis = new Jedis(“192.168.1.90”, 6379);
}

public static void main(String[] args) throws Exception {  
    System.out.println(geoADD("beijing", 116.312014, 39.963019,"haidian"));  
    System.out.println(geoADD("beijing", 116.227501, 39.90858,"shijingshan"));  
    System.out.println(geoADD("beijing", 116.297641, 39.861631,"fengtai"));  
    System.out.println(geoADD("beijing", 116.428146, 39.9316,"dongcheng"));  
    System.out.println(geoADD("beijing", 116.375829, 39.920091,"xicheng"));  
    System.out.println(geoADD("beijing", 116.110793, 39.943992,"mentougou"));  
    System.out.println(geoADD("beijing", 116.480464, 39.95948,"caoyang"));  
    System.out.println(geoADD("beijing", 116.663862, 39.916107,"tongzhou"));  
    System.out.println(geoADD("beijing", 116.349383, 39.729911,"daxing"));  
    System.out.println(geoADD("beijing", 116.157361, 39.748109,"fangshan"));  
    System.out.println(geoADD("beijing", 116.662137, 40.134017,"sunyi"));  
    System.out.println(geoADD("beijing", 116.2367, 40.224862,"changping"));  
    System.out.println(geoADD("beijing", 117.141617, 40.14196,"pinggu"));  
    System.out.println(geoADD("beijing", 116.64144, 40.316466,"huairou"));  


     System.out.println(geoHash("beijing","haidian"));  
     System.out.println(geoDist("beijing","haidian","shijingshan","km"));  
     System.out.println(geoPos("beijing","haidian"));  
     System.out.println(geoRadius("beijing",116.421822, 39.906809,10,"km",false));  
     System.out.println(geoRadiusByMember("beijing","dongcheng",10,"km",true));  
}  
/** 
 * 添加geo 
 * @param key  
 * @param longitude 
 * @param latitude 
 * @param name 位置名称 
 * @return 
 */  
public static Long geoADD(String key,double longitude,double latitude,String dName){  
    return (Long)jedis.eval("return redis.call('GEOADD',KEYS[1],KEYS[2],KEYS[3],KEYS[4])", 4,key,String.valueOf(longitude),String.valueOf(latitude),dName);  
}  

/** 
 * 查询2位置距离 
 * @param key 
 * @param d1 
 * @param d2 
 * @param unit 
 * @return 
 */  
public static Double geoDist(String key,String d1,String d2,String unit){  
    return Double.valueOf((String)jedis.eval("return redis.call('GEODIST',KEYS[1],KEYS[2],KEYS[3],KEYS[4])",4, key,d1,d2,unit));  
}  

/** 
 * 查询位置的geohash 
 * @param key 
 * @param dName 
 * @return 
 */  
public static String geoHash(String key,String dName){  
     Object data = jedis.eval("return redis.call('GEOHASH',KEYS[1],KEYS[2])", 2, key,dName);  
      List<String> resultList = (List<String>)data;  
      if(resultList!=null&&resultList.size() > 0){  
          return resultList.get(0);  
      }  
      return null;  
}  

/** 
 * 查询位置坐标 
 * @param key 
 * @param dName 
 * @return 
 */  
public static List<Double> geoPos(String key,String dName){  
     Object data = jedis.eval("return redis.call('GEOPOS',KEYS[1],KEYS[2])", 2, key,dName);  
      List<List<Double>> resultList = (List<List<Double>>)data;  
      if(resultList!=null&&resultList.size() > 0){  
          return resultList.get(0);  
      }  
      return null;  
}  

/** 
 * 查询附近坐标地址 
 * @param key 
 * @param longitude 
 * @param latitude 
 * @param unit 
 * @param asc 
 * @return 
 */  
public static List<String> geoRadius(String key,double longitude,double latitude,int radius,String unit,boolean asc){  
     Object data = jedis.eval("return redis.call('GEORADIUS',KEYS[1],KEYS[2],KEYS[3],KEYS[4],KEYS[5],KEYS[6])", 6, key,String.valueOf(longitude),  
             String.valueOf(latitude),String.valueOf(radius),unit,asc?"ASC":"DESC");  
      return (List<String>)data;  
}  

/** 
 * 根据位置查询附近点 
 * @param key 
 * @param dName 
 * @param unit 
 * @param asc 
 * @return 
 */  
public static List<String> geoRadiusByMember(String key,String dName,int radius,String unit,boolean asc){  
     Object data = jedis.eval("return redis.call('GEORADIUSBYMEMBER',KEYS[1],KEYS[2],KEYS[3],KEYS[4],KEYS[5])", 5, key,dName,String.valueOf(radius),unit,asc?"ASC":"DESC");  
     return (List<String>)data;  
}  

}
增加jar包依赖:
[html] view plain copy print?

redis.clients
jedis
2.7.3

参考文章:
1.redis官网lua脚本
2.spring+springdata redis入门教程实现java端调用redis lua脚本片段和lua脚本文件
3.利用redis + lua解决抢红包高并发的问题

原文地址:
http://blog.csdn.net/zhu_tianwei/article/details/49149699
其他介绍:
http://blog.jobbole.com/89225/

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