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

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/tclWebGis 、WebService
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美性生交xxxxx久久久| 在线中文字幕日韩| 鲁大师影院一区二区三区| 亚洲国产激情| 欧美一区二区观看视频| 欧美日韩成人综合天天影院| 影音先锋成人资源站| 亚洲女性喷水在线观看一区| 亚洲国产cao| 久久久精品国产免大香伊| 国产精品手机在线| 亚洲一二三级电影| 日韩视频在线免费| 欧美大片在线观看| 亚洲久久在线| 亚洲日本免费| 欧美大片免费| 99视频精品免费观看| 亚洲国产片色| 欧美国产一区二区| 一本色道久久综合精品竹菊| 亚洲第一精品在线| 欧美激情一区二区三区在线视频| 亚洲缚视频在线观看| 免费日韩一区二区| 欧美成人免费在线视频| 亚洲欧洲视频在线| 欧美激情一区二区三区 | 欧美成人一品| 亚洲国产一区二区三区a毛片| 久热精品视频在线| 亚洲欧洲av一区二区| 日韩视频在线免费观看| 国产精品久久久久久久第一福利 | 韩国视频理论视频久久| 伊人久久大香线| 欧美成人首页| 欧美激情精品久久久六区热门 | 国产精品久久久久婷婷| 欧美一二三视频| 久久精品国产一区二区三区免费看| 激情自拍一区| 亚洲精品人人| 国产精品久久久久久久午夜片| 欧美一级艳片视频免费观看| 午夜精品久久久久久久99黑人| 亚洲电影第三页| 亚洲经典在线| 亚洲中字在线| 1769国产精品| av不卡在线观看| 国产日韩综合一区二区性色av| 免费高清在线一区| 欧美特黄一区| 免费在线欧美视频| 国产精品乱码一区二区三区| 老司机午夜精品视频| 欧美电影免费观看高清| 欧美自拍偷拍午夜视频| 美女露胸一区二区三区| 午夜欧美精品久久久久久久| 欧美成人精品影院| 久久精品免费看| 欧美无乱码久久久免费午夜一区 | 一区二区高清在线观看| 在线观看一区欧美| 亚洲婷婷综合久久一本伊一区| 亚洲大胆人体在线| 亚洲欧美文学| 亚洲免费影视第一页| 久久久久久9999| 欧美一区二区三区免费看| 亚洲国产精彩中文乱码av在线播放| 欧美天堂在线观看| 欧美激情四色 | 欧美有码在线观看视频| 欧美成人午夜激情视频| 久久久久久久久久码影片| 欧美精品久久天天躁| 久久综合色88| 国产欧美在线播放| 亚洲国产精品t66y| 国产亚洲精品久久飘花| 亚洲精品在线观看免费| 久久av免费一区| 国产精品看片你懂得| 欧美国产极速在线| 国产精品久久久久aaaa九色| 亚洲电影免费观看高清完整版| 久久在线视频| 亚洲欧美日韩国产| 欧美国产视频在线| 欧美在线三区| 国产午夜精品全部视频播放| 国产精品天天看| 久久九九国产精品| 久久另类ts人妖一区二区| 国产精品狼人久久影院观看方式| 日韩一区二区精品| 欧美一区永久视频免费观看| 欧美成年人视频网站| 日韩视频一区二区三区在线播放| 欧美电影在线播放| 午夜精品亚洲一区二区三区嫩草| 美女免费视频一区| 老司机午夜精品视频在线观看| 欧美色一级片| 亚洲视频国产视频| 久久亚洲欧洲| 久久最新视频| 国产欧美精品xxxx另类| 亚洲视频中文字幕| 在线天堂一区av电影| 欧美午夜不卡| 99在线精品观看| 午夜精品久久久久久久久久久久 | 中日韩高清电影网| 国产精品99久久久久久白浆小说 | 国产精品va在线播放我和闺蜜| 欧美激情1区2区3区| 亚洲精品乱码| 免费精品视频| 欧美黄色一区二区| 亚洲精品一区二区三区樱花| 欧美va亚洲va日韩∨a综合色| 老司机午夜免费精品视频 | 蜜桃精品一区二区三区| 亚洲人午夜精品免费| 亚洲综合色在线| 国产精品乱人伦中文| 久久国产精品久久国产精品| 久久xxxx精品视频| 亚洲破处大片| 欧美日韩 国产精品| 亚洲一区二区在| 亚洲国产成人久久| 欧美精品一区二区高清在线观看| 欧美一级片在线播放| 亚洲一区3d动漫同人无遮挡| 久久久蜜桃精品| 极品尤物av久久免费看 | 久久激情五月婷婷| 亚洲福利精品| 亚洲成人影音| 亚洲国产专区| avtt综合网| 国产精品久久久久久五月尺| 亚洲精品一区二区三区福利| 久久久久久婷| 久久一区视频| 99热在这里有精品免费| 午夜精品区一区二区三| 国产欧美一二三区| 久久综合亚洲社区| 浪潮色综合久久天堂| 国产一区清纯| 欧美国产另类| 欧美一区二区三区免费看| 亚洲人精品午夜| 亚洲精品在线看| 国产亚洲精品高潮| 欧美一级在线亚洲天堂| 久久综合国产精品| 欧美一乱一性一交一视频| 欧美天堂亚洲电影院在线播放| 亚洲视频在线观看视频| 美女图片一区二区| 国产精品推荐精品| 欧美日韩久久精品| 欧美国产日本| 性色av香蕉一区二区| 国产精品99久久久久久久久久久久| 久久久www成人免费毛片麻豆| 亚洲欧美成人精品| 亚洲免费在线看| 亚洲福利小视频| 亚洲女同性videos| 国产精品久久久一区麻豆最新章节 | 亚洲国产免费看| 亚洲欧美日韩精品久久亚洲区| 亚洲日产国产精品| 欧美精品v日韩精品v韩国精品v| 欧美专区福利在线| 午夜精品偷拍| 夜夜嗨av一区二区三区网页| 亚洲精品视频免费| 久久漫画官网| 老牛嫩草一区二区三区日本 | 国产精品一香蕉国产线看观看| 免费成人黄色| 欧美激情综合五月色丁香小说| 99re热这里只有精品免费视频| 亚洲国产裸拍裸体视频在线观看乱了中文 | 麻豆成人在线观看| 久久久久久久综合狠狠综合| 亚洲资源在线观看| 亚洲欧美日韩国产中文在线| 亚洲精品免费看| 一区二区三区|亚洲午夜| 亚洲理论在线|