1. 网络-tcp

参考

1.1 tcp简介

介绍

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

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

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

TCP特点

  1. 面向连接

    • 通信双方必须先建立连接才能进行数据的传输,双方都必须为该连接分配必要的系统内核资源,以管理连接的状态和连接上的传输。
    • 双方间的数据传输都可以通过这一个连接进行。
    • 完成数据交换后,双方必须断开此连接,以释放系统资源。
  2. 可靠传输

    • TCP采用发送应答机制

      • TCP发送的每个报文段都必须得到接收方的应答才认为这个TCP报文段传输成果
    • 超时重传
      • 发送端发送一个报文段之和就启动定时器,如果在定时时间内没有收到应答就重新发送这个报文段
      • TCP为了保证不发生丢包,就给每一个包一个序列号,同时序号也保证了传送到接受端实体的包的按序接收
      • 然后接收端实体对已接收到的包发回一个相应的确认(ACK);如果发送端实体在合理的往返时延(RTT)内未收到确认,那么对应的数据包就被假设为已丢失将会被重传.
    • 错误校验
      • TCP用一个校验和函数来校验数据是否有错误;在发送和接收时都要计算校验和
    • 流量控制和拥塞管理
      • 流量控制用来避免主机发送得过快而使接收方来不及完全收下

TCP与UDP的不同点

  • 面向连接(确认有创建三方交流,连接已创建才作传输)
  • 有序数据传输
  • 重发丢失的数据包
  • 舍弃重复的数据包
  • 无差错的数据传输
  • 阻塞/流量控制

udp通信模型

udp通信模型中,在通信开始之前, 不需要建立相关的链接,只需要发送数据即可,类似于生活中的"写信"

1.2 tcp网络程序 - 客户端(重点)

服务器就是提供服务的一方,客户端就是需要被服务的一方

tcp客户端

  1. 创建套接字
  2. 链接服务器
  3. 收发数据
  4. 关闭套接字
from socket import *def main:tcp_socket = socket(AF_INET, SOCK_STREAM)server_ip = input("请输入要链接的ip: ")server_port = input("请输入要链接的port: ")server_addr  = (server_ip, server_port)tcp_socket.connect(server_addr)send_data = input("请输入要发送的数据: ")tcp_socket.send(send_data.encode("gbk"))tcp_socket.close()if __name__ == "__main__":main()

1.3 tcp服务器

  1. socket创建一个套接字
  2. bind绑定ip和port
  3. listen使套接字变为可用被动链接
  4. recv/send接收发送数据
from socket import *def main():# 创建tcp套接字tcp_server_socket = socket(AF_INET, SOCK_STREAM)# 绑定端口tcp_server_socket.bind(("", 7890))# 将tcp变为被动监听tcp_server_socket.listen(128)# 接线员获取客户端的套接字和地址(ip和端口号)new_client_socket, client_addr = tcp_server_socket.accept()# 使用新的套接字进行通信recv_data = new_client_socket.recv(1024)  # 接收数据,最大为1024字节print(recv_data)# 返回数据new_client_socket.send("hahaha".encode("utf-8"))# 关闭套接字tcp_server_socket.close()new_client_socket.close()if __name__ == "__main__":main()

小结:

  • tcp服务器,创建的套接字主要是用来监听的
  • 监听得到新的交互的套接字(可用算是通道吧TuT)

1.3.1 为多个客户端服务

同一时刻只能处理一个客户端,但是多个客户端同时连接,会按连接的顺序进行阻塞~当一个客户端处理完毕之后,会根据排队顺序处理后面的

from socket import *def main():# 创建tcp套接字tcp_server_socket = socket(AF_INET, SOCK_STREAM)# 绑定端口tcp_server_socket.bind(("", 7890))# 转为被动监听tcp_server_socket.listen(128)while True:print("等待一个新的客户端的到来!")# 接收客户端的套接字new_client_socket, client_addr = tcp_server_socket.accept()print("一个新的客户端以及到来 %s" % str(client_addr))# 使用新的套接字进行收发数据recv_data = new_client_socket.recv(1024)print("客户端发送过来的请求是: %s" % recv_data.decode("utf-8"))new_client_socket.send("Hello World".encode("utf-8"))# 关闭套接字new_client_socket.close()print("已经服务完毕...")tcp_server_socket.close()if __name__ == "__main__":main()

1.3.2 为多个客户服务多次

from socket import *def main():tcp_sever_socket = socket(AF_INET, SOCK_STREAM)tcp_sever_socket.bind(("", 8080))tcp_sever_socket.listen(128)while True:print("等待客户的到来...")new_socket, client_addr = tcp_sever_socket.accept()print("检测到 %s 的到来" % str(client_addr))while True:recv_data = new_socket.recv(1024)if  recv_data:print("收到信息 %s" % recv_data.decode("gbk"))new_socket.send("收到您的信息~".encode("gbk"))else:breaknew_socket.close()print("服务完毕...")tcp_server_socket.close()if __name__ == "__main__":main()

python --- 使用socket创建tcp服务相关推荐

  1. python应用系列教程——python使用socket创建tcp服务器和客户端

    全栈工程师开发手册 (作者:栾鹏) python教程全解 python使用socket创建tcp服务器和客户端. 服务器端为一个时间戳服务器,在接收到客户端发来的数据后,自动回复. 客户端,等待用户输 ...

  2. 六步创建TCP服务端

    //六步创建TCP服务端 #include<iostream> #include<Windows.h> using namespace std;int main() {//初始 ...

  3. python应用系列教程——python使用socket创建udp服务器端和客户端

    全栈工程师开发手册 (作者:栾鹏) python教程全解 python使用socket创建udp服务器端和客户端. 服务器端为一个时间戳服务器,在接收到客户端发来的数据后,自动回复. 客户端,等待用户 ...

  4. php udp发送和接收_63、php利用原生socket创建udp服务

    1.案例函数汇总 2.案例 通过socket创建udp服务,获取对端的ip和port信息.并进行打印 2.1.udp服务源码 /** * Copyright(C) Iamasb * @project ...

  5. 使用python基于socket的tcp服务器聊天室

    # coding=utf-8 import socket,threading,time '''代码说明:1.创建一个字典用于接受客户端的用户名和信息2.创建一个类对象client用于编写客户端套接字对 ...

  6. python网络-Socket之TCP编程(26)

    一.TCP简介 1.TCP介绍 TCP协议,传输控制协议(英语:Transmission Control Protocol,缩写为 TCP)是一种面向连接的.可靠的.基于字节流的传输层通信协议. TC ...

  7. MFC:Socket编程—TCP服务端和多个客户端通信

    前言 MFC是微软基础类库,于 C++ 对于 C语言来说,MFC对于window API ,MFC 就相当于C++,window API 相当于C.MFC 封装了 window API 使用起来更加的 ...

  8. python创_Python创建Windows 服务

    Python 写windows 服务,需要使用 pywin32包. 直接上代码: #encoding=utf8 ''' Created on 2014-7-1 @author: wangmengnan ...

  9. python实现socket编程,服务端开启多线程(和多个客户端聊天)

    首先运行服务端,待服务端运行起来之后,最后开始运行客户端进行对话,可以运行多个客户端和服务端对话,注意这个开启的客户端的顺序和服务端的聊天顺序(其实就是阻塞,待上一个客户端和服务端的一段对话结束之后, ...

最新文章

  1. Linux系统函数之IO函数
  2. Spring4有条件
  3. 的mvc_简述PHP网站开发的MVC模式
  4. golang package 是什么意思?一份来自初学者的golang package体验指南
  5. C#获取系统当前时间
  6. vue-router如何参数传递
  7. [OpenJDK]native.java.lang.UNIXProcess_md.c
  8. NFC中国-中国第一NFC论坛,NFC中文论坛+NFC技术社区+NFC_电子发烧友网【申明:来源于网络】...
  9. 5G概念被热炒,运营商吃相不要太难看
  10. 离职时机:避免把项目搞砸了再走人
  11. JavaFX及Java客户端技术的未来
  12. 协同多智能体学习的价值分解网络的原理与代码复现
  13. reflections歌词翻译_Reflections歌词
  14. 正在开启,一名金融猎头的二十年 | 专访伯乐百万金融顾问 Leslie Xu
  15. bootstrap table
  16. 职场健康:大脑20个已知秘密[转]
  17. Python函数参数之*与**用法详解
  18. linux文件查找命令
  19. python余数不等于的符号_有乐 这些符号如此重要,不知道就等于“白练琴”
  20. jzoj3823 遇见 [高斯消元解异或方程组]

热门文章

  1. vep文件如何转换mp4_如何将DVD的vob视频格式转换成mp4格式
  2. 一键 linux桌面安装vnc,Ubuntu 16.04 LTS一键安装VNC
  3. 读取当前linux进程内存_(笔记)Linux上的内存分配
  4. 深度学习试题_高中生物:今年高考试题3点显著变化及5个备考建议!不看准吃亏...
  5. freemaker if 多个条件_第4天|14天搞定Vue3.0,条件渲染和template
  6. iOS持久化存储-CoreData简介
  7. Java编程基础阶段笔记 day 07 面向对象编程(上)
  8. zabbix实现mysql数据库的监控
  9. oracle 数据库查询多条数据的一列值
  10. npm install mysql --save-dev