成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python實現Socket服務操作技巧分享

開發 后端
Python實現Socket服務看似是一個比較麻煩的操作,不過當我們真正實踐之后就會發現,其實是比較容易實現的。我們接下來就一起來看看具體的操作步驟吧。

Python編程語言的出現給我們帶來了哪些好處呢?對于大多數開發人員來說,應該是深有體會的。這一語言優秀的功能特點及簡單易學的優勢在很大程度上提高了編程人員程序開發的效率。在這里我們可以先從Python實現Socket服務的相關技巧來了解一下這一語言的編寫方式。#t#

首先,要明白不是所有的Socket服務都需要高性能。如果要求高性能,使用IOCP或EPoll模式用C/C++來完成,直接用API寫,用ACE的proactor封裝來完成是比較恰當的行為。但當性能不是主要問題時,用Python實現Socket服務,并享受高的開發效率將是一件快樂的事。下面,是用python完成的一個每thread/connect的一個echo服務。

經常的,在寫一段Python代碼時,我會先打開《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( ) 

只用數行代碼就完成工作,是不是非常輕松愉快。注意,這還不是一個實用程序,只是一個簡單的示例。但這個示例指示了方向,下面我會把Python實現Socket服務的一些小技巧一一列出。不過,在這之前,用幾行代碼完成一個測試用的客戶端是一個不錯的主意:

 

 

  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. sock = 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( ) 

看著上面寫的這些代碼,是不是感覺開發效率不一般的高 ^_^,下面進入正題

現在,我們來解決Python實現Socket服務中遇到***個問題,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 

一眼可知,類實現的是一個簡單的template模式,定義了setup, handle, finish讓繼承者重載,模式方法__init__則定義了三個方法的調用順序同時保證三個方法的運行。 很顯然,如果我們要在退出時關閉連接,重定義finish是一個很自然的行為。

 

 

  1. def finish(self):  
  2. self.request.close() 

第二個問題,如何記日志。Python有日志模塊logging。

 

 

  1. import logging  
  2. logging.basicConfig(level=logging.DEBUG,  
  3. format='%(asctime)s %(levelname)s %(message)s',  
  4. filename='log.txt',  
  5. filemode='a+'

 


不過實際操作Python實現Socket服務中需要做一點點的補充。因為在多線程程序中,要記錄日志需要線程相關的唯一ID來識別一些東西。我沒有找到直接的線程ID(哪位兄弟找到了請告知),但Python中有一個名為id的內建函數,用來返回一個對象的identity (注1)。將要記錄的信息預定義一個模板,我們就能得到一個漂亮的輸出了。

 

 

  1. def LogTemplate(self, s):  
  2. return '[id.' + str(id(self.request)) + ']: ' + str(s)  
  3. def Log(self, s):  
  4. ss = self.LogTemplate(s)  
  5. print ss  
  6. logging.info(ss)  
  7. def LogErr(self, s):  
  8. ss = self.LogTemplate(s)  
  9. print ss  
  10. logging.error(ss) 

下面我們可以這樣寫了

  1. def setup(self):  
  2. self.Log('進入處理線程')  
  3. def finish(self):  
  4. self.request.close()  
  5. self.Log("退出處理線程") 

 

另外模塊binascii對日志也很有用,我就會用到binascii.b2a_hex來幫助把一串二進制轉成可見的ASCII,象接收到的數據就***用b2a_hex轉換后再記日志。

第三個問題,超時處理。不多說了,直接貼出代碼。

  1. def setup(self):  
  2. self.request.settimeout(60)  
  3. def handle(self):  
  4. while 1:  
  5. try:  
  6. #接收和發送操作,略  
  7. except Socket.timeout:  
  8. print "caught Socket.timeout exception" 

每完成一小步,可以試試用測試程序發送你想發送的內容進行測試。你會非常高興的看到,Python實現Socket服務是如此的簡單。

責任編輯:曹凱 來源: 博客園
相關推薦

2010-03-03 16:57:28

Python字符

2010-03-05 13:29:00

Python增量備份

2010-03-04 10:50:45

windows ser

2009-12-10 17:27:39

PHP操作Cookie

2010-01-25 18:33:35

Android鍵盤操作

2010-03-04 15:57:23

Python實現ini

2009-12-16 11:04:51

Ruby操作文件權限

2010-01-06 17:02:28

.Net Framew

2010-01-28 14:12:20

Android Act

2010-01-28 17:12:45

Android閃屏

2009-12-10 10:24:24

PHP寫入文件

2009-12-10 17:20:00

PHP服務器架設

2010-02-01 17:09:07

C++鏈表操作

2010-01-15 19:04:09

2011-06-29 11:09:44

SEO外鏈

2009-12-29 11:01:46

WPF淡入效果

2010-01-04 14:14:43

Silverlight

2010-01-27 18:06:03

Android短信發送

2009-12-30 16:19:49

Silverlight

2010-02-24 11:22:04

WCF方法重載
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧洲精品一区 | 欧美一级艳情片免费观看 | 91av视频在线播放 | 大吊一区二区 | 欧美精品成人影院 | 特一级黄色毛片 | 欧美一区二区在线免费观看 | 岛国精品| 国产精品永久免费视频 | 奇米影视首页 | 99re6热在线精品视频播放 | 亚洲一区国产精品 | 亚洲综合资源 | 国产精品色| 九九九久久国产免费 | 成人一区二区在线 | 亚洲精品www久久久久久广东 | 手机在线观看av | 亚洲精品在线国产 | av网站观看 | 男女羞羞免费视频 | 国产一级特黄视频 | 亚洲 欧美 精品 | 精品欧美一区二区三区 | 国产精品高清一区二区三区 | 自拍偷拍小视频 | 国产精品一区二区av | 午夜资源 | 台湾a级理论片在线观看 | www.欧美视频| 91视频在线观看 | 精品毛片 | 91精品国产91| 久久久久久久国产精品 | 成人av免费在线观看 | 日本不卡一区 | 久久岛国| 9191成人精品久久 | 韩国av电影网 | 成年免费视频 | 福利片在线看 |