东莞列举网 > 商务服务 > 网站/软件服务 > 数据在网络中如何传输
东莞
[切换城市]

数据在网络中如何传输

更新时间:2022-06-20 11:15:31 浏览次数:43次
区域: 东莞 > 南城
类别:IDC服务
地址:南城高盛科技大厦
在计算机网络当中,数据是怎么样保证准确的从客户端发送到服务器端的?中间涉及到了哪些理论?
应用层会指定发送的服务器的域名(或者IP)和端口号、以及要发送数据的内容,传递给下一层传输层。
传输层会在把应用层的报文当成自己的数据,然后在前面拼接源端口号,和目标端口号。
其中源端口号就是客户端进程的端口号,这个端口号一般不是固定的,由操作系统在49152~65535范围内动态分配,而目标端口号就是服务器接收数据的端口号,一般是固定的,网络层会在传输层报文的基础上增加源IP和目标IP,其中源IP就是本地网卡的IP地址,目标IP是服务器的IP。
那么,首先需要通过DNS服务器将域名解析为IP,域名解析的流程:
先查浏览器缓存->操作系统缓存->hosts文件->DNS服务器。
数据链路层会在网络层的基础上增加源MAC地址和目标MAC地址,其中源MAC地址就是本机网卡的MAC地址,目标MAC地址是下一跳网络设备(一般是交换机或路由器)的MAC地址。
注意,目标MAC地址一般不是服务器的MAC地址(如果客户端和服务器端在同一个网段,那么目标MAC地址就是服务器的MAC地址),因为客户端根本就无法得知服务器的MAC地址,所以数据链路层采用下一跳的机制转递数据。当同一个网段上的主机接收到ARP报文时,会将这些信息添加自己的ARP缓冲区中的ARP列表,同时将自己的IP地址和MAC地址回应给发送者,这样每个位于同一个网段的主机都有整个网段内各个主机的IP与MAC地址的对应关系了。
交换机的交换
将目标IP与每一条记录的子网掩码(Genmask)一一按位与运算,匹配度高的Destination字段的IP就是下一跳的IP192.168.1.100,也就是网关地址GATEWAY,然后根据下一跳的IP去查ARP列表获得MAC地址00-30-F2-C1-2E-89。
就这样客户端完成了对报文的组装,交给物理层把数据从网卡发送出去,发送到交换机A。
交换机收到客户端的报文后,会进行解析,只解析到数据链路层,从中获得目标MAC地址,然后查找ARP列表,将报文转发给对应的网卡端口。
根据目标MAC地址00-30-F2-C1-2E-89找到交换机的端口为Fa2/1,这样交换机就会把报文从这个端口发送出去,发送到路由器,这里的端口是交换机的物理端口,也就是插入网线的插口。
路由器的路由
路由器可以连接两个不同的网络。
路由器有一张路由表,路由表可以通过网络工程师配置或者从其他路由器学习得到。
路由器会解析报文到网络层,然后发现目的IP是192.168.3.6,从上面的路由表可以可以发现,想要去192.168.3.0网段,只需要将数据从FastEthernet0/1端口发送出去即可。
查询IP192.168.3.6的MAC地址为0030.A396.5DE7然后将目标MAC替换成这个,然后将数据从FastEthernet0/1端口发送出去,交给交换机B,交换机B再将数据转发到服务器端。
服务器端各层对数据的解析
服务器端收到数据后会逐层进行解析,后将真正的数据交应用程序进行处理,至此一个数据从客户端到服务器端就完成了,服务器端会发送响应报文给客户端,大体的流程类似,但是数据不一定是原路返回的,因为中间经过的路由可能不同。
东莞网站/软件服务相关信息
制造业网站建设
其他-常平
1天前 刷新
工厂网站建设
其他-常平
1天前 刷新
1天前 刷新
11月20日 刷新
东莞网站建设
其他-常平
8月7日 刷新
注册时间:2021年07月02日
UID:725737
---------- 认证信息 ----------
手机已认证
查看用户主页