Pyhton学习——Day31
# 服务端和接收端的send和reve没有任何关系,只与协议之间有关系
# 应用程序产生的数据一定会交给操作系统,并由操作系统往外发送
# 发送端什么时候会清空自己的内存?
# 收到接收端的ACK响应以后才会清除自己的缓存
# 粘包的本质在于接收端在缓存接收,不知道从缓存区接收多少
# 粘包的两种情况:1.发送间隔短,数据量小;2.接收数据量过大
# 接收和发送数据一次不要超过8k(8096个字节),否则会失真
# socket的sendall方法,MTU值最多能发送1500Bytes,就是说发送数据大时,按照分段发出再重新组合,分段越大,再组合就越复杂
# 重新组合后接收的数据丢失的可能性就越大
# 解决粘包的思路:在发包之前告诉接收端发出的数据大小
# 解决无法用socket实现并发,需要使用socket server实现并发
# 多线程服务端,可以实现并发,可以同时开启多个任务等待链接,ThreadingTCPServer(tuple格式的(ip+prot),类名)
#详细代码请见Socket_Server_31 Socket_Client_31 Socket_Client_31_1
# socketserver模块介绍
# BaseServer是socket模块内部定义的一个类
# server类:处理链接
# GrandPa Dad Son
# | | |
# BaseServer<--TCPServer---<UDPServer
# BaseServer
# TCPServer
# UDPServer
# UnixStreamServer
# UnixDatagramServer
#######################################################################################################
# request类:处理通信
# BaseRequestHandler
# StreamRuquestHandler 流式传输处理方法
# DatagramRuquestHandler 数据报传输方法
# ForkingMixIn
# Forking:进程,与并发有关,ForkingServer多进程的开销高于多线程
# Threading:线程,与并发有关,
# 对于TCP来说self.ruquest接收到的是coon,
# 对于UDP来说self.request接收到的就是实际的消息
Win a contest, win a challenge
posted on 2018-03-11 16:25 pandaboy1123 阅读(107) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南