TCP介绍
TCP简称传输控制协议,它是一种面向链接的、可靠的、基于字节流的传输层通信协议,常用于对数据进行准确无误的传输,比如文件下载,浏览器上网
TCP通信步骤:
1-创建连接
2-传输数据
3-关闭连接
TCP的特点
面向连接
通信双方必须先建立好链接才能进行数据的传输,数据传输完成后,双方必须断开此链接,以释放资源
可靠传输
TCP采用发送应答机制
超时重传
错误校验
流量控制和阻塞管理Socket的概念
socket(简称套接字)是进程之间的一个通信工具,好比现实生活中的插座,进程之间想要进行网络通信需要基于这个socket。
socket作用:负责进程之间的网络数据传输,好比数据的搬运工
进程之间的网络数据的传输可以通过socket来完成,socket就是进程间网络数据通信的工具TCP网络应用程序开发流程
TCP网络应用程序开发分为:TCP客户端程序开发,TCP服务端程序开发
客户端程序是指运行在用户设备上的程序,主动发起简历连接请求
服务端程序是指运行在服务设备上的程序,专门为客户端提供数据服务,等待接受连接请求TCP客户端开发流程介绍
1-创建客户端套接字对象
2-和服务端套接字建立连接
3-发送数据
4-接收数据
5-关闭客户端套接字TCP客户端程序开发代码示例:
import socket
if name == ‘main’:
# 创建tcp客户端套接字
# 1. AF_INET:表示ipv4
# 2. SOCK_STREAM: tcp传输协议
tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 和服务端应用程序建立连接
tcp_client_socket.connect((“192.168.131.62”, 8080))
# 代码执行到此,说明连接建立成功
# 准备发送的数据
send_data = “你好服务端,我是客户端小黑!”.encode(“gbk”)
# 发送数据
tcp_client_socket.send(send_data)
# 接收数据, 这次接收的数据最大字节数是1024
recv_data = tcp_client_socket.recv(1024)
# 返回的直接是服务端程序发送的二进制数据
print(recv_data)
# 对数据进行解码
recv_content = recv_data.decode(“gbk”)
print(“接收服务端的数据为:”, recv_content)
# 关闭套接字
tcp_client_socket.close()TCP服务端程序开发流程介绍
1-创建服务端套接字对象 (socket.socket(socket.AF_INET, socket.SOCK_STREAM))
SF_INET表示ipv4地址类型
SOCK_STREAM 表示TCP传输协议类型
2-绑定端口号 (bind(‘ip地址’,端口号))
3-设置监听 (listen(最大等待连接个数))
4-等待接受客户端的连接请求(accept)
5-接收数据(recv(每次接收数据的大小),单位是字节,使用decode进行解码)
6-发送数据(send,要发送二进制数据,使用encode进行编码)
7-关闭套接字str.encode(编码格式),表示把字符串编码成为二进制
data.decode(编码格式),表示把二进制解码成为字符串当客户端与服务端建立连接后,服务端程序推出后不会立即释放,需要等待大概1-2分钟,解决办法有两种:
1-更换服务端端口号
2-设置端口号复用,让服务端程序退出后端口号立即释放
如下:tcp_server_setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,Ture)TCP服务端代码示例
import socket
if name == ‘main’:
# 创建tcp服务端套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置端口号复用,让程序退出端口号立即释放
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 给程序绑定端口号
tcp_server_socket.bind(("", 8989))
# 设置监听
# 128:最大等待建立连接的个数, 提示: 目前是单任务的服务端,同一时刻只能服务与一个客户端,后续使用多任务能够让服务端同时服务与多个客户端,
# 不需要让客户端进行等待建立连接
# listen后的这个套接字只负责接收客户端连接请求,不能收发消息,收发消息使用返回的这个新套接字来完成
tcp_server_socket.listen(128)
# 等待客户端建立连接的请求, 只有客户端和服务端建立连接成功代码才会解阻塞,代码才能继续往下执行
# 1. 专门和客户端通信的套接字: service_client_socket
# 2. 客户端的ip地址和端口号: ip_port
service_client_socket, ip_port = tcp_server_socket.accept()
# 代码执行到此说明连接建立成功
print(“客户端的ip地址和端口号:”, ip_port)
# 接收客户端发送的数据, 这次接收数据的最大字节数是1024
recv_data = service_client_socket.recv(1024)
# 获取数据的长度
recv_data_length = len(recv_data)
print(“接收数据的长度为:”, recv_data_length)
# 对二进制数据进行解码
recv_content = recv_data.decode(“gbk”)
print(“接收客户端的数据为:”, recv_content)
# 准备发送的数据
send_data = “ok, 问题正在处理中…”.encode(“gbk”)
# 发送数据给客户端
service_client_socket.send(send_data)
# 关闭服务与客户端的套接字, 终止和客户端通信的服务
service_client_socket.close()
# 关闭服务端的套接字, 终止和客户端提供建立连接请求的服务
tcp_server_socket.close()TCP网络应用程序注意点:
1-当 TCP 客户端程序想要和 TCP 服务端程序进行通信的时候必须要先建立连接
2-TCP 客户端程序一般不需要绑定端口号,因为客户端是主动发起建立连接的。
3-TCP 服务端程序必须绑定端口号,否则客户端找不到这个 TCP 服务端程序。
4-listen 后的套接字是被动套接字,只负责接收新的客户端的连接请求,不能收发消息。
5-当 TCP 客户端程序和 TCP 服务端程序连接成功后, TCP 服务器端程序会产生一个新的套接字,收发客户端消息使用该套接字。
6-关闭 accept 返回的套接字意味着和这个客户端已经通信完毕。
7-关闭 listen 后的套接字意味着服务端的套接字关闭了,会导致新的客户端不能连接服务端,但是之前已经接成功的客户端还能正常通信。
8-当客户端的套接字调用 close 后,服务器端的 recv 会解阻塞,返回的数据长度为0,服务端可以通过返回数据的长度来判断客户端是否已经下线,反之服务端关闭套接字,客户端的 recv 也会解阻塞,返回的数据长度也为0。
zabbix 监控 目标TCP连通性
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
上一篇:python管理Lib包
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
java实现管线拓扑关系连通性分析
本文详细介绍了Java实现管线拓扑关系连通性的方法,并给出了详细的代码示例;同时详细介绍了深度优先搜索(DFS)和广度优先搜索(BFS)的联系与区别。
Graph 搜索 深度优先搜索 Java 广度优先搜索 -
zabbix3.2使用fping批量监控ip的连通性
自动发现配置
bash 报错处理 服务端 客户端 vim