4.0网络通信模型-TCP

 

 

 

一、什么是TCP协议

TCP协议,传输控制协议(英语:Transmission Control Protocol,缩写为 TCP)是一种面向连接的、可靠的、基于字节流的传输层通信协议,由IETF的RFC 793定义。

TCP通信需要经过创建连接、数据传送、终止连接三个步骤。

TCP通信模型中,在通信开始之前,一定要先建立相关的链接,才能发送数据,类似于生活中,“打电话”"

二、TCP特点

1)TCP采用发送应答机制
TCP发送的每个报文段都必须得到接受方的应答才认为这个TCP报文段传输成功
例如:迅雷下载过程中有少量的上传数据,就是迅雷服务器把下载包分成N块传给客户端,客户端再回传消息给服务器表示下载成功,继续下一块传输
2)超时重传
发送端发出一个报文段之后就启动定时器,如果在定时时间内没有收到应答就重新发送这个报文段。
TCP为了保证不发生丢包,就给每个包一个序号,同时序号也保证了传送到接收端实体的包的按序接收。然后接收端实体对已成功收到的包发回一个相应的确认(ACK);如果发送端实体在合理的往返时延(RTT)内未收到确认,那么对应的数据包就被假设为已丢失将会被进行重传。
3)错误校验
TCP用一个校验和函数来校验数据是否有错误;在发送和接收时都要计算校验和。
4)流量控制和阻塞管理
流量控制用来避免主机发送得过快而使接收方来不及完全收下。

三、TCP与UDP的不同点
1、面向连接(确认有创建三方交握,连接已创建才作传输。)
2、有序数据传输
3、重发丢失的数据包
4、舍弃重复的数据包
5、无差错的数据传输
6、阻塞/流量控制
7、udp通信模型中,在通信开始之前,不需要建立相关的链接,只需要发送数据即可,类似于生活中,“写信”"

UDP通信模型

å¨è¿éæå¥å¾çæè¿°

TCP通信模型

å¨è¿éæå¥å¾çæè¿°

四、TCP客户端向服务器发送消息

#coding:utf-8
import socket

def main():
	# 1.创建TCP的套接字
	tcp_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

	# 2.链接服务器
	server_ip = input('请输入要链接的服务器的ip:')
	server_port = int(input('请输入要链接的服务器的port:'))
	server_addr = (server_ip, server_port)
	tcp_socket.connect(server_addr)

	# 3.发送消息
	send_data = input('请输入要发送的消息:')
	tcp_socket.send(send_data.encode('gbk'))

	# 4.关闭套接字
	tcp_socket.close()

if __name__ == '__main__':
	main()

五、TCP服务器接收客户端连接请求

固定流程
1、socket 创建一个套接字
2、bingd绑定ip和Port
3、listen 使套接字变为可以被动链接
4、accept接收发送数据
5、recv/send接收发送数据

#coding:utf-8
import socket

def main():
	# 1.创建套接字
	tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

	# 2.绑定本地信息,元组
	tcp_server_socket.bind(('', 8080))

	# 3.让默认的套接字由主动变为被动 listen 监听
	tcp_server_socket.listen(128)  # 表示等待的最大连接数

	print('等待客户端链接...')  #开始堵塞,直到有客户端连接进来
	# 4.等待客户端的链接 accept 返回一个元组,产生新的套接字服务客户端
	new_client_socket, client_addr = tcp_server_socket.accept()
	print('有客户端正在连接,请稍等...')

	print('对方ip和端口为:%s' % str(client_addr))
	
	# 5.接收客户端发送过来的请求
	recv_data = new_client_socket.recv(1024)  #不需要返回对方ip和port 所以不用recvfrom
	print(recv_data)

	# 6.回送一部分数据给客户端
	new_client_socket.send('where you are? ----OK----'.encode('utf-8'))

	#关闭套接字
	new_client_socket.close()
	tcp_server_socket.close()

if __name__ == '__main__':
	main()

六、客户端与服务端交互

#coding:utf-8
import socket

def main():
	# 1.创建套接字
	tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

	# 2.绑定本地信息,元组
	tcp_server_socket.bind(('', 8080))

	# 3.让默认的套接字由主动变为被动 listen 监听
	tcp_server_socket.listen(128)  # 表示等待的最大连接数

	# 循环等待客户端
	while True:
		print('等待新客户端连接...')  #开始堵塞,直到有客户端连接进来
		# 4.等待客户端的链接 accept 返回一个元组,产生链接1,链接2...
		new_client_socket, client_addr = tcp_server_socket.accept()
		print('有客户端正在连接,请稍等...%s' % str(client_addr))
		
		# 为同一个客户端 服务多次
		while True:
			# 5.接收客户端发送过来的请求
			recv_data = new_client_socket.recv(1024)  #不需要返回对方ip和port 所以不用recvfrom
			print('客户端发送的请求是:%s' % recv_data.decode('utf-8'))

			# 如果recv解堵塞,2种情况:
			# 1.客户端发送过来数据(发送消息不能空)
			# 2.客户端调用close导致 recv_data 为空,if none = false
			if recv_data:
				# 6.回送一部分数据给客户端
				new_client_socket.send('where you are? ----OK----'.encode('utf-8'))
			else:
				break
		#关闭本次连接的套接字
		new_client_socket.close()
		print('该客户端服务已结束,谢谢参与!')

	tcp_server_socket.close()

if __name__ == '__main__':
	main()

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值