为什么使用socketserver

虽然Python内置的socket和threading模块能实现简单的多线程服务器,在非正式环境,随便用用还是可以的,但是如果要在生产环境中使用,那是万万不够的。

Python考虑得很周到,为了满足我们对多线程网络服务器的需求,提供了"socketserver"模块。socketserver在内部使用IO多路复用以及多线程/进程机制,实现了并发处理多个客户端请求的socket服务端。每个客户端请求连接到服务器时,socketserver服务端都会创建一个“线程”或者“进程” 专门负责处理当前客户端的所有请求。

使用socketserver要点

  • 创建一个server类,继承"socketserver.BaseRequestHandler";
  • 这个类中必须重写一个名字为"handle"的方法,不能是别的名字,在此进行业务逻辑处理(比如收发数据等);
  • 将这个新建的类,连同服务器的IP和端口作为参数传递给"ThreadingTCPServer()"实例化;
  • 启动"ThreadingTCPServerObj.serve_forever()"。

栗子

服务端

import socketserver

# 1.必须继承socketserver.BaseRequestHandler类,后台自动建立双工通信,等待客户端连接
class MySockServer(socketserver.BaseRequestHandler):
def handle(self):
     # .进行收发数据
# request对象进行接收和发送数据
request = self.request
request.send('欢迎访问socketserver服务器'.encode())  # 发送数据send()
while True:
data = request.recv(1024).decode()          # 接收数据recv()
if data == 'exit':
print('断开与%s的连接!' % (self.client_address,))
break
elif data:
print('来自%s客户端向你发来数据:%s' % (self.client_address, data))
request.send('服务器已收到数据'.encode())   # 发送数据 if __name__ == '__main__':
# 3.创建一个多线程TCP服务器对象,绑定IP和端口
tcp_server = socketserver.ThreadingTCPServer(('127.0.0.1', 8888), MySockServer)
print('启动服务器!')
# 4.启动服务器,服务器将一直保持运行状态
tcp_server.serve_forever()

分析一下服务器端的代码,核心要点有这些:

  • 连接数据封装在"self.request"属性中!通过"self.request"对象调用"send()"和"recv()"方法。
  • "handle()"方法是整个通信的处理核心(业务逻辑处理,如收发数据等),一旦它运行结束,当前连接也就断开了(但其他的线程和客户端还正常),因此一般在此设置一个无限循环。
  • 注意"sock_server = socketserver.ThreadingTCPServer(('127.0.0.1', 8888), MySockServer)"中参数传递的方法。
  • "sock_server.serve_forever()"表示该服务器在正常情况下将永远运行。

客户端

import socket

# 客户端依然使用socket模块就可以了,不需要导入socketserver模块

IP_PORT = ('127.0.0.1', 8888)
# 1.创建socket对象
sock = socket.socket()
# 2.与服务端连接,建立双工通信
sock.connect(IP_PORT)
sock.settimeout(0.5)
# 3.进行收发数据
data = sock.recv(1024).decode()    # 接收数据recv()
print('接收返回数据:%s' % data)
while True:
inp = input('输入要发送的数据:').strip()
if not inp:
continue
sock.send(inp.encode())    # 发送数据send() if inp == 'exit':
print('谢谢使用,再见!')
break
data = sock.recv(1024).decode()
print('接收返回数据:%s' % data)

# 4.断开连接
sock.close()

客户端的代码很好理解,依然使用socket模块就可以了,不需要导入socketserver模块。

  至此,转载请注明出处。

Python 套接字socketserver网络编程的更多相关文章

  1. Python中利用原始套接字进行网络编程的示例

    Python中利用原始套接字进行网络编程的示例 在实验中需要自己构造单独的HTTP数据报文,而使用SOCK_STREAM进行发送数据包,需要进行完整的TCP交互. 因此想使用原始套接字进行编程,直接构 ...

  2. 基于TCP的socket套接字的网络编程(客户端/服务端模式)

    于数据完整性要求较高的场合,就应采用TCP协议. IP网络层提供IP寻址和路由.因为在网络上数据可以经由多条线路到达目的地,网络层负责找出最佳的传输线路. IP地址与数据包: IP层就是把数据分组从一 ...

  3. Python套接字编程(1)——socket模块与套接字编程

    在Python网络编程系列,我们主要学习以下内容: 1. socket模块与基本套接字编程 2. socket模块的其他网络编程功能 3. SocketServer模块与简单并发服务器 4. 异步编程 ...

  4. python套接字编程基础

    python套接字编程 目录 socket是什么 套接字的工作流程 基于tcp的套接字 基于udp的套接字 socket是什么 客户端/服务器架构(C/S架构) 服务端:提供服务的一端 客户端:请求服 ...

  5. python套接字编程实现ntp服务和远程命令执行

    python套接字编程实现ntp服务和远程命令执行 目录 基于udp实现ntp服务 基于tcp实现远程命令执行 基于udp实现远程命令执行 tcp与udp的比较 前面关于套接字基础请查阅 https: ...

  6. Python全栈【Socket网络编程】

    Python全栈[socket网络编程] 本章内容: Socket 基于TCP的套接字 基于UDP的套接字 TCP粘包 SocketServer 模块(ThreadingTCPServer源码剖析) ...

  7. python基础教程总结13——网络编程,

    1.网络设计模块 1.1 socket模块    根据连接启动的方式以及本地套接字要连接的目标,套接字之间的连接过程可以分为三个步骤:服务器监听,客户端请求,连接确认. 1)服务器监听:是服务器端套接 ...

  8. 吴裕雄--天生自然python学习笔记:Python3 网络编程

    Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络 ...

  9. python套接字基本使用

    socket socket通常也称作"套接字",用于描述IP地址和端口,应用程序通常通过"套接字"向网络发出请求或者应答网络请求,可以认为是一种计算机网络的数据 ...

随机推荐

  1. mysql 开发进阶篇系列 4 SQL 优化(各种优化方法点)

    1 通过handler_read 查看索引使用情况 如果索引经常被用到 那么handler_read_key的值将很高,这个值代表了一个行被索引值读的次数, 很低的值表明增加索引得到的性能改善不高,索 ...

  2. sql server 性能调优之 当前用户请求分析 (1)

    一. 概述 在生产数据库运行期间,有时我们需要查看当前用户会话状态或者是说数据库当前是否运行良好, 应用的场景比如:当运行的应用系统响应突然变慢时需要分析数据库的.或想分析当前的数据库是否繁忙,是否有 ...

  3. mysql 开发基础系列4 字符数据类型

    字符串类型 1.1 CHAR 和VARCHAR 类型 CHAR 列的长度固定为创建表时声明的长度,VARCHAR 列中的值为可变长字符串.在检索的时候,CHAR 列删除了尾部的空格,而VARCHAR ...

  4. newwork setup

    #-*-coding:utf-8-*- ######################################################################### # Copy ...

  5. linq标准查询运算符

    Order By操作 适用场景:对查询出的语句进行排序,比如按时间排序等等. 说明:按指定表达式对集合排序:延迟,:按指定表达式对集合排序:延迟,默认是升序,加上descending表示降序,对应的扩 ...

  6. Ubuntu16.04环境下搭建基于三台主机的mysql galera cluster集群(实测有效)

    (注意: (1)文中红色字体部分不一定需要操作 (2)由于word文档编辑的原因,实际操作时部分命令需要手动输入!!直接复制粘贴会提示错误!! ) 一  搭建环境: 1 Ubuntu16.04版本(系 ...

  7. spring学习(三) ———— spring事务操作

    前面一篇博文讲解了什么是AOP.学会了写AOP的实现,但是并没有实际运用起来,这一篇博文就算是对AOP技术应用的进阶把,重点是事务的处理. --wh 一.jdbcTemplate 什么是JdbcTem ...

  8. Go基础系列:数据类型转换(strconv包)

    Go不会对数据进行隐式的类型转换,只能手动去执行转换操作. 简单的转换操作 转换数据类型的方式很简单. valueOfTypeB = typeB(valueOfTypeA) 例如: // 浮点数 a ...

  9. 翻译:replace into语句(已提交到MariaDB官方手册)

    本文为mariadb官方手册:REPLACE INTO的译文. 原文:https://mariadb.com/kb/en/replace/ 我提交到MariaDB官方手册的译文:https://mar ...

  10. IIS发布网站 报错500.19 错误解决过程记录

    首先先报上我的环境 WindowsServer 2012 IIS 8.5 网站是FrameWork 4.0 发布网站后浏览,报错信息如下: 解决过程记录如下: 1.看到这个问题首先想到的是权限问题,设 ...