【Linux 网络】网络基础(三)(数据链路层协议:以太网协议、ARP 协议)

一、以太网

两个不同局域网的主机传递数据并不是直接传递的,而是通过路由器 “一跳一跳” 的传递过去。

跨网络传输的本质:由无数个局域网(子网)转发的结果。

所以,要理解数据跨网络转发原理就要先理解一个局域网中数据是如何转发的,它就是以太网协议

在同一个局域网内的两太主机是可以直接通信的。

举例:在局域网通信就好比如,老师上课的时候喊张三的名字,所有人都能听到,只不过分析发现老师喊的不是自己就忽略掉,而只有张三会处理这个老师发出来的这个消息,那么老师和张三的通信就可以看作是 1 对 1 的直接通信。

  • “以太网” 不是一种具体的网络,而是一种技术标准。既包含了数据链路层的内容,也包含了一些物理层的内容。例如:规定了网络拓扑结构,访问控制方式,传输速率等。
  • 例如以太网中的网线必须使用双绞线,传输速率有 10M,100M,1000M 等。
  • 以太网是当前应用最广泛的局域网技术,和以太网并列的还有令牌环网,无线 LAN 等。

1、以太网帧格式

局域网两台主机之间通信必须要封装 MAC 帧。

以太网的帧格式如下图所示:  

  • 源地址和目的地址是指网卡的硬件地址(也叫 MAC 地址),长度是 48 位,是在网卡出厂时固化的。
  • 帧协议类型字段有三种值,分别对应 IP 协议、ARP 协议和 RARP 协议。
  • 帧末尾是 CRC 校验码。

用红色圈出来的部分就是报头部分。中间的则是数据部分,数据部分包含上层的报头加有效载荷(HTTP、TCP、IP 的封装)。


2、MAC 帧将报头与有效载荷进行分离 & 向上交付

如何将报头与有效载荷分离呢?

MAC 帧的分离方式就是采用定长报头。直接对前面的 14 个和后边的 4 个进行提取,剩下的就是有效载荷。


向上交付给哪个协议?

在 MAC 帧的帧头当中有 2 个字节的类型字段,因此在分离出报头和有效载荷后,根据该字段将有效载荷交付给对应的上层协议即可。


3、认识 MAC 地址

局域网通信,每台主机都要有自己的唯一标识(虚拟机中的 MAC 地址不是真实的 MAC 地址,可能会冲突,也有些网卡支持用户配置 MAC 地址),每一台机器都要配一张网卡,每一个网卡都有一个序列号,这个序列号就是该网卡的 MAC 地址用来识别数据链路层中相连的节点,在全球范围内具有唯一性(其实在局域网内保证唯一性就够了),长度为 48 位(6 个字节),一般用 16 进制数字加上冒号的形式来表示(例如:08:00:27:03:fb:19)。

注意:MAC 地址在网卡出厂时就确定了,不能修改。


4、局域网转发原理(基于协议)

假设现在要 MAC 1发送数据给 MAC7,那么首先就需要封装一个 MAC 帧

每台主机的数据链路层都会收到这个 MAC 帧,然后进行报头和有效载荷的分离,然后查看目的 IP 地址发现是 MAC7,如果发现不是自己,直接把数据帧丢弃,上层根本就不知道收到了这个数据帧;如果发现是自己,就把有效载荷向上交付。

处理结束后,MAC7 也会给 MAC1 一个应答。

发送的过程同上。

结论:其实局域网所有的主机都能收到 MAC 帧,只不过如果目标 MAC 地址不等于自己的 MAC 地址,就直接在数据链路层丢弃掉。

由此在局域网中,网卡有一种混杂模式:就是不丢弃任何的数据帧,全部向上交付,这就是局域网抓包工具的原理。
由此也可以看出 HTTPS 数据加密的必要性。


(1)数据碰撞

由于以太网中的所有的主机共享一个通信信道,所以多台主机同时发送数据,数据之间就可能会产生数据碰撞问题。

举例:在教室老师想跟李四说话,但是所有人都在互相说话,导致李四听不到老师的声音。

解决方法:在同一时刻只允许有一台主机发送数据

如何保证我在发送数据时,别人也想发送数据成功呢?

两种方法:

  1. 令牌环:谁拿牌谁就能发消息,类比互斥锁。
  2. 以太网:如果发生了碰撞,就暂时不发数据,发送主机会休息一段(随机)时间再尝试发送。这种方法叫做主机的碰撞检测和碰撞避免算法

如果我们不断向局域网发送垃圾数据并且不执行碰撞检测和碰撞避免,那么就能让局域网所有主机都无法通信。

那么就可以把局域网看成一个临界资源,通过碰撞检测 + 碰撞避免让任何时刻只有一台主机能够发送消息。

局域网中的主机越多越好,还是越少越好呢?

越少越好。

局域网数据帧发送数据的时候,数据帧是越长越好,还是越短越好呢?

数据帧越短越好。数据太长容易造成碰撞问题,但太短的话,能携带的信息就比较少,所以不能太短。


(2)交换机

如果局域网过大,就会导致碰撞的概率增加,所以就有了交换机。

  • 交换机可以识别到局部性的碰撞,对碰撞的数据不做转发。
    比方说交换机左侧发生了碰撞,并不会影响到 MAC3 给 MAC4 发消息。

  • 交换机对正常发送的数据也不会做转发
    比方说 MAC1 是给 MAC5 发消息,那么就没必要让交换机的右侧收到消息,右侧的碰撞概率就减小了。

交换机的核心作用:划分碰撞域。


5、对比理解 MAC 地址和 IP 地址

  • IP 地址描述的是路途总体的起点和终点
  • MAC 地址描述的是路途上的每一个区间的起点和终点

IP 就是一个大目标,MAC 就是实现大目标的每一个小目标。

因此数据在路由过程中,源 IP 地址和目的 IP 地址可以理解成是不会变化的,而数据每进行一跳后其源 MAC 地址和目的 MAC 地址都会变化


6、认识 MTU  

MTU(最大传输单元)描述的是底层数据帧一次最多可以发送的数据量,这个限制是不同的数据链路层对应的物理层产生的。以太网对应 MTU 的值一般是 1500 字节。不同的网络类型有不同的 MTU。

如果一个数据包从以太网路由到拨号链路上,数据包长度大于拨号链路的 MTU 了,则需要对数据包进行分片(fragmentation)。

MAC 帧规定有效载荷的长度的范围是【46~1500】。ARP 数据包的长度不够 46 字节时,要在后面补填充位。

可以把 MTU 看作发快递时对包裹的大小限制,不同的数据链路层标准的 MTU 是不同的。


(1)MTU 对 IP 协议的影响

由于数据链路层 MTU 的限制,如果 IP 层一次发送的字节数超过了 MTU,就需要进行切片。

  • 将较大的 IP 包分成多个小包,并给每个小包打上标签。
  • 每个小包 IP 协议头的 16 位标识(id)都是相同的。每个小包的 IP 协议头的 3 位标志字段中,第 2 位置为 0,表示允许分片,第 3 位来表示结束标记(当前是否是最后一个小包,是的话置为 1,否则置为 0)。
  • 到达对端时再将这些小包,会按顺序重组,拼装到一起返回给传输层。一旦这些小包中任意一个小包丢失,接收端的重组就会失败,但是 IP 层不会负责重新传输数据。

补充:数据在路由器转发的过程路由器也可能会进行切分,因为不同网络的 MTU 是不同的。这样我们可以把 IP 协议中的不可切分字段置为 1,如果遇到 MTU 较小的,直接舍弃掉数据,重发重新选择路径,这样就可以选出一条吞吐量大的路径


(2)MTU 对 UDP 协议的影响

一旦 UDP 携带的数据超过 1472(1500 - 20(IP 首部)- 8(UDP 首部)), 那么就会在网络层分成多个 IP 数据报。

这多个 IP 数据报有任意一个丢失都会引起接收端网络层重组失败。那么这就意味着,如果 UDP 数据报在网络层被分片,整个数据被丢失的概率就大大增加了


(3)MTU 对于 TCP 协议的影响

TCP 作为传输控制协议,它需要控制有效载荷数据不能超过某一阈值,还是受制于 MTU。TCP 的单个数据报的最大消息长度,称为 MSS(Max Segment Size,最大报文段长度)。

TCP 在建立连接的过程中,通信双方会进行 MSS 协商。最理想的情况下,MSS 的值正好是在 IP 不会被分片处理的最大长度(这个长度仍然是受制于数据链路层的 MTU)。

MAC 帧的有效载荷最大为 MTU,TCP 的有效载荷最大为 MSS,由于 TCP 和 IP 常规情况下报头的长度都是 20 字节,因此一般情况下 MSS = MTU - 20 - 20,而 MTU 的值一般是 1500 字节,因此 MSS 的值一般就是 1460 字节。所以一般建议 TCP 将发送的数据控制在 1460 字节以内,此时就能够降低数据分片的可能性。

这也解释了为什么滑动窗口范围内会有多个报文段,不能直接一起发送,就是因为一次不允许发送太大的单个数据段。

双方在发送 SYN 的时候会在 TCP 头部写入自己能支持的 MSS 值,然后双方得知对方的 MSS 值之后,选择较小的作为最终 MSS。

MSS 的值就是在 TCP 首部的 40 字节变长选项中(kind=2)。

如何减少分片?

如果传输层控制好一次交给 IP 的数据量不要太大,那么数据在 IP 层自然也就不需要进行分片。


如果 UDP 和 TCP 携带的数据过大,超过 MTU,对于 UDP 来说就直接丢包了,对于 TCP 就是数据重传。所以可以得出切片是不好的。


(4)MSS 和 MTU 的关系


(5)查看硬件地址和 MTU 

使用 ifconfig 命令,即可查看 ip 地址,mac 地址和 MTU:


二、ARP 协议

注意 :ARP  不是一个单纯的数据链路层的协议, 而是一个介于数据链路层和网络层之间的协议。

1、ARP 协议的作用

当跨不同子网的两太主机 A 和 B 通信,最终数据会送到主机 B 局域网中的路由器 D,我们知道 D 和 B 属于同一个局域网,那么就得封装 MAC 帧进行通信,但是报文中只含有 B 的 IP 地址,并不知道 B 的 MAC 地址。这就需要有一个过程让路由器获取主机 B 的 MAC 地址。

ARP 协议建立了主机 IP 地址和 MAC 地址的映射关系,其作用就是根据 IP 地址来获取目标主机的 MAC 地址。

在网络通讯时,源主机的应用程序知道目的主机的 IP 地址和端口号,却不知道目的主机的硬件地址。数据包首先是被网卡接收到再去处理上层协议的,如果接收到的数据包的硬件地址与本机不符,则直接丢弃。因此在通讯前必须获得目的主机的硬件地址。


2、ARP 协议的工作流程

举例:现在在一个教室上课,老师第一次来,不认识每个学生,只知道每个人的学号,那么老师如何知道每个人的姓名呢?—— 可以直接叫学号,然后得到这名同学的反馈,也就建立了学号和姓名的映射关系。

当路由器收到数据要发送给目标主机的时候,就会封装 ARP 报文,广播报文,寻找匹配的目标 IP,目标主机收到 ATP 后会封装一个 ARP 应答,该应答里包含了自己的 MAC 地址。由此路由器就知道了目标主机的 MAC 地址,然后才会把数据包封装 MAC 帧进行发送。

  • 源主机发出 ARP 请求,询问 “IP 地址是 192.168.0.1 的主机的硬件地址是多少”,并将这个请求广播到本地网段(以太网帧首部的硬件地址填 FF:FF:FF:FF:FF:FF 表示广播)。
  • 目的主机接收到广播的 ARP 请求,发现其中的 IP 地址与本机相符,则发送一个 ARP 应答数据包给源主机,将自己的硬件地址填写在应答包中。
  • 每台主机都维护一个 ARP 缓存表,可以用 arp -a 命令查看。缓存表中的表项有过期时间(一般为 20 分钟),如果 20 分钟内没有再次使用某个表项,则该表项失效,下次还要发 ARP 请求来获得目的主机的硬件地址。


(1)ARP 的请求过程

假设现在路由器 A 构建 ARP 请求发送给 B。

构建 ARP 请求:

  • 硬件类型指链路层的网络类型,1 为以太网。
  • 协议类型指要转换的地址类型,0x0800 为 IP 地址。
  • 硬件地址长度对于以太网地址为 6 字节,因为 MAC 地址是 48 位的。
  • 协议地址长度对于 IP 地址为 4 字节,因为 IP 地址是 32 位的。
  • op 字段为 1 表示 ARP 请求,op 字段为 2 表示 ARP 应答。

以太网地址和发送端 IP 地址,对应就是路由器 A 的 MAC 地址和 IP 地址。
目的以太网地址和目的 IP 地址,对应就是主机 B 的 MAC 地址和 IP 地址,因为不知道主机 B 的 MAC 地址,所以填全 F。

这个报文实际上是在 ARP 层封装的:

报文要先向下交付数据链路层进行封装才会发送到局域网。
所以现在需要添加以太网帧的报头:

  • 目的 MAC 地址并不知道,所以填全 F。
  • 源地址就填路由器 A 的 MAC 地址。
  • 类型就填 0806,因为 MAC 帧当中的帧类型字段设置为 0806。
  • 最后要加上 CRC 校验。

MAC 帧封装完毕后,路由器 A 就可以将封装好的 MAC 帧以广播的方式发送到局域网当中了。

假设现在 MAC2 主机收到了这个报文,解包后发现目标 MAC 是全 F,就是广播的,当识别到 MAC 帧当中的帧类型字段为 0806 后,便知道这是一个 ARP 的请求或应答的数据包,于是会将 MAC 帧的有效载荷向上交付给 ARP 层。
当 ARP 收到数据包后,先比对 op 字段,判断是请求还是响应。发现是 1 就是请求,然后提取目的IP字段,发现不是自己,就在 ARP 层直接丢弃数据包。


(2)ARP 的应答过程

构建 ARP 响应:

  • op 填 2,表示应答。
  • 目标 MAC 就填路由器 A。
  • 其他同理 ARP 请求。

为了发送到局域网,所以加下来封装 MAC 帧报头:

MAC 帧封装完毕后,主机 B 就可以将封装好的 MAC 帧发送到局域网当中了。

所有主机都会收到这个 MAC 帧,看到 MAC 帧报头中的目的 IP 如果不是自己的,就直接丢弃了,不会传递到 ARP 层。
当路由器 A 的 ARP 层收到这个数据包后,先看的 op 字段为 2,于是判定这是一个 ARP 应答,然后就会提取发送端以太网的地址和发送端 IP 地址,此时路由器 D 就拿到了主机 B 的 MAC 地址。

结论: 

  • 任何主机可能之前向目标主机发送过 ARP 请求,也就注定了未来一定会收到对应的 ARP 应答。
  • 任何一台主机也有可能收到别人发起的 ARP 请求。

所以,局域网中,任何一台主机收到 ARP 的时候,可能是一个应答,也可能是一个请求。

总结所有 ARP 层收到数据包后,都会先看 op 字段,如果是 1 请求,那么就构建应答,如果是 2 应答,那么就提取源 IP 和源 MAC 地址就可以知道对方的 IP 和 MAC 地址了。

是不是只会在目标最终的子网中进行 ARP,其它地方是否会发生 ARP 呢?

会,ARP 可能在网络中的任意一条路径中发生。


3、ARP 数据报的格式

因为 ARP 里面包含了 IP,所以 ARP 协议协议属于 MAC 帧的上层协议

所以 MAC 帧在封装的时候,不仅仅有 IP 报文,还有可能是 ARP 请求/应答。

注意到源 MAC 地址、目的 MAC 地址在以太网首部和 ARP 请求中各出现一次,对于链路层为以太网的情况是多余的,但如果链路层是其它类型的网络则有可能是必要的。

这里的前三个字段是 MAC 帧的报头,所以真实的 ARP 请求只有后面的部分:

  • 硬件类型指链路层的网络类型,1 为以太网。
  • 协议类型指要转换的地址类型,0x0800 为 IP 地址。
  • 硬件地址长度对于以太网地址为 6 字节,因为 MAC 地址是 48 位的。
  • 协议地址长度对于 IP 地址为 4 字节,因为 IP 地址是 32 位的。
  • op 字段为 1 表示 ARP 请求,op 字段为 2 表示 ARP 应答。

后边四个字段就是用来 ARP 的请求和响应的。如果后边一些字段不清楚,例如目的 MAC 地址,就可以填成全 F 标识没有被设置。


4、ARP 缓存表

局域网通信要用到 MAC 地址,所以要使用 ARP 协议通过 IP 得到 MAC 地址,ARP 看起来至少进行一个请求和一个应答,难道每一次发送数据都要用这个流程吗?

不是,arp 请求成功之后,请求方会暂时将 IP:MAC 地址的映射关系保存起来。

每次发起 ARP 请求后都会建立对应主机 IP 地址和 MAC 地址的映射关系,每台主机都维护了一个 ARP 缓存表,我们可以用命令:arp -a 进行查看。

注意:缓存表中的表项有过期时间,这个时间一般为 20 分钟。如果 20 分钟内没有再次使用某个表项,那么这个表项就会失效,下次使用时就需要重新发起 ARP 请求来获得目的主机的硬件地址,这主要是因为 IP 地址是会发生变化的。 


5、RARP 协议

RARP(反向地址转换协议),是根据 MAC 地址获取 IP 地址的协议。

在同一局域网内知道了 MAC 地址就可以直接向给主机发送消息了,因此我们可以直接发消息询问对方的 IP 地址就行了。


6、ARP 欺骗

假设现在有一个局域网,每个主机内部都有 ARP 缓存表如下:

但此时来了一个中间人,它封装大量假的 ARP 请求发送给 MAC1,里面写的是 IP4:MAC3,同理给路由器发送 IP1:MAC3

这样 MAC3 就成为了中间人,这种操作就叫作 ARP 欺骗

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/842529.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安全厂商第一站!OASA 走进绿盟科技圆满结束

近日,龙蜥社区安全联盟(OASA)走进联盟成员单位绿盟科技集团股份有限公司(以下简称“绿盟科技”),就未来合作方向,双方进行了一次深入的合作交流。该会议共有 11 位人员出席,有来自绿…

视频监控平台AS-V1000产品介绍:账户或用户数据的导入和导出功能介绍

目录 一、功能描述 (一)导入功能定义 (二)导出功能定义 二、用户数据的导入导出的作用 三、AS-V1000新版本的导出和导入功能介绍 (一)功能主界面 (二)导出功能 1、导出操作 …

从零开始构建 Vision Transformer(ViT) 模型

Transformer 模型最早由 Vaswani 等人在 2017 年论文 Attention Is All You Need 中提出,并已广泛应用于自然语言处理。 2021年,Dosovitsky 等人在论文An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale中提出将 Transforme…

第十二届蓝桥杯物联网试题(国赛)

不得不说国赛相比较省赛而言确实,功能变得更加复杂,更加繁琐,特别是串口LORA通信相结合的更加频繁,且对收取的字符处理要求要更加复杂,处理判别起来会更加复杂。 对于收发数据本身来说,收发的数据本身是以…

每日一题——Python实现PAT甲级1029 Median(举一反三+思想解读+逐步优化)

一个认为一切根源都是“自己不够强”的INTJ 个人主页:用哲学编程-CSDN博客专栏:每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 我的方法 代码功能和结构点评 时间复杂度分析 空间复杂度分析 优化建议 我要更强…

深度学习环境安装教程-anaconda-python-pytorch

首先是anaconda的安装,可以从下面地址下载安装包 Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 尽量选择最新的日期的anaconda进行安装,我这里是windows电脑,因此选择了windos-x86_64.exe&#xf…

如何在anaconda的环境下安装langchain

1、安装anaconda; 2、在终端上,输入: conda install langchain -c conda-forge Proceed ([y]/n)? y 输入:Y 3、安装完成后,输入: python -c "import langchain; print(langchain.__version__)&…

Redisson集成SpringBoot

前言:Redisson集成SpringBoot主要有两种方式,一个是使用redisson-spring-boot-starter依赖(优先推荐),毕竟springboot主打的就是约定大于配置,这个依赖就是为springboot准备的。 再一种方式就是引入rediss…

JVM学习-javap解析Class文件

解析字节码的作用 通过反编译生成字节码文件,可以深入了解Java工作机制,但自己分析类文件结构太麻烦,除了第三方的jclasslib工具外,官方提供了javapjavap是jdk自带的反解析工具,它的作用是根据class字节码文件&#x…

一个投稿好方法让你的文章早日发表

作为一名单位信息宣传员,我初入此行时,满腔热情,怀揣着传播单位价值、展示团队风采的理想,一头扎进了稿件撰写的海洋。我的目标很简单,就是通过文字的力量,让外界听到我们的声音,感受到我们的活力。然而,理想很丰满,现实却给我上了生动的一课。 起初,我遵循传统路径,选择了一家…

QT安装和配置[安装注意点][QT找不到python27.dll][缩小空间]

安装注意点 本文摘录于:https://blog.csdn.net/Python_0011/article/details/131699443只是做学习备份之用,绝无抄袭之意,有疑惑请联系本人! 双击"qt-online-installer-windows-x64-4.8.0.exe"文件后输入账号选择如下控…

什么是Capto刀柄,一起来认识一下

大家好,今天咱们不聊齿轮,说一说一款刀柄的相关内容。目前,高速加工中心的主轴转速可以达到10,000——50,000r /min ,极大地提高了生产率。高速加工工具系统的主要作用是保证刀具在机床主轴中的精确定位,将主轴的运动和…

Python脚本启动应用并输入账号或密码

一、简介 如果每天要启动某个软件还要输入账号密码登录的需求的话,可以参考本文章; 二、Python环境 环境:Python3.11 已经在Windows电脑中配置Python环境变量,且配置了pipd的环境变量; 三、安装模块 安装所需要的…

计算机毕业设计 | SpringBoot招投标系统 任务发布网站(附源码)

1,绪论 在市场范围内,任务发布网站很受欢迎,有很多开发者以及其他领域的牛人,更倾向于选择工作时间、工作场景更自由的零工市场寻求零散单子来补贴家用。 如今市场上,任务发布网站鱼龙混杂,用户需要找一个…

(原创)从右到左排列RecycleView的数据

问题的提出 当我们写一个Recycleview时,默认的效果大概是这样的: 当然,我们也可以用表格布局管理器GridLayoutManager做成这样: 可以看到,默认的绘制方向是: 从左到右,从上到下 那么问题来了…

STM32系列(HAL库)——F103C8T6通过HC-SR04超声波模块实现测距

一、模块资料 (1)模块简介 超声波是振动频率高于20kHz的机械波。它具有频率高、波长短、绕射现象小、方向性好、能够成为射线而定向传播等特点。HC-SRO4是一款尺寸完全兼容老版本,增加UART和IIC功能的开放式超声波测距模块,默认条件下,软件…

执行普罗米修斯插件mysqld_exporter出现闪退问题如何解决?

运行 mysqld_exporter.exe 文件闪退的问题可能是由于配置文件或环境变量设置不正确导致的。 检查配置文件 my.cnf: 打开 my.cnf 文件,确保其中的配置项正确无误,尤其是 MySQL 数据库的连接信息。配置示例:[client] useryour_mysql…

如何评价 OpenAI 最新发布支持实时语音对话的模型GPT-4o?OpenAI发完GTP-4o,国内大模型行业还有哪些机会?

文章目录 OpenAI发完GTP-4o,国内大模型行业还有哪些机会?详细了解一下OpenAI最新发布的支持实时语音对话的模型GPT-4o国内大模型如何寻找发展机会?想要发展技术必须要创新与追赶或许应用场景拓展也是一种出路产业生态构建 ChatGPT 问世才 17 …

阿里妈妈->创意图片生成

数智商业技术2.0时代的新「三驾马车」,阿里妈妈郑波谈如何把握生成式大模型ACM\x26#39;23 中国图灵大会 SIGAI China 论坛上,阿里妈妈及闲鱼 CTO 郑波分享关于数智商业技术的洞见。他认为在这轮生成式 AI 大模型的驱动下,数智商业技术将进入 2.0 时代,其中知识驱动、逻辑推…

【程序员如何送外卖】

嘿,咱程序员要在美团送外卖,那还真有一番说道呢。 先说说优势哈,咱程序员那逻辑思维可不是盖的,规划送餐路线什么的,简直小菜一碟。就像敲代码找最优解一样,能迅速算出怎么送最省时间最有效率。而且咱平时…