Python socket服务如何进行配置详解

开发 后端
Python socket服务需要不断的学习才能跟上目前技术的更新潮流。下面我们就来详细的学习下相关的代码,希望对大家有所帮助。

Python socket服务需要我们进行不断的学习,因为广泛的应用需要不断的学习。下面就是一些详细的介绍。希望对大家有所帮助。首先,要明白不是所有的socket服务都需要高性能。

如果要求高性能,使用IOCP或EPoll模式用C/C++来完成,直接用API写,用ACE的proactor封装来完成是比较恰当的行为。但当性能不是主要问题时,用Python socket服务,并享受高的开发效率将是一件快乐的事。下面,是用Python socket服务完成的一个每thread/connect的一个echo服务。

经常的,在写一段Python socket服务代码时,我会先打开《Python Cookbook》(O'Reilly)一书,看看有没有所需要的(这也是保证效率的一种方式),下面的代码就是摘自此书。

  1. import SocketServer  
  2. class MyHandler(SocketServer.BaseRequestHandler):  
  3. def handle(self):  
  4. while 1:  
  5. dataReceived = self.request.recv(1024)  
  6. if not dataReceived: break  
  7. self.request.send(dataReceived)  
  8. myServer = SocketServer.ThreadingTCPServer(('',8881), MyHandler)  
  9. myServer.serve_forever( ) 

只用数行代码就完成工作,是不是非常轻松愉快。注意,这还不是一个实用程序,只是一个简单的示例。但这个示例指示了方向,下面我会把完成一个真正的服务端的一些小技巧一一列出。不过,在这之前,用几行代码完成一个测试用的客户端是一个不错的主意:

  1. import socket  
  2. remote_host = '127.0.0.1' 
  3. remote_port = 9919 
  4. send_buf = open('binary.txt', 'rb').read()   
  5. #send_bufsend_buf = send_buf.replace('\x0D\x0A', '')   
  6. ock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
  7. sock.connect((remote_host, remote_port))  
  8. sock.send(send_buf)  
  9. response_data = sock.recv(1024)  
  10. print response_data  
  11. sock.close( ) 

看着上面写的这些代码,是不是感觉开发效率不一般的高 ^_^,下面进入正题

现在,我们来解决遇到***个问题,MyHander是继承自SocketServer.BaseRequestHandler,但文档对这个模块介绍不怎么详细。不详细的原因?我想是因为这个类实在很简单。打开Lib目录下的SocketServer.py文件,我们直接看代码:

 

  1. class BaseRequestHandler:  
  2. def __init__(self, request, client_address, server):  
  3. self.request = request  
  4. self.client_address = client_address  
  5. self.server = server  
  6. try:  
  7. self.setup()  
  8. self.handle()  
  9. self.finish()  
  10. finally:  
  11. sys.exc_traceback = None # Help garbage collection  
  12. def setup(self):  
  13. pass  
  14. def handle(self):  
  15. pass  
  16. def finish(self):  
  17. pass  

以上就是对Python socket服务的详细介绍。一眼可知,类实现的是一个简单的template模式,定义了setup, handle, finish让继承者重载,模式方法__init__则定义了三个方法的调用顺序同时保证三个方法的运行。 很显然,如果我们要在退出时关闭连接,重定义finish是一个很自然的行为。

【编辑推荐】

  1. Python数组实践中具体问题分析
  2. Python数据类型在常见集合中的语法
  3. Python列表与C#语言的相似度介绍
  4. Python抓取的具体应用解答
  5. Python循环语句使用中异常现象的处理
责任编辑:张浩 来源: 互联网
相关推荐

2010-02-22 16:05:40

Python配置

2010-05-24 16:21:55

SVNServer安装

2010-05-24 16:21:55

SVNServer安装

2010-03-18 19:39:44

Java Socket

2023-03-24 16:18:08

微服务架构

2011-07-14 14:58:19

网络服务器配置服务器

2010-05-25 18:32:22

apache+svn+

2010-03-17 17:19:29

Python数据结构

2010-03-25 18:52:15

Nginx负载均衡

2010-02-01 10:21:36

Python编码转换

2010-02-03 13:55:51

Python 代码

2010-09-27 10:54:53

JVM参数配置

2011-04-29 16:56:47

打印机偏色校正

2010-02-01 14:48:43

2010-02-01 17:33:24

Python主线程

2010-02-01 18:20:17

Python 多重继承

2010-03-11 17:38:20

Python中文

2010-03-15 15:11:50

Python列表

2010-02-02 16:47:12

Python主线程

2010-08-29 20:44:25

DHCP服务器
点赞
收藏

51CTO技术栈公众号