聊聊Redis中的GEO地理位置模块


geo是 redis 在3.2版本之后新增的地理位置模块,下面本篇文章带大家了解一下geo地理位置模块,希望对大家有所帮助!

聊聊Redis中的GEO地理位置模块

GEO是 Redis 在3.2版本之后新增的地理位置模块,意味可以用 Redis 来实现附近的地点功能。【相关推荐:Redis视频教程】

用数据库计算

1.png

一般的方法都是通过矩形区域来限定元素的数量,然后对区域内的元素进行全量距离计算再排序。这样可以明显减少计算量。

select id from positions where x0-r < x < x0+r and y0-r < y < y0+r

以上SQL为了增加性能,需要在经纬度坐标加上双向复合索引。 但是数据库查询性能毕竟有限,如果在高并发场合,这可能并不是一个很好的方案。

GEO算法

  • 业界比较通用的地理位置距离排序算法是 GeoHash 算法,Redis 也使用 GeoHash 算法。
  • GeoHash 算法将 二维的经纬度数据映射到一维的整数,这样所有的元素都将在挂载到一条线上,距离靠近的二维坐标映射到一维后的点之间距离也会很接近。当我们想要计算「附近的人时」,首先将目标位置映射到这条线上,然后在这个一维的线上获取附近的点就行了。
  • 算法实现,它将整个地球看成一个 二维平面,然后划分成了一系列正方形的方格,就好比围棋棋盘。所有的地图元素坐标都将放置于唯一的方格中。方格越小,坐标越精确。然后对这些方格进行整数编码,越是靠近的方格编码越是接近。
  • 编码之后,每个地图元素的坐标都将变成一个整数,通过这个整数可以还原出元素的坐标,整数越长,还原出来的坐标值的损失程度就越小。
  • GeoHash 算法会继续对这个整数做一次 base32 编码 (0-9,a-z 去掉 a,i,l,o 四个字母) 变成一个字符串。
  • 在 Redis 里面,经纬度使用 52 位的整数进行编码,放进了 zset 里面,zsetvalue 是元素的 keyscoreGeoHash 的 52 位整数值。
  • 在使用 Redis 进行 Geo 查询时,我们要时刻想到它的内部结构实际上只是一个 zset(skiplist)。通过 zsetscore 排序就可以得到坐标附近的其它元素 (实际情况要复杂一些,不过这样理解足够了),通过将 score 还原成坐标值就可以得到元素的原始坐标。

Redis GEO指令

2.png

1. 增加 geoadd

geoadd key longitude latitude member [longitude latitude member ...]
127.0.0.1:6379> geoadd beijing 116.403856 39.924043 gugong
(integer) 1
127.0.0.1:6379> geoadd beijing 116.343620 39.947633 dongwuyuan
(integer) 1
127.0.0.1:6379> geoadd beijing 116.328643 39.900272 xizhan 116.415324 39.931231 meishuguan 116.416852 39.887607 tiantan
(integer) 3

删除用 zset 的 zrem 即可

2. 距离 geodist

geodist key member1 member2 [unit]
127.0.0.1:6379> geodist beijing gugong xizhan km
"6.9402"
127.0.0.1:6379> geodist beijing gugong dongwuyuan   # 默认单位m
"5768.5737"
127.0.0.1:6379> geodist beijing xizhan xizhan
"0.0000"

距离单位可以是 m、km、ml、ft,分别代表米、千米、英里和尺。

3. 位置 geopos

geopos key member [member ...]
127.0.0.1:6379> geopos beijing gugong
1) 1) "116.4038559794426"
   2) "39.92404192186725"
127.0.0.1:6379> geopos beijing tiantan xizhan
1) 1) "116.41685396432877"
   2) "39.887607839922914"
2) 1) "116.32864147424698"
   2) "39.900271306834973"

4. hash值 geohash

佳蓝智能应答系统 佳蓝智能应答系统

类似智能机器人程序,以聊天对话框的界面显示,通过输入问题、或点击交谈记录中的超链接进行查询,从而获取访客需要了解的资料等信息。系统自动保留用户访问信息及操作记录。后台有详细的设置和查询模块。适用领域:无人职守的客服系统自助问答系统智能机器人开发文档、资源管理系统……基本功能:设置对话界面的显示参数设置各类展示广告根据来访次数显示不同的欢迎词整合其他程序。

佳蓝智能应答系统 4 查看详情 佳蓝智能应答系统
geohash key member [member ...]
127.0.0.1:6379> geohash beijing gugong
1) "wx4g0gfwqk0"

经纬度字符串编码是 base32 编码,可以通过 http://geohash.org/wx4g0gfwqk0 直接查找经纬度

5. 附近地点 georadiusbymember

1、查询 ireader 范围 20 公里以内最多 3 个元素按距离正排,它不会排除自身(倒排使用用 desc

127.0.0.1:6379> georadiusbymember company ireader 20 km count 3 asc
1) "ireader"
2) "juejin"
3) "meituan"

2、三个可选参数 withcoord withdist withhash 用来携带附加参数, withdist 很有用,它可以用来显示距离

georadiusbymember key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC|DES]
127.0.0.1:6379> georadiusbymember beijing gugong 5 km withcoord withdist withhash count 3 asc
1) 1) "gugong"
   2) "0.0000"
   3) (integer) 4069885568932443
   4) 1) "116.4038559794426"
      2) "39.92404192186725"
2) 1) "meishuguan"
   2) "1.2634"
   3) (integer) 4069885710390435
   4) 1) "116.41532510519028"
      2) "39.93123039107514"
3) 1) "tiantan"
   2) "4.2014"
   3) (integer) 4069885398502557
   4) 1) "116.41685396432877"
      2) "39.887607839922914"

3、根据坐标值来查询附近的元素

 georadius key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC|DES]
127.0.0.1:6379> georadius beijing 116.383882 39.922061 5 km withcoord withdist withhash count 3 asc
1) 1) "gugong"
   2) "1.7180"
   3) (integer) 4069885568932443
   4) 1) "116.4038559794426"
      2) "39.92404192186725"
2) 1) "meishuguan"
   2) "2.8693"
   3) (integer) 4069885710390435
   4) 1) "116.41532510519028"
      2) "39.93123039107514"
3) 1) "dongwuyuan"
   2) "4.4588"
   3) (integer) 4069879836419688
   4) 1) "116.34361892938614"
      2) "39.94763257169722"

注意事项

实际应用中数据可能会有百万千万条,我们知道 Redis Geo 将全部放在一个 zset 集合中。在 Redis 的集群环境中,集合可能会从一个节点迁移到另一个节点,如果单个 key 的数据过大,会对集群的迁移工作造成较大的影响,在集群环境中单个 key 对应的数据量不宜超过 1M,否则会导致集群迁移出现卡顿现象,影响线上服务的正常运行。

所以,这里建议 Geo 的数据使用单独的 Redis 实例部署,不使用集群环境。

如果数据量过亿甚至更大,就需要对 Geo 数据进行拆分,按国家拆分、按省拆分,按市拆分,在人口特大城市甚至可以按区拆分。这样就可以显著降低单个 zset 集合的大小。

更多编程相关知识,请访问:编程视频!!

以上就是聊聊Redis中的GEO地理位置模块的详细内容,更多请关注其它相关文章!


# 都是  # 淮南专业网站建设  # 吉林先进网站建设特征  # 国美电器网站建设需要  # 网站推广实践报告  # 巴中建设网站哪家好  # 淮阴专业seo优化服务  # 越秀区网站优化报价公告  # 嘉兴企业营销推广哪家好  # 蒲江县电子商务网站建设  # 联盟网站建设方案  # 是一个  # Redis  # 人时  # 越小  # 如何实现  # 网络带宽  # 坐标值  # 都将  # 就可以  # 线上  # 地理位置模块  # GEO 


相关栏目: 【 Google疑问12 】 【 Facebook疑问10 】 【 优化推广96088 】 【 技术知识133117 】 【 IDC资讯59369 】 【 网络运营7196 】 【 IT资讯61894


相关推荐: Bootstrap 5导航栏折叠功能失效:数据属性迁移指南  鲁班大师乓乓皮肤获取方法  mysql如何配置从库只读_mysql从库只读设置方法  铁拳8在线玩 铁拳8在线秒玩入口  抖音号显示企业机构号是什么意思?企业机构号申请条件是什么?  我的世界官方网址入口 我的世界游戏主页直达入口  邮编号码查询app有哪些_邮编号码查询推荐app及使用体验  《大学搜题酱》官网地址登录  《荔枝fm》导出文件教程  《暗黑破坏神4》国服回归送狂欢礼包 价值6916元  Linux如何自动分析系统异常日志_Linux日志智能检测  性能与资源监视器快捷打开  吃完饭就犯困是什么原因 餐后嗜睡如何缓解  冬季去寒冷地区旅游,以下哪种做法有助于缓解冻伤  我居然低估了 DeepSeek,这次更新它做到了这些!  Google Drive API 认证:服务账户与OAuth 2.0的选择与实践  mysql如何回滚事务_mysql ROLLBACK事务回滚方法  《雅迪智行》用手机开锁方法  win11怎么更改账户类型 Win11标准用户和管理员权限切换【教程】  AO3永久镜像入口开放_AO3最新网址兼容所有浏览器  Word如何将文字快速转成表格 Word文本转换成表格功能使用技巧【效率】  菜鸟裹裹怎样获得取件码_菜鸟裹裹获得取件码步骤  c++20的指定初始化(Designated Initializers)怎么用_c++ C风格结构体初始化  J*aScript装饰器_元编程实战  Excel如何制作月度销售统计图_Excel动态图表制作与控件应用  TikTok视频播放不流畅怎么办 TikTok视频播放优化方法  win11怎么设置默认终端为Windows Terminal Win11替代CMD和PowerShell【技巧】  批改网官网首页登录 批改网学生用户登录入口  2025SNH48年度青春盛典门票价格及购买方式  《oppo商城》维修服务位置  《咸鱼之王》新版孙坚技能解析  J*a中为什么强调组合优于继承_组合模式带来的灵活性与可维护性解析  PDF文件去水印平台入口 PDF水印删除网址  CSS如何使用outline-offset与颜色组合突出元素边框  顺丰快递怎么查物流_顺丰快递物流信息实时查询操作指南  汽水音乐网页端访问 汽水音乐官方网页直达  可米酷漫画在线阅读入口_ 可米酷漫画官网直达链接  抖音团长模式怎么做?团长模式是什么意思?  123网页端官方登录页 123邮箱网页版即时通讯服务  VS Code中的Tailwind CSS IntelliSense插件使用技巧  小红书网页版怎么进 小红书网页版通用入口  《飞猪旅行》购买汽车票方法  从HTML表单获取逗号分隔值并转换为NumPy数组进行预测  TikTok网页版实时观看入口 TikTok网页版短视频在线浏览  漫蛙manwa漫画官网链接_漫蛙manwa最新可用网址推荐  使用 .htaccess 正确配置 WordPress 子目录重定向与路径保留  windows10怎么关闭自动安装应用_windows10禁止推广应用下载  安居客移动经纪人怎么设置自动回复?-安居客移动经纪人设置自动回复的方法  b站怎么查看视频的码率_b站视频码率查看方法  实时数据流中高效查找最小值与最大值 

 2021-12-28

了解您产品搜索量及市场趋势,制定营销计划

同行竞争及网站分析保障您的广告效果

点击免费数据支持

提交您的需求,1小时内享受我们的专业解答。

运城市盐湖区信雨科技有限公司


运城市盐湖区信雨科技有限公司

运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。

 8156699

 13765294890

 8156699@qq.com

Notice

We and selected third parties use cookies or similar technologies for technical purposes and, with your consent, for other purposes as specified in the cookie policy.
You can consent to the use of such technologies by closing this notice, by interacting with any link or button outside of this notice or by continuing to browse otherwise.