方案1:

假设数据结构是这个样子的结构

那么找某个范围之内的用户,相当于:

select * from tb_lbs_user where lat > lat_min and lat < lat_max and lng >lng_min and lng < lng_max;

优点:几乎没有,唯一能说优点的就是比较直观是个人都能够想到;

缺点:慢,数据量大和并发量大的情况下可以把数据库拖死;

方案2:

使用geohash

那么找某个范围之内的用户,相当于:

select * from tb_lbs_user where GeoHash  like  “abcd%”;

优点:利用geohash优化关系型数据库,查询效率,而且还比较直观;

缺点:慢,数据量大和并发量大的情况下可以把数据库拖死;

方案3:

思路:

将地球划分为n个方格,geohash值为6个位,每个方格为(宽一平方千米,以人口均值取值)

数据结构:

1)用户群圈定:

以geohash值为key,在用户更新地理位置的时候更新或插入;

userGeoList:List< M{userid :{lat,lan,gender, free }}>

示例:

key                     value

5cfr5x                 {{12322:{11,11,1}},{1234:{0.5,0.2,1}},{ 4567:{0.2,0.3,1}},….}

5cfr5f                 {{12322:{11,11,1}},{1234:{0.5,0.2,1}},{4567:{0.2,0.3,1}},….}

.                 .

.                 .

.                 .

2)用户信息:

一个用户信息;纬度、经度、GeoHash值

userInfo ={lan,lat ,geo}

例如:

key                     value

12322                {5661,1234, 5cfr5x }

344                            {344,333, 5cfr5x }

.                 .

.                 .

.                 .

算法实现:

1)更新:

定义:

user_new_geohash:新的geohash值

userid:用户ID

getUserInfo:根据userid获取用户信息

updateGeohash:更新用户的geohash

removeUserid:根据userid,移除集合中的某个用户

getuserGeoList:根据geohash获取用户群

addUserid:往用户群中添加userid

UserGeoListNew:创建用户群对象

实现:

user_new_geohash = “5cfr5f”

userid = 12322;

userInfo  =  getUserInfo(userid);

user_old_geohash = userInfo. geo

if user_new_geohash  !=  user_old_geohash

userInfo.updateGeohash (userid, user_old_geohash, userInfo. geo)

userGeoListOld  =  getuserGeoList(user_old_geohash);

userGeoListOld .removeUserid(userid)

userGeoListNew  =  getuserGeoList(user_new_geohash);

if userGeoListNew  !=null:

userGeoListNew.addUserid(userid, gender,free)

else:

userGeoListNew = new UserGeoListNew();

2)查询

定义:

getuserGeoHash:根据userid获取geohash

getuserGeoList:根据geohash和偏移值获取用户集合

sort:根据地理位置由近到远排序

NearbyUserListCache:用户缓存

k:查询条件

geohash = getuserGeoHash(userid);

lan = 0

userGeoList2  =  new userGeoList ()

for (int i = 3; i >= 2; i--) {

userGeoList  = getuserGeoList(geohash,lan)

for(user: userGeoList ){

if user.gender == 1 and user.free == 1://查询条件

userGeoList2.add(user);

}

lan  +=  1000;

if (userGeoList2.size() >= 1000) {

break;

}

}

userGeoList.sort();

NearbyUserListCache.add(k, userGeoList);

以NearbyUserListCache逐步分页

算法复杂度:

n*n

可能查询多次

方案4:

2)用户群数值记录:

以geohash值为key,在用户更新地理位置的时候更新或插入;

userNum : DECR/INCR

userFemaleNum : DECR/INCR

userMaleNum : DECR/INCR

2)查询

定义:

getuserGeoHash:根据userid获取geohash

getuserGeoList:根据geohash和偏移值获取用户集合

sort:根据地理位置由近到远排序

NearbyUserListCache:用户缓存

k:查询条件

geohash = getuserGeoHash(userid);

lan = 0

userGeoList = new userGeoList ()

while true:

if len >=10000

userGeoList  = getuserGeoList(geohash)

else:

len +=xxx;

break;

userGeoList2.sort();

NearbyUserListCache.add(k, userGeoList2);

以NearbyUserListCache逐步分页

只需要查询一次

LBS优化方案探究的更多相关文章

  1. Tomcat 配置详解/优化方案

     转自:http://blog.csdn.net/cicada688/article/details/14451541 Service.xml Server.xml配置文件用于对整个容器进行相关的配置 ...

  2. 一个网站完整详细的SEO优化方案

    根据自己的个人经验完成了这篇文章,希望对SEOer有点帮助,高手直接跳过,请勿喷水... 一个完整的SEO优化方案主要由四个小组组成: 一.前端/页编人员 二.内容编辑人员 三.推广人员 四.数据分析 ...

  3. mysql 性能优化方案

    网 上有不少MySQL 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...

  4. iOS界面跳转的一些优化方案

    原文地址: http://blog.startry.com/2016/02/14/Think-Of-UIViewController-Switch/ iOS界面跳转的一些优化方案 App应用程序开发, ...

  5. tomcat配置详解/优化方案

    Service.xml Server.xml配置文件用于对整个容器进行相关的配置. <Server>元素:是整个配置文件的根元素.表示整个Catalina容器. 属性:className: ...

  6. mysql 性能优化方案1

    网 上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...

  7. [转]MYSQL高可用方案探究(总结)

    前言 http://blog.chinaunix.net/uid-20639775-id-3337432.htmlLvs+Keepalived+Mysql单点写入主主同步高可用方案 http://bl ...

  8. (转)Web性能优化方案

    第一章 打开网站慢现状分析 在公司访问部署在IDC机房的VIP网站时会感觉很慢.是什么原因造成的?为了缩短页面的响应时间,改进我们的用户体验,我们需要知道用户的时间花在等待什么东西上. 可以跟踪一下我 ...

  9. mysql 性能优化方案 (转)

    网 上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...

随机推荐

  1. 一个令人蛋疼的 Microsoft.AspNet.FriendlyUrls

    我一个项目都基本上做完了,结果部署到我服务器的时候结果一直报404 找不到 一看global.asax有个路由注册的代码 public static void RegisterRoutes(Route ...

  2. MYSQL远程登录权限设置(转)

    Mysql默认关闭远程登录权限,如下操作允许用户在任意地点登录: 1. 进入mysql,GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY ...

  3. windows中快速停掉占用某端口的进程的方法

    在Windows操作系统中,我们在启动一个tomcat服务器时,经常会发现8080端口已经被占用的错误,而我们又不知道如何停止这个tomcat服务器. 本文将通过命令来强行终止这个已经运行的tomca ...

  4. c#之Redis实践list,hashtable

    写在前面 最近公司搞了一个活动,用到了redis的队列,就研究了下redis的相关内容.也顺手做了个demo. C#之使用Redis 可以通过Nuget安装Reidis的相关程序集.安装之后发现会引入 ...

  5. 老项目的#iPhone6与iPhone6Plus适配#Icon适配

        本文永久地址为http://www.cnblogs.com/ChenYilong/p/4020373.html ,转载请注明出处.  这是Evernote印象笔记的链接:https://www ...

  6. JSON做下拉表格

    主页面,5-18j.php <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http ...

  7. 关于showModalDialog()对话框点击按钮弹出新页面的问题

    页面a.aspx上,单击按钮a,走脚本,弹出showModalDialog("b.aspx",....) 在b.aspx上有个服务器控件按钮b,单击按钮,更新数据后,会弹出一个新的 ...

  8. [Effective JavaScript 笔记]第55条:接收关键字参数的选项对象

    53节建议保持参数顺序的一致约定对于帮助程序员记住每个参数在函数调用中的意义很重要.参数较少这个主意不错,但如果参数过多后,就出现麻烦了,记忆和理解起来都不太容易. 参数蔓延 如下面这些代码: var ...

  9. 变色龙安装程序 Chameleon Install 2.2 svn 2281发布

    变色龙安装程序 Chameleon Install 2.2 svn 2281发布 1.更好的支持10.9 Mavericks2.更新ATi.nVidia显卡支持列表3.添加新的 CPU Model I ...

  10. 基于DCMTK的DICOM相关程序编写攻略

    2008年09月10日 星期三 15:35 基于DCMTK的DICOM相关程序编写攻略 前言: 由于现在的医学影像设备的图像存储和传输正在逐渐向DICOM标准靠拢,在我们进行医学图像处理的过程中,经常 ...