Redis以及Jedis的GEO地图功能
引言:redis是一个高性能的非关系型数据库,作为一个单线程的应用程序,速度非常快。并且不存在多线程情况下的共同资源访问锁的问题。
PS:太久没有写文章,老脸一红。今日记录一下Redis的地图坐标功能
一、Redis介绍
Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
在Java开发中,Redis是一款经常使用的Nosql数据库,无论是做计数、缓存还是分布式共享Session都非常方便
Redis 与其他 key - value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
- Redis支持事务,但是事务功能不是很完善,不推荐使用
二、Redis优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
三、Redis坐标功能语法
今天主要来说说计数功能
Redis3.2版本提供了GEO(地理位置定位)功能(注意:只有3.2以上的Redis版本才能使用),支持存储地理位置信息来实现诸如附近位置、摇一摇这类依赖于地理位置信息的功能,对于需要实现这些功能的开发者来说是一大福音。GEO功能是Redis的另一做着Matt Stancliff借鉴NoSQL数据库Ardb实现的,Ardb的作者是一名中国人,它提供了优秀的GEO功能。
先来说说Redis的原生语法
![](https://i-blog.csdnimg.cn/blog_migrate/9fa5922ebcb9452b1c7f12e98e9439f8.png)
参数介绍:
geoadd: redis 语法,固定关键字
key: 一系列点的集合Key
longitude: 经度
latitude: 纬度
member: 具体的经纬度的点的名字
例子:geoadd points 104.074977 30.560872 世纪城地铁站
![](https://i-blog.csdnimg.cn/blog_migrate/66fcb31d28b9c1326a4a52e6bc86877d.png)
根据某个点的名字来获取经纬度信息
![](https://i-blog.csdnimg.cn/blog_migrate/09ffa8d5c0eada6e3c5a807770655d1e.png)
![](https://i-blog.csdnimg.cn/blog_migrate/5d598350c51b2d0023f25947cb6f8ddd.png)
georadius : 根据某个点,查出其周围半径为radiusm的点
georadiusbymember : 根据某个点的名字找到那个点,然后找其周围半径为radiusm的点
![](https://i-blog.csdnimg.cn/blog_migrate/3cc8cef2d37f49a1e12e1ba8adeb240b.png)
例子:georadiusbymember points beijing 150km
例子2: georadius points 104.074977 30.560872 2km
![](https://i-blog.csdnimg.cn/blog_migrate/ed69a5fe1f11ba1dc3fdd8cb3821ce4b.png)
四、Redis的Geo与java的结合
当然,上面那么多东西并不是我们Java程序员实际关心的语法,我们关心的更多还是上面的那些语法与Java的一个结合。
下面我们就根据一个demo程序来具体来看geo的用法
demo中使用的是springboot程序
首先是pom.xml配置文件
![](https://i-blog.csdnimg.cn/blog_migrate/fa16ee19fb2d44d50703ccbb39aba0f5.png)
注:spring-boot-starter-data-redis中包含了Jedis的依赖包
然后是Jedis相关Bean的配置
![](https://i-blog.csdnimg.cn/blog_migrate/fddb19e3134aca279ad007ebdd491e36.png)
接下来就是Geo的相关的Jedis工具类
![](https://i-blog.csdnimg.cn/blog_migrate/28c65736e3a6dce0f59a80e7c3df8a0a.png)
![](https://i-blog.csdnimg.cn/blog_migrate/90a5ad276bae7ae907728cd6a5ba6e37.png)
![](https://i-blog.csdnimg.cn/blog_migrate/450e417b463faba27b485abff0a34993.png)
最后一个controller来控制
![](https://i-blog.csdnimg.cn/blog_migrate/436689b9d1aee8fdee0d01ce016c5192.png)
注:该controller只是用于测试geo的功能,写得比较简陋。。。
一切搞定后,我们就开始测试该程序是否起作用。
先是向redis中添加坐标
![](https://i-blog.csdnimg.cn/blog_migrate/3b0a77450dde348e1fd8f02900b8fc83.png)
![](https://i-blog.csdnimg.cn/blog_migrate/a13bdc6b372a644f47ad0198695a8bde.png)
然后看是否能根据某个点,查找周围的点
当距离为三公里事,可以找到先前添加的两个点
![](https://i-blog.csdnimg.cn/blog_migrate/9bb087a1e1161b197e3ebbf8be43affd.png)
当距离为两公里时,就不能找到"世纪城地铁口"
![](https://i-blog.csdnimg.cn/blog_migrate/25a79ed5c54e45c3c21b46ad4746cc38.png)
以下地图中红色圈的位置,是我文章中用到的三个点坐标
![](https://i-blog.csdnimg.cn/blog_migrate/fe6af318d65e33048f026e03339c647e.jpeg)
到这里,已经可以证明,Redis的周围坐标功能起了作用。
五、总结
这个功能在做摇一摇或者周边餐饮、车辆时非常有用
当然,使用百度JSPAPI也可以实现这个功能,不过要引入第三方的依赖。
比较简单的功能,完全可以使用Redis的GEO功能来实现。
以上,是Redis的GEO功能,感谢阅读。