Day9 基于TCP的套接字和基于UDP的套接字
- 服务端:
- ss=socket() #创建服务器套接字
- ss.bind() #把地址绑定到套接字
- ss.listen() #监听套接字,
- inf_loop: #服务器无限循环
- cs=ss.accept() 接受客户端连接
- comm_loop: #通讯循环
- cs.recv()/cs.send() #对话(接收与发送)
- cs.close() #关闭客户端套接字
- ss.close() #关闭服务器套接字(可选)
- #客户端
14 cs=socker() #创建客户端套接字
15 cs.connet() #尝试连接服务器
16 command_loop: #通讯循环
17 cs.send()/cs.recv() #对话(发送/接收)
18 cs.close() #关闭客户端套接字
这是基于TCP连接的套接字模型。
UDP链接的套接字模型是这样的:
- 服务端:
- ss=socket() #创建一个服务器的套接字
- ss.bind() #绑定服务器套接字
- inf_loop: #服务器无限循环
- cs=ss.recvfrom()/ss.sendto() #对话(接收与发送)
- ss.cloes() #关闭服务器套接字
- 客户端:
- cs=socket() #创建客户端套接字
- comm_loop: #通信循环
- cs.sendto()/cs.recvfrom() #对话(发送和接收)
- cs.close() #关闭客户套接字
UDP的会话的无关先启动哪一端,先启动服务端或者客户端都不会报错。
而且当客户端发消息的时候,无论服务端收到或者收不到都不会报错;
客户端和服务端收到的消息都分为两部分,
(b"发送的内容",("127.0.0.1",4888)) 我们可以利用 data1,client_addr=udp_server.recvfrom(1024)这种方式来收取数据和对方的地址。
- #udp服务端
- from socket import *
- udp_server=socket(AF_INET,SOCK_DGRAM)
- udp_server.bind(('127.0.0.1',8080))
- while True:
- data,client_addr=udp_server.recvfrom(1024)
- print(data,client_addr)
- udp_server.sendto(data.upper(),client_addr)
- #udp client
- from socket import *
- udp_client=socket(AF_INET,SOCK_DGRAM)
- while True:
- msg=input('>>: ').strip()
- udp_client.sendto(msg.encode('utf-8'),('127.0.0.1',8080))
- data,server_addr=udp_client.recvfrom(1024)
- print(data.decode('utf-8'))
基于TCP的连接,发送数据的时候可能会发生粘包(在数据量比较小,时间间隔比较短的情况下),所以我们要探讨下UDP会不会出现这种情况。
#测试代码:
- #udp server
- from socket import *
- udp_server=socket(AF_INET,SOCK_DGRAM)
- udp_server.bind(('127.0.0.1',8080))
- data1,client_addr=udp_server.recvfrom(1)
- print('data1',data1)
- data2,client_addr=udp_server.recvfrom(1024)
- print('data2',data2)
- #udp client
- from socket import *
- udp_client=socket(AF_INET,SOCK_DGRAM)
- udp_client.sendto('hello'.encode('utf-8'),('127.0.0.1',8080))
- udp_client.sendto('world'.encode('utf-8'),('127.0.0.1',8080))
#通过代码测试我们可以清楚的看到,基于UDP的链接不会发生粘包现象
#但是当UDP发送的字节大于服务端(或者客户端)所接收的字节时,会报错。
实现并发的UDP链接:
- #服务端
- import socketserver
- class MyUDPhandler(socketserver.BaseRequestHandler):
- def handle(self):
- print(self.request)
#(b'aaa', <socket.socket fd=252, family=AddressFamily.AF_INET, type=SocketKind.SOCK_DGRAM, proto=0, laddr=('127.0.0.1', 8080)>)打印出来是这种格式- #数据+用来给回消息的socket+地址
self.request[1].sendto(self.request[0].upper(),self.client_address)- if __name__ == '__main__':
- s=socketserver.ThreadingUDPServer(('127.0.0.1',8080),MyUDPhandler) #UDP的socket服务进程,()内的是地址和端口,后边跟的是自己定义的类
- s.serve_forever()
Day9 基于TCP的套接字和基于UDP的套接字的更多相关文章
- 网络编程——基于TCP协议的Socket编程,基于UDP协议的Socket编程
Socket编程 目前较为流行的网络编程模型是客户机/服务器通信模式 客户进程向服务器进程发出要求某种服务的请求,服务器进程响应该请求.如图所示,通常,一个服务器进程会同时为多个客户端进程服务,图中服 ...
- Learning-Python【28】:基于TCP协议通信的套接字
什么是 Socket Socket 是应用层与 TCP/IP 协议通信的中间软件抽象层,它是一组接口.在设计模式中,Socket 其实就是一个门面模式,它把复杂的 TCP/IP 协议族隐藏在 Sock ...
- 基于TCP的socket套接字的网络编程(客户端/服务端模式)
于数据完整性要求较高的场合,就应采用TCP协议. IP网络层提供IP寻址和路由.因为在网络上数据可以经由多条线路到达目的地,网络层负责找出最佳的传输线路. IP地址与数据包: IP层就是把数据分组从一 ...
- 网络编程----socket介绍、基于tcp协议的套接字实现、基于udp协议的套接字实现
一.客户端/服务器架构(C/S架构) 即C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架 ...
- python基础22------python基础之基于tcp和udp的套接字
一.TCP套接字 1.low版tcp套接字 服务器端 客户端 2.改进版tcp套接字 服务端 客户端 二.UDP的套接字 服务器 客户端 注:udp的套接字可以支持多个客户端同时访问,但tcp套接字就 ...
- 20181225 基于TCP/IP和基于UDP/IP的套接字编程
一.TCP/IP的套接字编程 服务器端代码: import socketserver = socket.socket() # 默认是基于TCP# 基于TCP的对象serve=socket.sock ...
- unix网络编程第四章----基于TCP套接字编程
为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议 #include<sys/socket.h> int socket(int family,int ...
- 基于TCP协议的socket套接字编程
目录 一.什么是Scoket 二.套接字发展史及分类 2.1 基于文件类型的套接字家族 2.2 基于网络类型的套接字家族 三.套接字工作流程 3.1 服务端套接字函数 3.2 客户端套接字函数 3.3 ...
- 基于TCP连接的socket套接字编程
基于TCP协议的套接字编程(简单) 服务端 import socket server = socket.socket() server.bind( ('127.0.0.1', 9999) ) serv ...
随机推荐
- 深入浅出Java MVC(Model View Controller) ---- (JSP + servlet + javabean实例)
在DRP中终于接触到了MVC,感触是确实这样的架构系统灵活性不少,现在感触最深的就是使用tomcat作为服务器发布比IIS好多了,起码发布很简单,使用起来方便. 首先来简单的学习一下MVC的基础知识, ...
- Android初级教程理论知识(第一章快速入门)
一.综合介绍. Android项目的目录结构 Activity:应用被打开时显示的界面 src:项目代码 R.java:项目中所有资源文件的资源id Android.jar:Android的jar包, ...
- 【算法导论】第i小的元素
第i小的元素 时间复杂度:O(n). 基本思想:和快速排序的思想相似,也是对数组进行递归划分,但是有所差别的是,快速排序会递归处理划分的两边,而随机化的选择算法只选择一边. 具 ...
- UNIX环境高级编程——进程控制
一.进程标识符 ID为0的进程是调度进程,常常被称为交换进程.该进程是内核的一部分,它并不执行任何磁盘上的程序,因此也被称为系统进程.进程ID 1通常是init进程,在自举过程结束时由内核调用.ini ...
- Android官方技术文档翻译——Gradle 插件用户指南(4)
最近赶项目,白天基本没时间,只有晚上在家的时候才能看一看.昨天晚上只翻译完了第四章,今天就只发第四章吧. 本文译自Android官方技术文档<Gradle Plugin User Guide&g ...
- Universal-Image-Loader完全解析--从源代码分析Universal-Image-Loader中的线程池
一般来讲一个网络访问就需要App创建一个线程来执行,但是这也导致了当网络访问比较多的情况下,线程的数目可能积聚增多,虽然Android系统理论上说可以创建无数个线程,但是某一时间段,线程数的急剧增加可 ...
- 内存数据网格hazelcast的一些机制原理
hazelcast作为一个内存数据网格工具,还算比较优秀,听说有Apache顶级项目使用它,值得研究下,使用文档可以直接看官方文档,但机制原理相关的资料基本没有,本人硬撸源码写的一些东西,跟大家分享一 ...
- 大型服装集团BI决策系统的分析主题模块
一般BI商业智能解决方案都包含财务.销售.客户等分析模块,本文分享的是某大型服装集团通过帆软FineBI建设的BI决策系统.该决策系统主要针对财务.资金.采购.生产.库存.物流.销售.渠道.产品.客户 ...
- 传输控制协议(TCP) -- TCP状态转换图
TCP状态转换图 在<UNIX网络编程 卷1>一书中,作者给出了TCP状态转换图(如下).本文也将围绕此图进行阐释. 注:上图红框表示比较特殊的地方. TCP状态转换两条主线 图2-4中的 ...
- 操作系统 - Linux进程实现的内部结构
在进程描述符中进入几个字段来表示进程之间的父子关系和兄弟关系. 图3-4显示了一组进程间的亲属关系. 表3-4:建立非亲属关系的进程描述符字段 在某些情况下,内核必须能从进程的PID到处对应的进程描述 ...