• 粘包问题,以及在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 是比较理想的状态
  • 相关阅读:
    控件与布局
    高性能mysql笔记 第一章 mysql架构
    简单排序——冒泡,选择,插入
    spring boot的默认配置
    nginx配置 负载均衡
    nginx+tomcat反向代理
    fiddler(4)安装--L
    fiddler(3)http协议-响应报文--L
    fiddler(2)http协议-请求报文--L
    Fiddler(1)简介--L
  • 原文地址:https://www.cnblogs.com/shuai1993/p/9477472.html
Copyright © 2020-2023  润新知