python网络编程之socketserver

简介:

防伪码:存在的,忘却了,红尘万丈,入眸幻灭


  在进行网络编程前我们先来说说在网络中服务器与客户端是如何交互的,也就是传说中的TCP三次握手。

wKiom1iIRg3DUQ5rAAKGMa2dV9w418.png

  三次握手的目的是为了确认客户端与服务端都能接收到对方的信息,以下是三次握手的详细过程:

    第一次握手:客户端给服务端发送请求包

      此时服务端确认自己可以接收到客户端的请求包

      客户端无法确认服务端是否接收到了自己发的请求包

    第二次握手:服务端回复客户端

      此时客户端确认自己发的请求包已被服务端收到,也确认自己可以正常接收服务端发来的包

      服务端可以确认自己能接收到客户端的包,但不能确认客户端是否能收到自己发送的包

    第三次握手:客户端回复服务端

      此时客户端已无疑问

      服务端也确认刚刚客户端收到了自己的回复包。两边都没问题了,开始通信

  在python中提供了两个socket编程模块,分别是socket和socketserver。

  我们先来说说socket编程需要经历哪些步骤:

   客户端:

      1、创建socket客户端连接对象

      2、通过连接对象的connect()方法连接服务端

      3、通过连接对象的send()方法给服务端发送信息或指令

      4、通过连接对象的recv()方法接收服务端的返回信息

      5、通过连接对象的close()方法断开连接
   服务端:

      1、创建socket服务端连接对象

      2、通过连接对象的bind()方法绑定要监听的IP与端口

      3、通过连接对象的listen()方法来监听

      4、通过连接对象的accept()方法创建与客户端交互的子连接对象并等待客户端连接

      5、接收并处理客户端的请求

      6、将处理结果返回给客户端

  由于socket无法支持多用户,多并发。于是就有了socketserver

  socketserver最主要的作用就是实现并发处理。

  socketserver有以下几种类型:

  TCPServer:tcp协议

1
class  socketserver.TCPServer(server_address,RequestHandlerClass,bind_and_activate = True )

  ThreadingTCPServer:多线程,多并发的TCPServer

1
class  socketserver.ThreadingTCPServer(server_address,RequestHandlerClass,bind_and_activate = True )

  ForkingTCPServer:多进程,多并发的TCPServer #在windows中不能使用这个

1
class  socketserver.ForkingTCPServer(server_address,RequestHandlerClass,bind_and_activate = True )

  UDPServer:udp协议

1
class  socketserver.UDPServer(server_address,RequestHandlerClass,bind_and_activate = True )

  UnixStreamServer:tcp协议,Unix本机间不同进程间通信可以使用这个server

1
class  socketserver.UnixStreamServer(server_address,RequestHandlerClass,bind_and_activate = True )

  UnixDatagramServer:udp协议,Unix本机间不同进程间通信可以使用这个server

1
class  socketserver.UnixDatagramServer(server_address,RequestHandlerClass,bind_and_activate = True )  

  BaseServer是所有Server类型的基类。

  TCPServer继承了BaseServer,UnixStreamServer继承了TCPServer。

  UDPServer继承了TCPServer,UnixDatagramServer继承了UDPServer。

  BaseServer有以下这些方法:

    fileno():返回文件描述符

    handle_request():处理单个请求

    serve_forever(poll_interval=0.5):处理多个请求

      poll_interval用来设置多长时间检查一下是否有收到shutdown()请求

      当收到shutdown()请求后,调用service_actions(),serve_forever将停止提供服务

    shutdown():告诉serve_forever()让其停掉

    server_close():关闭服务


  创建socketserver的步骤:

  1、创建一个BaseRequestHandlerclass的子类并在子类中重写handle()方法

    这个子类用来处理客户端的请求

    与客户端所有的交互都是在handle()方法中编写

  2、实例化一个server(如TCPServer)类,并且将Server_IP和上一步创建的子类传给这个实例化的类(此处是       TCPServer)作为参数

  3、调用第2步实例化出来的对象的方法,这里假定这个实例化出来的对象为server:

    server.handle_request():只处理一个请求,处理完后退出

    server.serve_forever():处理多个请求,永远执行

  4、调用close()方法关闭server


  重写BaseRequestHandlerclass类的handle()方法:

1
2
3
4
5
6
7
8
def  handle( self ):
     #self.request is the TCP socket connected to the client
     self .data  =  self .request.recv( 1024 ).strip()
     print ( "{} wrote:" . format ( self .client_address[ 0 ]))
     print ( self .data)
     #just send back the same data,but upper-cased
     self .request.sendall( self .data.upper())
     #sendall其实就是重复调用send,在这里也可以用send









本文转自 忘情OK  51CTO博客,原文链接:http://blog.51cto.com/itchentao/1894707,如需转载请自行联系原作者
目录
相关文章
|
1月前
|
运维 监控 数据可视化
Python 网络请求架构——统一 SOCKS5 接入与配置管理
通过统一接入端点与标准化认证,集中管理配置、连接策略及监控,实现跨技术栈的一致性网络出口,提升系统稳定性、可维护性与可观测性。
|
4月前
|
机器学习/深度学习 算法 量子技术
GQNN框架:让Python开发者轻松构建量子神经网络
为降低量子神经网络的研发门槛并提升其实用性,本文介绍一个名为GQNN(Generalized Quantum Neural Network)的Python开发框架。
110 4
GQNN框架:让Python开发者轻松构建量子神经网络
|
27天前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的青少年网络使用情况分析及预测系统
本研究基于Python大数据技术,构建青少年网络行为分析系统,旨在破解现有防沉迷模式下用户画像模糊、预警滞后等难题。通过整合多平台亿级数据,运用机器学习实现精准行为预测与实时干预,推动数字治理向“数据驱动”转型,为家庭、学校及政府提供科学决策支持,助力青少年健康上网。
|
2月前
|
JavaScript Java 大数据
基于python的网络课程在线学习交流系统
本研究聚焦网络课程在线学习交流系统,从社会、技术、教育三方面探讨其发展背景与意义。系统借助Java、Spring Boot、MySQL、Vue等技术实现,融合云计算、大数据与人工智能,推动教育公平与教学模式创新,具有重要理论价值与实践意义。
|
3月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
225 18
|
4月前
|
JSON 网络安全 数据格式
Python网络请求库requests使用详述
总结来说,`requests`库非常适用于需要快速、简易、可靠进行HTTP请求的应用场景,它的简洁性让开发者避免繁琐的网络代码而专注于交互逻辑本身。通过上述方式,你可以利用 `requests`处理大部分常见的HTTP请求需求。
459 51
|
3月前
|
数据采集 存储 数据可视化
Python网络爬虫在环境保护中的应用:污染源监测数据抓取与分析
在环保领域,数据是决策基础,但分散在多个平台,获取困难。Python网络爬虫技术灵活高效,可自动化抓取空气质量、水质、污染源等数据,实现多平台整合、实时更新、结构化存储与异常预警。本文详解爬虫实战应用,涵盖技术选型、代码实现、反爬策略与数据分析,助力环保数据高效利用。
242 0
|
10月前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
543 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
4月前
|
存储 监控 算法
基于 Python 跳表算法的局域网网络监控软件动态数据索引优化策略研究
局域网网络监控软件需高效处理终端行为数据,跳表作为一种基于概率平衡的动态数据结构,具备高效的插入、删除与查询性能(平均时间复杂度为O(log n)),适用于高频数据写入和随机查询场景。本文深入解析跳表原理,探讨其在局域网监控中的适配性,并提供基于Python的完整实现方案,优化终端会话管理,提升系统响应性能。
129 4
|
6月前
|
调度 Python
探索Python高级并发与网络编程技术。
可以看出,Python的高级并发和网络编程极具挑战,却也饱含乐趣。探索这些技术,你将会发现:它们好比是Python世界的海洋,有穿越风暴的波涛,也有寂静深海的奇妙。开始旅途,探索无尽可能吧!
181 15

推荐镜像

更多