青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

socketref,再見!高德

https://github.com/adoggie

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  246 Posts :: 4 Stories :: 312 Comments :: 0 Trackbacks

常用鏈接

留言簿(54)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

耗時1天,根據公司應用需求,開發一種簡易的基礎的通信框架,簡化系統其它模塊在網絡通信工作方面的復雜度
簡單測試network.py service 做服務器,network.py client做客戶端,傳送多個消息報文,且能響應sock連接和斷開狀態
考慮到性能和實際項目對線程需求,故都采用單連接單線程模式,預留select多路復用接口,可見: service.selectIn()


  1 # -- coding:utf-8 --
  2 # network.py 
  3 # bin.zhang@sw2us.com 
  4 # 2012.3.8
  5 # revision:  
  6 #
  7 
  8 import socket,traceback,os,os.path,sys,time,struct,base64,gzip,array,threading
  9 import select
 10 
 11 import message
 12 from message import * 
 13 
 14 global_compress_type = COMPRESS_ZLIB
 15     
 16 NETMSG_ERROR_MAGIC = 1
 17 NETMSG_ERROR_SIZE = 2
 18 NETMSG_ERROR_DECOMPRESS =3
 19 NETMSG_ERROR_NOTSUPPORTCOMPRESS = 4
 20 NETMSG_ERROR_MESSAGEUNMARSHALL = 5
 21         
 22 #NetPacketQueue 處理消息分解
 23 class NetPacketQueue:
 24     def __init__(self,conn = None,size= 1024):
 25         self.size = size
 26         self.outs={}
 27         self.ins={}
 28         self.user=None
 29         self.conn = conn
 30         self.bf=''
 31         self.pktlist=[] #解出來的消息
 32         self.mtxptks=threading.Condition()
 33         self.invalid = False 
 34     
 35     def clearPackets(self):
 36         self.mtxptks.acquire()
 37         self.pktlist=[]
 38         self.mtxptks.release()
 39         
 40     def destroy(self):
 41         self.invalid = True
 42         self.mtxptks.acquire()
 43         self.mtxptks.notify()
 44         self.mtxptks.release()
 45 
 46 
 47     # def getMessage(self):
 48         # m = None
 49         # if self.invalid: 
 50             # return m            
 51         # self.mtxptks.acquire()
 52         # if self.pktlist:
 53             # m = self.pktlist[0]
 54             # del self.pktlist[0]
 55         # else:
 56             # self.mtxptks.wait(0.5)
 57             # if self.pktlist:
 58                 # m = self.pktlist[0]
 59                 # del self.pktlist[0]
 60         # self.mtxptks.release()
 61         # return m
 62 
 63     def getMessageList(self):
 64         m =[]        
 65         self.mtxptks.acquire()
 66         m = self.pktlist
 67         self.pktlist=[]
 68         self.mtxptks.release()
 69         return m
 70         
 71     '''
 72         @return: false - 臟數據產生 
 73     '''
 74     def dataQueueIn(self,d):
 75         rc = (True,2)
 76         self.bf+=d
 77         d = self.bf
 78         while True:            
 79             hdrsize = NetMetaPacket.minSize()
 80             #print hdrsize,len(d)
 81             if len(d)<NetMetaPacket.minSize():                
 82                 rc = True,0 #數據不夠,等待
 83                 break
 84             magic,size,compress,encrypt,ver = struct.unpack('!IIBBI',d[:hdrsize])
 85             if magic != NetMetaPacket.magic4:
 86                 return False, NETMSG_ERROR_MAGIC#
 87             if size<=10:
 88                 return False,NETMSG_ERROR_SIZE
 89             if len(d)< size+4:
 90                 rc = True,1 #數據不夠
 91                 break
 92             size-=10
 93             #print size,compress,encrypt,ver
 94             s = d[hdrsize:hdrsize+size]
 95             d = d[hdrsize+size:]
 96             if compress == message.COMPRESS_ZLIB:
 97                 try
 98                     s = zlib.decompress(s)
 99                 except:
100                     return False,NETMSG_ERROR_DECOMPRESS
101             elif compress != message.COMPRESS_NONE:
102                 return False,NETMSG_ERROR_NOTSUPPORTCOMPRESS
103             # restore to NetMetaPacket
104             #MessageBase
105             m = MessageBase.unmarshall(s)
106             if m == None:
107                 return False,NETMSG_ERROR_MESSAGEUNMARSHALL
108             self.mtxptks.acquire()
109             self.pktlist.append(m)
110             self.mtxptks.notify()
111             self.mtxptks.release()
112         self.bf = d
113         return rc
114     
115 class NetConnThread:
116     def __init__(self,conn,proc=None):
117         self.conn = conn
118         if not proc:
119             proc = self.inner
120         self.thread = threading.Thread(target=proc)
121         self.thread.start()
122         
123     def inner(self):
124         while True:        
125             try:
126                 d = self.conn.recvData()
127                 if not d:
128                     self.conn.close()
129                     break            
130                 self.conn.eventDataRecv(d)        
131             except:
132                 self.conn.close()
133                 break
134         self.conn.eventDestroyed()
135         print 'NetConnThread Exiting'
136 
137 class NetConnectionEvent:
138     EVENT_CONNECTED=1
139     EVENT_DATA=2
140     EVENT_DISCONNECTED=3
141     def __init__(self,type,conn,data=None):
142         self.type = type
143         self.conn = conn
144         self.data = data
145         
146 class NetConnection:
147     def __init__(self,sock=None,svc=None,recvfunc=None):
148         self.service =svc
149         self.sock = sock
150         self.delta = None
151         self.recvfunc = recvfunc        
152         self.queue = NetPacketQueue(self)
153     
154     def getService(self):
155         return self.service
156         
157     def getQueue(self):
158         return self.queue
159         
160     def peer(self):
161         pass
162     
163     def connect(self,dest):
164         self.sock = socket.socket()
165         try:            
166             self.sock.connect(dest)
167         except:
168             return False
169         return True
170     '''    
171     def setDataRecvFunc(self,funcRecv):
172         recvfunc = funcRecv
173     '''
174     def eventDataRecv(self,data):
175         r = False        
176         r = self.queue.dataQueueIn(data)
177         if not r:
178             self.close() #數據解碼錯誤,直接關閉連接
179             return 
180         msglist = self.queue.getMessageList()
181         if len(msglist) == 0:
182             return 
183         #直接將數據拋給service接收處理 
184         if self.service:
185             self.service.eventGotMessage( msglist ,self ) #由到這里將消息直接彈射給用戶,需要獨立的或多個線程做支持
186         #如果是無service的connection對象接收數據需要構建一個thread對象,且在另外線程調用 conn.queue.getMessage()獲取消息包
187         if self.recvfunc:
188             evt = NetConnectionEvent(NetConnectionEvent.EVENT_DATA,self,msglist)
189             self.recvfunc(evt)
190         
191     def recvData(self,size=1024):
192         return self.sock.recv(size)
193         
194     def sendData(self,d):
195         pass
196     
197     def sendMessage(self,m):
198         try:
199             d = NetMetaPacket(msg=m,compress=global_compress_type).marshall()
200             self.sock.sendall(d)            
201         except:
202             self.close()
203             #traceback.print_exc()
204             return False
205         return True
206             
207     def close(self):    
208         try:
209             self.sock.close()
210         except:pass
211     
212     def eventDestroyed(self):
213         self.queue.destroy()    
214         if self.service:
215             self.service.eventConnDisconnected(self)
216             
217         if self.recvfunc:
218             evt = NetConnectionEvent(NetConnectionEvent.EVENT_DISCONNECTED,self)
219             self.recvfunc(evt)
220         
221 class NetService:
222     def __init__(self,name,addr):
223         self.name = name
224         self.addr = addr
225         
226         self.condexit = threading.Condition()
227         self.sock = None
228         self.mtxconns = threading.Lock()
229         self.conns=[]
230         
231         
232     def eventConnCreated(self,conn):
233         print 'conn created'
234         self.mtxconns.acquire()
235         self.conns.append(conn)
236         self.mtxconns.release()
237     
238     def eventConnDisconnected(self,conn):
239         print 'conn disconnected'
240         self.mtxconns.acquire()
241         self.conns.remove(conn)
242         self.mtxconns.release()
243     
244     #service模式下接收的消息從這里冒上來
245     # conn - 從哪個連接上接收的數據
246     def eventGotMessage(self,msglist,conn):
247         pass
248     
249     #將連接設置為select模式
250     def selectConnIn(self,conn):
251         pass
252     
253     def getConnections(self):
254         pass
255     
256     def start(self):
257         try:
258             
259             self.sock = socket.socket()
260             print 'lll',self.addr
261             self.sock.bind(self.addr)            
262             self.sock.listen(5)
263             
264             self.thread = threading.Thread(target=self.service_loop)
265             self.thread.start()
266             
267         except:
268             traceback.print_exc()
269             return False
270         
271     def shutdown(self):
272         self.sock.close()
273         self.mtxconns.acquire()
274         for c in self.conns:
275             c.close()
276         self.mtxconns.release()
277     
278     def service_loop(self):
279         print 'service:(%s) thread starting'%self.name
280         while True:
281             fdr = []
282             fdr.append(self.sock)
283             infds,wr,e = select.select(fdr,[],[])
284             if e:
285                 print 'service thread exit'
286                 break
287             for s in infds:
288                 if s == self.sock: #新連接到達 
289                     sock = None
290                     try:
291                         sock,peer = self.sock.accept()    #異常產生表示self.sock被強行關閉                
292                     except
293                         print 'service:(%s) thread exiting'%self.name
294                         return 
295                     conn = NetConnection(sock,self)
296                     sock.delta['conn'= conn                    
297                     self.eventConnCreated(conn)                    
298         ##
299         
300         #self.condexit.nofity()
301         
302         
303 class NetworkServer:
304     def __init__(self,name=''):
305         self.name = name
306         self.services={}
307         setattr(socket.socket,'delta',{})
308         setattr(socket.socket,'conn',None)
309 
310     def createService(self,name,addr,port,servicecls=NetService):
311         svc = serviccls(name,addr,port)
312         self.services[name]=svc
313         return svc
314     
315     def addService(self,serv):
316         self.services[serv.name]=serv
317     
318 
319         
320         
321 def test_packetqueue():
322     q = NetPacketQueue()
323     for n in range(3*10):
324         d = NetMetaPacket(msg=MsgCallReturn(value=[n],bin='A'*(n+1) ),compress=COMPRESS_ZLIB).marshall()
325         q.dataQueueIn(d)
326 '''    
327     while True:
328         m = q.getMessage()
329         if not m:
330             break
331         print m.attrs,m.bin
332 '''
333 
334 class MyService(NetService):
335     def __init__(self,name,addr):
336         NetService.__init__(self,name,addr)
337     
338     def eventConnCreated(self,conn):
339         NetService.eventConnCreated(self,conn)
340         #print 'client connection created!',conn
341         thread = NetConnThread(conn)
342         
343     def eventGotMessage(self,msglist,conn):
344         for m in msglist:
345             print m.attrs,m.bin
346         
347 test_dest = ('localhost',12004)
348 
349 class MyClient:
350     def __init__(self):
351         conn = NetConnection(recvfunc = self.recvEvent)
352         r = conn.connect( test_dest)
353         thread = NetConnThread(conn)
354         for n in range(100):
355             if not conn.sendMessage(MsgCallReturn(value=[n],bin='A'*(n+1) )):
356                 print 'serivce lost  abord!!'
357                 break
358             time.sleep(1)
359             
360     def recvEvent(self,evt):
361         evt.conn == 1
362         if evt.type == NetConnectionEvent.EVENT_DATA:
363             for m in evt.data:
364                 print m.attrs,m.bin
365         if evt.type == NetConnectionEvent.EVENT_DISCONNECTED:
366             print 'connection lost!'
367             
368 def test_service():
369     server = NetworkServer('test-server')
370     svc =MyService('fileserver',test_dest)
371     #svc = server.createService("filesync-server",'localhost',12001,MyService)
372     server.addService(svc)
373     svc.start()
374     #time.sleep(5)
375     #svc.shutdown()
376 
377 def test_client():
378     MyClient()
379     
380 if __name__=='__main__':
381     #test_packetqueue()
382     p = sys.argv[1]
383     if p=='client':
384         test_client()
385         sys.exit(0)
386     if p=='service':
387         test_service()
388         
389     time.sleep(100)
posted on 2012-03-08 23:12 放屁阿狗 閱讀(2137) 評論(0)  編輯 收藏 引用 所屬分類: OpenSource開源工程perl/python/php/lua/tclWebGisWebService
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜欧美精品| 亚洲性视频网站| 欧美日韩国产在线一区| 亚洲精品视频免费在线观看| 一本色道久久综合亚洲精品高清| 欧美激情影院| 久久精品日产第一区二区| 欧美wwwwww| 午夜精品视频在线观看| 在线观看日韩一区| 国产精品黄视频| 欧美成人蜜桃| 一区二区精品在线| 欧美成人精品在线| 在线视频日韩精品| 亚洲美女黄色| 欧美激情一区在线| 久热精品视频在线观看一区| 美女日韩欧美| 亚洲精品国久久99热| 久久亚洲精品欧美| 亚洲国产日韩一区二区| 国产欧美日韩一级| 欧美极品欧美精品欧美视频| 亚洲国产一区二区三区在线播 | 欧美h视频在线| 亚洲激情成人网| 伊人影院久久| 国产综合自拍| 国产一区二区三区四区| 国产精品尤物福利片在线观看| 中文国产成人精品| 亚洲激情国产精品| 国产一区二区久久精品| 欧美精品日韩三级| 久久久欧美一区二区| 亚洲一区自拍| 日韩西西人体444www| 亚洲电影激情视频网站| 美女诱惑一区| 欧美不卡在线| 欧美在线视频一区二区三区| 羞羞漫画18久久大片| 夜夜嗨av一区二区三区中文字幕| 亚洲黄色免费电影| 亚洲精品三级| 亚洲视频日本| 欧美一区二区三区视频免费| 亚洲尤物在线| 久久精品亚洲热| 另类图片国产| 亚洲品质自拍| 中国成人在线视频| 亚洲欧美综合精品久久成人| 久久成人资源| 欧美精彩视频一区二区三区| 亚洲三级网站| 99视频在线观看一区三区| 9国产精品视频| 99在线视频精品| 久久激五月天综合精品| 久久久噜噜噜久久久| 欧美另类综合| 国产视频不卡| 亚洲人成7777| 香蕉国产精品偷在线观看不卡| 性欧美xxxx大乳国产app| 久久资源av| 亚洲高清av在线| 欧美一区二区三区视频| 欧美激情va永久在线播放| 亚洲成人在线免费| 午夜精品久久久久久99热软件| 9l国产精品久久久久麻豆| 亚洲已满18点击进入久久| 久久久91精品| 国产精品捆绑调教| 亚洲精品乱码久久久久久日本蜜臀 | 欧美一区二区黄| 欧美在线播放视频| 亚洲激情欧美| 国产精品私房写真福利视频| 1024日韩| 久久人体大胆视频| 亚洲四色影视在线观看| 欧美激情精品久久久久久免费印度 | 一区二区电影免费观看| 久久综合九色99| 国产亚洲欧美另类中文| 亚洲欧美日韩精品在线| 欧美成人精品三级在线观看| 亚洲综合日韩在线| 欧美日韩播放| 亚洲人成网站精品片在线观看| 亚洲免费在线播放| 亚洲精品日本| 欧美精品七区| 亚洲国产91| 久久手机免费观看| 午夜精品久久久久久99热软件 | 久久久久久久一区二区三区| 国产偷国产偷精品高清尤物| 亚洲视频高清| 99视频热这里只有精品免费| 欧美日韩亚洲综合一区| 亚洲国产福利在线| 欧美国产一区视频在线观看| 久久人人爽人人| 国产精品视频九色porn| 狠狠色综合网站久久久久久久| 亚洲欧美激情在线视频| 一本色道久久精品| 中文在线资源观看网站视频免费不卡 | 亚洲精品婷婷| 欧美激情按摩| 欧美激情a∨在线视频播放| 亚洲黄色影片| 亚洲国产精品va在看黑人| 久久综合色8888| 亚洲国内高清视频| 亚洲精品国产精品国自产观看浪潮| 久久精品一二三区| 在线日韩电影| 91久久夜色精品国产网站| 国产一区二区电影在线观看| 久久久久久久999| 久久se精品一区精品二区| 海角社区69精品视频| 伊人伊人伊人久久| 亚洲美女毛片| 国内精品视频在线观看| 久久一区欧美| 欧美日韩精品欧美日韩精品 | 一区二区三区欧美视频| 欧美日本成人| 欧美日韩成人在线观看| 亚洲最新色图| 亚洲欧美日韩综合| 亚洲国产成人一区| 亚洲人精品午夜| 欧美天堂亚洲电影院在线观看| 久久国产日韩欧美| 新狼窝色av性久久久久久| 国产主播精品在线| 欧美成人日韩| 欧美日韩国产精品专区| 久久久欧美精品sm网站| 欧美日韩精品一区视频 | 夜夜嗨一区二区| 亚洲一区二区三区精品视频 | 国产精品免费一区二区三区在线观看| 亚洲国产一区二区三区高清| 99爱精品视频| 国产精品久久久久久久7电影| 亚洲在线1234| 久久精品国产清高在天天线| 在线成人免费观看| 欧美肥婆bbw| 日韩一级大片| 久久久久久久久久久久久女国产乱| 樱桃成人精品视频在线播放| 欧美精品在线视频| 午夜精品久久久久久久久| 久久综合激情| aa日韩免费精品视频一| 国产精品日韩欧美综合| 久久婷婷色综合| 在线一区观看| 老司机免费视频久久 | 欧美成人性网| 亚洲午夜精品一区二区| 国产综合久久久久久鬼色| 欧美mv日韩mv国产网站| 亚洲一区二区三区777| 免费不卡在线视频| 亚洲欧美在线一区| 91久久精品美女| 欧美三级黄美女| 亚洲午夜久久久久久尤物| 久久一区中文字幕| 亚洲综合三区| 亚洲欧洲日本国产| 国产日韩欧美视频在线| 欧美精品一区二区三区久久久竹菊 | 欧美日韩性生活视频| 久久国产一二区| 在线综合亚洲欧美在线视频| 欧美aⅴ99久久黑人专区| 性久久久久久久久| 一本色道久久综合亚洲精品高清| 国内精品模特av私拍在线观看| 国产精品va在线播放我和闺蜜| 噜噜噜躁狠狠躁狠狠精品视频 | 久久久久久久成人| 亚洲视频中文| 亚洲精品三级| 91久久久久久久久| 女人色偷偷aa久久天堂| 久久精品噜噜噜成人av农村| 亚洲你懂的在线视频|