- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章实例讲解Python中SocketServer模块处理网络请求的用法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
SocketServer创建一个网络服务框架。它定义了类来处理TCP,UDP, UNIX streams 和UNIX datagrams上的同步网络请求.
1、Server Types 。
有五个不同的服务器类在SocketServer中.
1.BaseServer定义了API, 而且他不是用来实例化和直接使用的。 2.TCPServer用作TCP/IP的socket通讯。 3.UDPServer使用datagram sockets。 4.UnixStreamServer和UnixDatagramServer使用Unix-domain sockets而且智能在unix平台上使用.
2、Server Objects 。
构建一个服务器, 通过它来监听请求的地址和请求的处理类(not instance).
1.class SocketServer.BaseServer 这是模块中所有服务器对象的超类,它定义了接口,实现大多数都在子类中完成.
2.BaseServer.fileno 。
返回一个整数文件描述符来表示哪个服务器正在监听。这个函数最常见的传递给select.select(),允许监控多个相同处理过程的服务.
3.BaseServer.handle_request 。
处理单一的请求,这个函数会顺序调用接下来的方法。get_request(),verify_request和proccess_request。 用户提供handle()方法抛出一个异常,那么handle_error()方法会被调用。 self.timeout的时间内没有收到请求,handle_timeout()和handle_request()将返回.
4.BaseServer.serve_forever 。
BaseServer.serve_forever(poll_interval=0.5),处理请求一直到明确的shutdown()请求。轮训每隔poll_interval时间内关闭。忽略self.timeout,如果需要使用定时任务,需要使用其他线程.
5.BaseServer.shutdown 。
告诉serve_forever()循环停止.
6.BaseServer.RequestHandlerClass 。
用户请求处理程序类,为每个请求创建这个类的一个实例.
3、Implementing a Server 。
如果你创建一个服务器,它通常可以重复使用现有的类和简单的提供一个自定义请求处理的类。如果不符合需求,有几种BaseServer方法覆盖一个子类.
1.verify_request(reqeust, client_address): 必须返回一个布尔值,如果返回True,请求将被处理,如果返回False,请求将被拒绝。这个函数可以覆盖来实现访问控制服务。 2.process_request(request, client_address): 调用finish_request来创建一个RequestHandlerClass()的实例,如果需要该函数可以创建一个新的进程或协程来处理请求。 3.finish_request(request, client_address): 创建一个请求处理实例。调用handle()来处理请求.
4、Request Handlers 。
请求处理程序做的大部分工作接收传入的请求,并决定采取何种行动。处理程序负责实现“协议”上的套接字层(例如,HTTP或xml - rpc)。从传入的请求处理程序读取请求数据通道,流程,和写一个响应。有三个方法可以重写.
1.setup(): 准备请求的请求处理程序, 就是初始化运行在handle之前。 2.handle(): 做真正的请求工作。解析传入的请求,处理数据和返回响应。 3.finish(): 清理任意时间创建的setup().
5、例子 。
下面例子展示了tcp, udp和异步 。
1.TCPServer 例子 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
import
SocketServer
class
MyHandler(SocketServer.BaseRequestHandler):
def
handle(
self
):
self
.data
=
self
.request.recv(
1024
).strip()
print
'{} wrote:'
.
format
(
self
.client_address[
0
])
print
self
.data
self
.request.sendall(
self
.data.upper())
if
__name__
=
=
'__main__'
:
HOST, PORT
=
'localhost'
,
9999
server
=
SocketServer.TCPServer((HOST, PORT), MyHandler)
server.serve_forever()
|
2.UDPServr 例子 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
import
SocketServer
class
MyHandler(SocketServer.BaseRequestHandler):
def
handle(
self
):
data
=
self
.request[
0
].strip()
socket
=
self
.request[
1
]
print
'{} wrote:'
.
format
(
self
.client_address[
0
])
print
data
socket.sendto(data.upper(),
self
.client_address)
if
__name__
=
=
'__main__'
:
HOST, PORT
=
'localhost'
,
9999
server
=
SocketServer.UDPServer((HOST, PORT), MyHandler)
server.serve_forever()
|
3.异步例子 。
可以通过ThreadingMixIn和ForkingMixIn类来构造异步处理程序.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
import
socket
import
threading
import
SocketServer
class
MyHandler(SocketServer.BaseRequestHandler):
def
handle(
self
):
data
=
self
.request.recv(
1024
)
curr_thread
=
threading.current_thread()
response
=
'{}: {}'
.
format
(curr_thread.name, data)
self
.request.sendall(response)
class
Server(SocketServer.ThreadingMixIn, SocketServer.TCPServer):
pass
def
client(ip, port, message):
sock
=
socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((ip, port))
try
:
sock.sendall(message)
response
=
sock.recv(
1024
)
print
'Received: {}'
.
format
(response)
finally
:
sock.close()
if
__name__
=
=
'__main__'
:
HOST, PORT
=
'localhost'
,
0
server
=
Server((HOST, PORT), MyHandler)
ip, port
=
server.server_address
serer_thread
=
threading.Thread(target
=
server.serve_forever)
server_thread.daemon
=
True
server_thread.start()
print
'Server loop running in thread:'
, server_thread.name
client(ip, port,
'Hello World 1'
)
client(ip, port,
'Hello World 2'
)
client(ip, port,
'Hello World 3'
)
server.shutdown()
server.server_close()
|
4.SocketServer 实现客户端与服务器间非阻塞通信 (1)创建SocketServerTCP服务端 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
#创建SocketServerTCP服务器:
import
SocketServer
from
SocketServer
import
StreamRequestHandler as SRH
from
time
import
ctime
host
=
'xxx.xxx.xxx.xxx'
port
=
9999
addr
=
(host,port)
class
Servers(SRH):
def
handle(
self
):
print
'got connection from '
,
self
.client_address
self
.wfile.write(
'connection %s:%s at %s succeed!'
%
(host,port,ctime()))
while
True
:
data
=
self
.request.recv(
1024
)
if
not
data:
break
print
data
print
"RECV from "
,
self
.client_address[
0
]
self
.request.send(data)
print
'server is running....'
server
=
SocketServer.ThreadingTCPServer(addr,Servers)
server.serve_forever()
|
(2)创建SocketServerTCP客户端 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
from
socket
import
*
host
=
'xxx.xxx.xxx.xxx'
port
=
9999
bufsize
=
1024
addr
=
(host,port)
client
=
socket(AF_INET,SOCK_STREAM)
client.connect(addr)
while
True
:
data
=
raw_input
()
if
not
data
or
data
=
=
'exit'
:
break
client.send(
'%s\r\n'
%
data)
data
=
client.recv(bufsize)
if
not
data:
break
print
data.strip()
client.close()
|
最后此篇关于实例讲解Python中SocketServer模块处理网络请求的用法的文章就讲到这里了,如果你想了解更多关于实例讲解Python中SocketServer模块处理网络请求的用法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这与 Payubiz payment gateway sdk 关系不大一体化。但是,主要问题与构建项目有关。 每当我们尝试在模拟器上运行应用程序时。我们得到以下失败: What went wrong:
我有一个现有的应用程序,其中包含在同一主机上运行的 4 个 docker 容器。它们已使用 link 命令链接在一起。 然而,在 docker 升级后,link 行为已被弃用,并且似乎有所改变。我们现
在 Internet 模型中有四层:链路 -> 网络 -> 传输 -> 应用程序。 我真的不知道网络层和传输层之间的区别。当我读到: Transport layer: include congesti
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
前言: 生活中,我们在上网时,打开一个网页,就可以看到网址,如下: https😕/xhuahua.blog.csdn.net/ 访问网站使用的协议类型:https(基于 http 实现的,只不过在
网络 避免网络问题降低Hadoop和HBase性能的最重要因素可能是所使用的交换硬件,在项目范围的早期做出的决策可能会导致群集大小增加一倍或三倍(或更多)时出现重大问题。 需要考虑的重要事项:
网络 网络峰值 如果您看到定期的网络峰值,您可能需要检查compactionQueues以查看主要压缩是否正在发生。 有关管理压缩的更多信息,请参阅管理压缩部分的内容。 Loopback IP
Pure Data 有一个 loadbang 组件,它按照它说的做:当图形开始运行时发送一个 bang。 NoFlo 的 core/Kick 在其 IN 输入被击中之前不会发送其数据,并且您无法在 n
我有一台 Linux 构建机器,我也安装了 minikube。在 minikube 实例中,我安装了 artifactory,我将使用它来存储各种构建工件 我现在希望能够在我的开发机器上做一些工作(这
我想知道每个视频需要多少种不同的格式才能支持所有主要设备? 在我考虑的主要设备中:安卓手机 + iPhone + iPad . 对具有不同比特率的视频进行编码也是一种好习惯吗? 那里有太多相互矛盾的信
我有一个使用 firebase 的 Flutter Web 应用程序,我有两个 firebase 项目(dev 和 prod)。 我想为这个项目设置 Flavors(只是网络没有移动)。 在移动端,我
我正在读这篇文章Ars article关于密码安全,它提到有一些网站“在传输之前对密码进行哈希处理”? 现在,假设这不使用 SSL 连接 (HTTPS),a.这真的安全吗? b.如果是的话,你会如何在
我试图了解以下之间的关系: eth0在主机上;和 docker0桥;和 eth0每个容器上的接口(interface) 据我了解,Docker: 创建一个 docker0桥接,然后为其分配一个与主机上
我需要编写一个java程序,通过网络将对象发送到客户端程序。问题是一些需要发送的对象是不可序列化的。如何最好地解决这个问题? 最佳答案 发送在客户端重建对象所需的数据。 关于java - 不可序列化对
所以我最近关注了this有关用 Java 制作基本聊天室的教程。它使用多线程,是一个“面向连接”的服务器。我想知道如何使用相同的 Sockets 和 ServerSockets 来发送对象的 3d 位
我想制作一个系统,其中java客户端程序将图像发送到中央服务器。中央服务器保存它们并运行使用这些图像的网站。 我应该如何发送图像以及如何接收它们?我可以使用同一个网络服务器来接收和显示网站吗? 最佳答
我正在尝试设置我的 rails 4 应用程序,以便它发送电子邮件。有谁知道我为什么会得到: Net::SMTPAuthenticationError 534-5.7.9 Application-spe
我正在尝试编写一个简单的客户端-服务器程序,它将客户端计算机连接到服务器计算机。 到目前为止,我的代码在本地主机上运行良好,但是当我将客户端代码中的 IP 地址替换为服务器计算机的本地 IP 地址时,
我需要在服务器上并行启动多个端口,并且所有服务器套接字都应在 socket.accept() 上阻塞。 同一个线程需要启动客户端套接字(许多)来连接到特定的 ServerSocket。 这能实现吗?
我的工作执行了大约 10000 次以下任务: 1) HTTP 请求(1 秒) 2)数据转换(0.3秒) 3)数据库插入(0.7秒) 每次迭代的总时间约为 2 秒,分布如上所述。 我想做多任务处理,但我
我是一名优秀的程序员,十分优秀!