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

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

WBOY
WBOYOriginal
2016-08-18 09:16:182056Durchsuche

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

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

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

看起来很简单,但是对我这个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行不行)

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

补充配图(蜂鸟众包/达达配送):
javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?

谢谢大家了^_^

回复内容:

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

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

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

看起来很简单,但是对我这个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行不行)

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

补充配图(蜂鸟众包/达达配送):
javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?javascript - 大家好,我想做一个类似滴滴打车的软件,大概需要用到哪方面的技术?

谢谢大家了^_^

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

  1. web服务端

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

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

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

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

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

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn