Maison >développement back-end >tutoriel php >javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?
要做一个这样的项目,类似于滴滴打车,美团众包
其实就是同城配送:有新的外卖订单了,实时推送给订单附近的配送人员端,配送人员接到单子后配送。
看起来很简单,但是对我这个web开发
的来说有点不知道从何动手,我首先想到的:
配送人员手机的
APP
与服务器WebSocket
直连,实时将地理位置经纬度上传给服务器,服务器使用内存数据库将位置保存下来(redis/mongodb
),然后定时循环不断的检测新订单,不断的计算新订单附近是否有配送人员,有的话就推送给相应的配送人员。
想法很简单,可是有几个问题:
配送人员获取位置怎么实时传给服务器呢,每隔几秒钟吗,那不像
ajax
一样了,我想用WebSocket
稳定一些吧,配送人员骑着车总在到处跑的。服务器用内存数据库存配送人员的位置信息吗,但是
redis
支持地理位置索引
吗,等下查的时候怎么查,怎么查订单附近的配送人员。这会不会产生大量的数据啊,
内存数据库
能实现吗
我不知道这里面需要用到哪些知识,猜测应该有这几种技术:
1: nosql
,内存数据库
2: 实时通信,多进程,多线程,并发
3: 队列
,定时程序
,CLI
,后台常驻服务
4: 空间索引,空间计算,地理位置索引计算
5: Socket编程
,Socket通信
,Socket推送,H5 Socket
6: APP开发,但是我用web H5
的Socket
能不能行呢,配送人员不一定要用APP
吧,只要WebSocket
稳定就行了(再弱弱的问一句,ajax
行不行)
希望有经验的大神指点一下,不要叫我放弃,可能涉及的知识面我不了解,但是不妨说出来,我去一一学习,起码知道这个里面需要用到哪些知识。
补充配图(蜂鸟众包/达达配送):
谢谢大家了^_^
要做一个这样的项目,类似于滴滴打车,美团众包
其实就是同城配送:有新的外卖订单了,实时推送给订单附近的配送人员端,配送人员接到单子后配送。
看起来很简单,但是对我这个web开发
的来说有点不知道从何动手,我首先想到的:
配送人员手机的
APP
与服务器WebSocket
直连,实时将地理位置经纬度上传给服务器,服务器使用内存数据库将位置保存下来(redis/mongodb
),然后定时循环不断的检测新订单,不断的计算新订单附近是否有配送人员,有的话就推送给相应的配送人员。
想法很简单,可是有几个问题:
配送人员获取位置怎么实时传给服务器呢,每隔几秒钟吗,那不像
ajax
一样了,我想用WebSocket
稳定一些吧,配送人员骑着车总在到处跑的。服务器用内存数据库存配送人员的位置信息吗,但是
redis
支持地理位置索引
吗,等下查的时候怎么查,怎么查订单附近的配送人员。这会不会产生大量的数据啊,
内存数据库
能实现吗
我不知道这里面需要用到哪些知识,猜测应该有这几种技术:
1: nosql
,内存数据库
2: 实时通信,多进程,多线程,并发
3: 队列
,定时程序
,CLI
,后台常驻服务
4: 空间索引,空间计算,地理位置索引计算
5: Socket编程
,Socket通信
,Socket推送,H5 Socket
6: APP开发,但是我用web H5
的Socket
能不能行呢,配送人员不一定要用APP
吧,只要WebSocket
稳定就行了(再弱弱的问一句,ajax
行不行)
希望有经验的大神指点一下,不要叫我放弃,可能涉及的知识面我不了解,但是不妨说出来,我去一一学习,起码知道这个里面需要用到哪些知识。
补充配图(蜂鸟众包/达达配送):
谢谢大家了^_^
首先,谢谢邀请回答。
这种项目涉及到服务端,客户端
客户端
如果客户端使用H5的话,建议用socket.io,不要用自带的websocket,前者解决方案多,而且可以断线重连。前端逻辑不多,无非是定期获取坐标然后上班服务端同时人在地图上移动。
服务端
web服务端
socket.io服务端
web服务端语言不限,请注意WEB服务端不要用复杂计算,web服务端只负责把数据库数据显示
后台程序比较多,消息队列,位置计算这些计算量大的需要放到后台。
要实现其实也没什么复杂的
首先建立长连接(随意的网络技术,什么网络框架都可以,只要能建立长连接),当有订单过来时 服务器端推送消息去告知客户端将地理位置发送过来(根据地图api获取),然后服务器端去和下单的客户的地理位置做对比(可自己对比,如果地图有提供api,可以用api对比),挑出最近的一批人,然后派单(普通编程逻辑)。
然后一期可以不实现订单追踪功能(即可以不保存人员的轨迹数据),等以后再实现,要实现订单追踪,就需要每隔几秒发送位置信息(这里可以缓存,也可以持久化,看日后分析是否需要,缓存可以用redis可以用mongodb,什么样的都可以),然后服务器更新位置信息。
其中用到的技术其实可以选择,现在位置信息,位置对比基本上都是通过调用地图的api获取,要知道原理,可以做完项目后自己研究。
逻辑简单,第一期用的技术也没什么复杂的,大数据什么的等量上来在过滤,想的太复杂就成了过度设计,这是大忌。