粘包问题,以及在python中如何调用操作系统命令

一.新模块'subprocess'

复习: 在os模块中调用系统命令
import os
f = os.popen('dir')
print(f.read())


上面的结果和下面的写法是一样的
import subprocess
r = subprocess.Popen('ls',shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE)

# subprocess.Popen(cmd,shell=True,subprocess.stdout,subprocess.stderr)
# cmd : 代表系统命令
# shell = True   代表这条命令是 系统命令,告诉操作系统,将cmd当成系统命令去执行
# stdout   是执行完系统命令之后,用于保存结果的一个管道
# stderr   是执行完系统命令之后,用于保存错误结果的一个管道
stdout = r.stdout.read().decode('gbk')
stderr = r.stderr.read().decode('gbk')
print('正确的返回结果:',stdout)
print('错误的返回结果:',stderr)
print('错误的返回结果:',stderr)

 

二.粘包问题  (只有tcp协议才会发送粘包,udp不会发生)

 

EX: 发送端发送数据,接收端不知道应该如何接收,造成的一种数据混乱的现象

1.合包机制(nagle算法): 将多次连续发送且间隔较小的数据,进行打包数据传送

 

 

 

2.拆包机制: 有一个机制是拆包机制,在发送端,因为受到网卡的MTU限制,将大的超过MTU限制的数据,进行拆分,拆分成多个小的数据,进行传输.  当传输到目标主机的操作系统层时,重新将多个小的数据合并成原本的数据

针对 使用udp协议发送数据,一次收发大小究竟多少合适?
  udp不会发生粘包,udp协议本层对一次收发数据大小的限制是:
    65535 - ip包头(20) - udp包头(8) = 65507

  站在数据链路层,因为网卡的MTU一般被限制在了1500,所以对于数据链路层来说,
一次收发数据的大小被限制在
1500 - ip包头(20) - udp包头(8) = 1472 得到结论: 如果sendto(num) num > 65507 报错 1472 < num < 65507 会在数据链路层拆包,而udp本身就是不可靠协议,所以一旦拆包之后,造成的多个小数据包在网络传输中,如果丢任何一个,那么此次数据传输失败 num < 1472 是比较理想的状态

 

posted @ 2018-08-14 20:05  shuai1993  阅读(144)  评论(0编辑  收藏  举报