Python网络编程(socket模块、缓冲区、http协议)
- 服务器:
- localhost/127.0.0.1
- 客户端:
- 只是在本机启动客户端,用127.0.0.1访问
- 服务器:
- 0.0.0.0
- 客户端:
- 可以在本机用127.0.0.1、192.168.0.1
- 服务器:
- 192.168.0.1
- 客户端:
- 局域网内用192.168.0.1
- 如果建立的另一端链接被断开, 则recv立即返回空字符串
- recv是从接受缓冲区取出内容,当缓冲区为空则阻塞
- recv如果一次接受不完缓冲区的内容,下次执行会自动接受
- 如果发送的另一端不存在则会产生Pipe Broken异常
- send是从发送缓冲区发送内容,当缓冲区为满则堵塞
- 协调数据的收发(接受和处理)速度
- 减少和磁盘的交互
- 1.流式套接字采用字节流的方式进行传输,
- 而数据报套接字使用数据报形式传输数据
- 2.tcp套接字会产生粘包,udp不会
- 3.tcp编程可以保证消息的完整性,udp则不一定
- 4.tcp需要listen、accept、udp不用
- 5.tcp消息的发送接收使用recv、send、sendall、
- udp使用recvfrom,sendto
- s.type:表示套接字类型
- s.family:地址类型
- sys.stdin 0
- sys.stdout 1
- sys.stderr 2
-
-
- GET: 获取网络资源
- POST: 提交一定的附加数据
- HEAD: 获取响应头
- PUT: 更新服务器资源
- DELETE: 删除服务器资源
- CONNECT: 未使用
- TRACE: 用于测试
- OPTIONS: 获取服务器性能信息
-
-
- 1xx:提示信息,表示请求已经接收
- 2xx:响应成功
- 3xx:响应需要定向(重新记载链接第三方链接)
- 4xx:客户端错误
- 5xx:服务器端错误
- 1xx:提示信息,表示请求已经接收
- tcp是一种可靠的、面向有链接数据传输服务
- tcp能够保证数据的完整性、顺序性、无重复以及无差错
- tcp是一种以文件流的形式传输数据的服务 文件流之间是没有边界
- 的所以基友可能会产生粘包的情况 粘包是因为接受速度没有传输速度快
- 导致缓存区的数据拥堵 下次取出数据时从而产生非独立数据的链接 这种情况
- 叫做粘包 粘包只有传输多个数据时才会出现
- tcp的编程需要监听套接字 和 等待链接过程 只有链接成功才能发送数据
- 这种情况叫做三次握手、还有断开时的四次挥手
- 三次挥手:客户端请求链接、服务器返回报文、客户端完成链接
- 四次挥手:客户端请求断开、服务器接受请求、服务器准备完毕可以断开、客户端断开
- tcp收发送消息需要使用recv、send、sendall方法
- sendall比特殊 功能和send一样 但sendall有事务 若发送成功返回None 否则触发异常
- 链接时必须先运行服务器端后运行客户端
- udp就比较简单了 是面向无连接的不可靠的数据传输服务
- udp没有数据流 接受大小取决于接收方
- 若数据超出接收方接受范围则丢掉所有超出范围的内容
- udp不存在粘包的情况
- udp不需要等待链接 没有挥手过程 先发就发 想收就收 自由度比较高
- udp编程时收发消息使用recvfrom、sendto方法
- udp可用于广播可以随时断开或链接
- 客户端和服务器端可以随时运行
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
2018-08-08学习笔记
6.4 Android绘图技巧(Primary:四大方法&Layer) 3.2 View的测量 3.3 View的绘制 3.4 ViewGroup的测量 & 3.5 ViewGroup的绘制 3.6 自定义View (3.6.1) 3.6 自定义View (3.6.2) NoSuchMethodException: <init> class android.content.Context, interface android.util.AttributeSet... java.lang.IndexOutOfBoundsException and drawPosText
- 下一篇
JavaWeb技术内幕七:JVM体系结构和工作方式
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/81501369 JVM能够跨越计算机体系结构来执行字节码,主要是因为JVM屏蔽了与各个机器平台相关的软件或者硬件之间的差异。使得与平台相关的耦合由JVM提供者来实现。 本文将介绍 1 jvm的总体设计结构 2 jvm的执行引擎如何工作 3 执行引擎如何模拟执行jvm指令 JVM体系结构 何谓JVM JVM是Java虚拟机,它通过模拟一个计算机来达到一个计算机所具有的的计算功能。而真实的计算机具有哪些功能呢。 1 指令集,这是计算机能识别的机器语言的命令集合 2 计算单元 3 寻址方式 4 寄存器定义,包括操作数寄存器,变址寄存器等 5 存储单元,比如内存和磁盘 什么是指令集 指令集就是CPU中用来控制计算机的一套指令的集合,每个CPU在设计时规定了一系列与其他硬件电路配合的指令系统,通过指令集可以对应地操作硬件电路,简单的指令集可以理解为译码电路,每个指令集单元对应一个电路操作,比如打开,关闭,显示特定数字等功能。 计算机指令集可分为精简指...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果