一、TCP、UDP区别总结

1、TCP面向连接(如打电话要先拨号建立连接);UDP是无连接的,即发送数据之前不需要建立连接

2、TCP提供可靠的服务,也就是说,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,即不保证可靠交付

3、UDP具有较好的实时性,工作效率比TCP高,适用于对高速传输和实时性较高的通信或广播通信

4、每一条TCP连接只能是点到点的;UDP支持一对一,一对多,多对一和多对多的交互通信

5、TCP对系统资源要求较多,UDP对系统资源要求较少

 二、TCP服务端以及客户端编程

服务器端:

from socket import *

#创建套接字sockfd
sockfd = socket() #默认参数可以创建tcp套接字 #套接字绑定ip,端口
sockfd.bind(('192.168.191.1',8888)) #让套接字具有监听功能,创建监听队列
sockfd.listen(5) while True:
print("waiting for connect....")
connfd,addr = sockfd.accept()
# accept函数主要用于服务器端,一般位于listen函数之后,默认会阻塞进程,
# 直到有一个客户请求连接,建立好连接后,它返回的一个新的套接字connfd,以及客户的地址addr,
# 此后,服务器端即可使用这个新的套接字connfd与该客户端进行通信,
# 而sockfd则继续用于监听其他客户端的连接请求
print("connect from",addr)
while True:
data = connfd.recv(1024) #收消息
if not data:
break
print("客户端发来的消息:",data.decode())
#发消息通过str.decode()编码 connfd.send("服务端已收到消息!".encode()) #发消息
#收消息通过str.encode()解码 connfd.close() sockfd.close()

客户端:

from socket import *

#创建套接字
sockfd = socket() #发起连接
sockfd.connect(('192.168.191.1',8888)) while True:
msg = input("发消息>>")
#服务端那边是先收消息,所以客户端就先发
#发消息
sockfd.send(msg.encode())
if not msg:
break #收消息
data = sockfd.recv(1024)
print(data.decode()) sockfd.close()

三、UDP服务端以及客户端编程

服务器端:

from socket import *
import sys
from time import ctime #这里使用了一个sys.agrv,从命令行传入IP和端口
#格式:python3 udp_server.py 192.168.191.1 8888 #如果输入格式不对,给一个提示信息
if len(sys.argv) < 3:
print('''
argv is error!!!
input as
python3 udp_server.py 192.168.191.1 8888
''') HOST = sys.argv[1]
PORT = int(sys.argv[2])
ADDR = (HOST,PORT)
BUFFERSIZE = 1024 #创建数据报套接字
sockfd = socket(AF_INET,SOCK_DGRAM)
#绑定地址
sockfd.bind(ADDR) while True:
#收消息
data,addr = sockfd.recvfrom(BUFFERSIZE)
#recvfrom()和recv()有点不同,recvfrom()返回的是接收到的消息和消息发送者的地址
print('recv from %s:%s' %(addr,data.decode())) #发消息
sockfd.sendto((" %s 接收到消息" %ctime()).encode(),addr)
#sendto()和send()也有点不同,sendto()有两个参数,一个为发送的消息,另一个是发送给某个主机的地址 sockfd.close()

客户端:

from socket import *
import sys #从命令行传入IP和端口
#python3 udp_server.py 192.168.191.1 8888
if len(sys.argv) < 3:
print('''
argv is error!!!
input as
python3 udp_server.py 192.168.191.1 8888
''') HOST = sys.argv[1]
PORT = int(sys.argv[2])
ADDR = (HOST,PORT)
BUFFERSIZE = 1024 #创建数据报套接字
sockfd = socket(AF_INET,SOCK_DGRAM) while True:
#发消息
data = input("消息>>")
if not data:
break
sockfd.sendto(data.encode(),ADDR) #收消息
data,ADDR = sockfd.recvfrom(BUFFERSIZE)
print('从服务器收到:',data.decode())
sockfd.close()

四、TCP和UDP编程步骤区别总结

1、创建套接字

TCP使用的是SOCK_STREAM(套接字类型:字节流),SOCK_STREAM这种的特点是面向连接的,即每次收发数据之前必须通过connect建立连接

UDP使用的是SOCK_DGRAM(套接字类型:数据包),SOCK_DGRAM这种是User Datagram Protocol协议的网络通讯,它是无连接的,不可靠的

2、TCP服务端使用listen开启监听以及accept阻塞进程来等待客户端连接(所以TCP对系统资源要求较多),UDP是面向无连接的则不需要

3、收发消息

TCP使用的是recv()接收消息,send()发送消息

UDP使用的是recvfrom()循环接收数据,sendto()发送数据

*TCP一旦发生丢包,TCP将后续的包缓存起来,等前面的包重传并接收到后再继续发送,延时会越来越大

UDP对实时性要求较为严格的情况下,采用自定义重传机制,能够把丢包产生的延迟降到最低,尽量减少网络造成的影响

TCP和UDP的区别以及使用python服务端客户端简单编程的更多相关文章

  1. Python TCP与UDP的区别

    TCP:英文全拼(Transmission Control Protocol)简称传输控制协议,它是一种面向连接的.可靠的.基于字节流的传输层通信协议. TCP通信需要经过创建连接.数据传送.终止连接 ...

  2. 面试官:说说TCP和UDP的区别和应用场景

    原创文章首发于公众号:「码农富哥」,欢迎收藏和关注,如转载请注明出处! 上一篇聊完 一文彻底搞懂 TCP三次握手.四次挥手过程及原理 这次聊聊TCP和UDP的区别和场景 TCP/IP 中有两个具有代表 ...

  3. OSI参考模型及各层功能,TCP与UDP的区别

    OSI参考模型:ISO/IEC 7498标准定义了网络互联的7层结构模型,即开放系统互连参考模型. OSI参考模型定义了开放系统的层次结构.层次之间的相互关系,以及各层所包括的可能的服务.OSI的服务 ...

  4. TCP与UDP的区别

    TCP与UDP的区别 TCP面向连接:UDP是无连接,即发送数据之前不需要建立连接 TCP提供可靠的服务,TCP连接传送的数据,无差错.不丢失.不重复,且按顺序到达:UDP尽最大努力交付,即不保证可靠 ...

  5. TCP和UDP的区别(转)

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  6. TCP与UDP的区别(转)

    源:http://blog.chinaunix.net/uid-20745340-id-1878774.html 参考:TCP协议与UDP协议的区别 TCP与UDP的区别 中国移动.中国联通推行的GP ...

  7. 【基础网络】TCP与UDP 的区别

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  8. 【转】TCP/IP协议中TCP和UDP的区别

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  9. 知其所以然~tcp和udp的区别

    TCP UDP TCP与UDP基本区别 基于连接与无连接 TCP要求系统资源较多,UDP较少: UDP程序结构较简单 流模式(TCP)与数据报模式(UDP); TCP保证数据正确性,UDP可能丢包 T ...

随机推荐

  1. python学习日记(模块导入)

    什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的代码(.p ...

  2. IDictionary使用/声明

    因为不常用,老师忘记怎么申明..这次记下来,哪天用了又忘了就来翻翻 主要代码 IDictionary<string, string> openWith = new Dictionary&l ...

  3. [HNOI2007]神奇游乐园(插头DP)

    题意:n*m的矩阵内值有正有负,找一个四连通的简单环(长度>=4),使得环上值的和最大. 题解:看到2<=m<=6和简单环,很容易想到插头DP,设f[i][j][k]表示轮廓线为第i ...

  4. [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [E:\soft\studySoft\tomcat\apache-tomcat-8.5.33\webapp

    问题 启动tomcat,就一直卡在了这里 继续往上查看日志 解决方法:

  5. mac-redis安装与使用

    安装: brew install redis --------------- 使用: 启动redis-server: sudo redis-server 连接:./redis-cli -h 127.0 ...

  6. trackerClient.getConnection()为null

    如题,整了个fastDFS文件服务器.但是集成项目spring boot时上传文件失败! Debug到trackerClient.getConnection()时为null.于是看了服务器上track ...

  7. vue DES 加密

    安装crypto-js cnpm install crypto-js --save 封装一个des.js ECB模式 import cryptoJs from 'crypto-js' // DES加密 ...

  8. Linux进程管理工具Supervisor

    简述 Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启. 它是通过fork/exec的方式把这些被管 ...

  9. 神奇的 UNICODE 字符 : U+202E

  10. 查看文件状态与跟踪新文件(git status/add)

    查看当前文件状态 使用git status查看文件状态,如果是空仓库,执行结果如下 $ git status On branch master No commits yet nothing to co ...