PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?

原创
2016-08-18 09:16:18 1808浏览

要做一个这样的项目,类似于滴滴打车,美团众包

其实就是同城配送:有新的外卖订单了,实时推送给订单附近的配送人员端,配送人员接到单子后配送。

看起来很简单,但是对我这个web开发的来说有点不知道从何动手,我首先想到的:

配送人员手机的APP与服务器WebSocket直连,实时将地理位置经纬度上传给服务器,服务器使用内存数据库将位置保存下来(redis/mongodb),然后定时循环不断的检测新订单,不断的计算新订单附近是否有配送人员,有的话就推送给相应的配送人员。

想法很简单,可是有几个问题:

  1. 配送人员获取位置怎么实时传给服务器呢,每隔几秒钟吗,那不像ajax一样了,我想用WebSocket稳定一些吧,配送人员骑着车总在到处跑的。

  2. 服务器用内存数据库存配送人员的位置信息吗,但是redis支持地理位置索引吗,等下查的时候怎么查,怎么查订单附近的配送人员。

  3. 这会不会产生大量的数据啊,内存数据库能实现吗

我不知道这里面需要用到哪些知识,猜测应该有这几种技术:
1: nosql,内存数据库
2: 实时通信,多进程,多线程,并发
3: 队列定时程序CLI,后台常驻服务
4: 空间索引,空间计算,地理位置索引计算
5: Socket编程Socket通信,Socket推送,H5 Socket
6: APP开发,但是我用web H5Socket能不能行呢,配送人员不一定要用APP吧,只要WebSocket稳定就行了(再弱弱的问一句,ajax行不行)

希望有经验的大神指点一下,不要叫我放弃,可能涉及的知识面我不了解,但是不妨说出来,我去一一学习,起码知道这个里面需要用到哪些知识。

补充配图(蜂鸟众包/达达配送):

谢谢大家了^_^

回复内容:

要做一个这样的项目,类似于滴滴打车,美团众包

其实就是同城配送:有新的外卖订单了,实时推送给订单附近的配送人员端,配送人员接到单子后配送。

看起来很简单,但是对我这个web开发的来说有点不知道从何动手,我首先想到的:

配送人员手机的APP与服务器WebSocket直连,实时将地理位置经纬度上传给服务器,服务器使用内存数据库将位置保存下来(redis/mongodb),然后定时循环不断的检测新订单,不断的计算新订单附近是否有配送人员,有的话就推送给相应的配送人员。

想法很简单,可是有几个问题:

  1. 配送人员获取位置怎么实时传给服务器呢,每隔几秒钟吗,那不像ajax一样了,我想用WebSocket稳定一些吧,配送人员骑着车总在到处跑的。

  2. 服务器用内存数据库存配送人员的位置信息吗,但是redis支持地理位置索引吗,等下查的时候怎么查,怎么查订单附近的配送人员。

  3. 这会不会产生大量的数据啊,内存数据库能实现吗

我不知道这里面需要用到哪些知识,猜测应该有这几种技术:
1: nosql,内存数据库
2: 实时通信,多进程,多线程,并发
3: 队列定时程序CLI,后台常驻服务
4: 空间索引,空间计算,地理位置索引计算
5: Socket编程Socket通信,Socket推送,H5 Socket
6: APP开发,但是我用web H5Socket能不能行呢,配送人员不一定要用APP吧,只要WebSocket稳定就行了(再弱弱的问一句,ajax行不行)

希望有经验的大神指点一下,不要叫我放弃,可能涉及的知识面我不了解,但是不妨说出来,我去一一学习,起码知道这个里面需要用到哪些知识。

补充配图(蜂鸟众包/达达配送):

谢谢大家了^_^

首先,谢谢邀请回答。
这种项目涉及到服务端,客户端
客户端
如果客户端使用H5的话,建议用socket.io,不要用自带的websocket,前者解决方案多,而且可以断线重连。前端逻辑不多,无非是定期获取坐标然后上班服务端同时人在地图上移动。
服务端

  1. web服务端

  2. socket.io服务端
    web服务端语言不限,请注意WEB服务端不要用复杂计算,web服务端只负责把数据库数据显示

后台程序比较多,消息队列,位置计算这些计算量大的需要放到后台。

要实现其实也没什么复杂的
首先建立长连接(随意的网络技术,什么网络框架都可以,只要能建立长连接),当有订单过来时 服务器端推送消息去告知客户端将地理位置发送过来(根据地图api获取),然后服务器端去和下单的客户的地理位置做对比(可自己对比,如果地图有提供api,可以用api对比),挑出最近的一批人,然后派单(普通编程逻辑)。

然后一期可以不实现订单追踪功能(即可以不保存人员的轨迹数据),等以后再实现,要实现订单追踪,就需要每隔几秒发送位置信息(这里可以缓存,也可以持久化,看日后分析是否需要,缓存可以用redis可以用mongodb,什么样的都可以),然后服务器更新位置信息。

其中用到的技术其实可以选择,现在位置信息,位置对比基本上都是通过调用地图的api获取,要知道原理,可以做完项目后自己研究。

逻辑简单,第一期用的技术也没什么复杂的,大数据什么的等量上来在过滤,想的太复杂就成了过度设计,这是大忌。

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。