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

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>
            国产精品久久久久久av下载红粉| 欧美在线一级va免费观看| 亚洲一区二区精品在线| 伊人激情综合| 亚洲国产日韩欧美在线99| 精品成人免费| 99日韩精品| 亚洲综合色视频| 久久久www免费人成黑人精品| 久久久美女艺术照精彩视频福利播放 | 国产一区二区成人久久免费影院| 国产精品一区免费观看| 极品日韩久久| 中文网丁香综合网| 久久久xxx| 亚洲精品免费网站| 亚洲校园激情| 久久久久一区二区| 欧美色视频在线| 一区二区在线视频播放| 一区二区三区视频在线看| 久久成人一区| 亚洲美女精品一区| 久久激情五月婷婷| 欧美三区美女| 1024成人网色www| 午夜影院日韩| 亚洲破处大片| 久久精品国产一区二区电影 | 国产精品99久久久久久久vr| 久久精品国产96久久久香蕉| 美国十次成人| 先锋影音国产精品| 欧美日韩成人精品| 亚洲精品123区| 久久九九热re6这里有精品| 亚洲伦理网站| 欧美国产第一页| 亚洲第一视频| 久久久久一区二区三区| 午夜欧美精品| 国产欧美日韩视频一区二区三区| aⅴ色国产欧美| 亚洲国产人成综合网站| 久久伊伊香蕉| 国产精品日韩在线| 亚洲专区在线视频| 99精品视频免费观看| 欧美日本中文| 亚洲视频在线一区| 日韩一区二区福利| 欧美日韩大片| 亚洲午夜性刺激影院| 亚洲美女视频| 国产精品v欧美精品v日韩| 亚洲最新合集| 夜夜狂射影院欧美极品| 欧美日韩美女| 亚洲影视九九影院在线观看| 99视频有精品| 国产精品视频久久久| 欧美一区二区三区四区在线观看地址 | 欧美午夜国产| 在线亚洲美日韩| 亚洲美女av网站| 欧美日韩亚洲高清| 中文久久乱码一区二区| 日韩午夜剧场| 欧美亚州一区二区三区| 亚洲婷婷国产精品电影人久久| 亚洲精品一二区| 欧美激情国产高清| 一区二区三区免费看| 亚洲精选一区| 欧美日韩视频在线第一区| 一本色道久久88综合日韩精品| 99精品视频免费全部在线| 欧美午夜免费影院| 亚洲欧美日韩精品久久久| 亚洲男人的天堂在线| 一区二区三区在线视频播放 | 亚洲深夜影院| 亚洲一区二区视频在线| 亚洲精品美女免费| 一区二区三区.www| 一区二区日本视频| 亚洲午夜羞羞片| 国产一区二区三区自拍 | 日韩视频三区| 日韩视频在线免费| 国产一区二区三区黄| 亚洲国产中文字幕在线观看| 欧美日韩一区三区| 麻豆精品一区二区av白丝在线| 免费视频亚洲| 性做久久久久久免费观看欧美 | 亚洲视频免费观看| 黄色国产精品| 99在线精品观看| 在线观看日韩精品| 一本到12不卡视频在线dvd| 国产亚洲欧美日韩精品| 亚洲国产免费| 国产一区二区av| 亚洲麻豆视频| 亚洲国产精品一区二区第一页 | 欧美中文字幕在线| 中日韩在线视频| 久久综合亚州| 久久精品二区| 国产九区一区在线| 亚洲毛片视频| 99精品国产热久久91蜜凸| 欧美在线视频在线播放完整版免费观看 | 老司机免费视频一区二区| 欧美视频日韩视频| 欧美二区在线播放| 国产亚洲欧美日韩一区二区| 中文久久乱码一区二区| 日韩午夜在线| 欧美福利视频在线| 欧美77777| 激情综合色丁香一区二区| 香蕉成人久久| 欧美在线日韩精品| 国产精品久久久久91| 亚洲免费精品| 一区二区三区毛片| 欧美日韩性视频在线| 99精品99久久久久久宅男| 亚洲精品一区二区三区婷婷月| 久久精品在线免费观看| 欧美在线亚洲综合一区| 欧美午夜精品伦理| a4yy欧美一区二区三区| 亚洲一区二区欧美| 国产精品日韩高清| 香蕉久久精品日日躁夜夜躁| 欧美在线黄色| 黄网站免费久久| 噜噜噜在线观看免费视频日韩| 欧美成人在线免费视频| 亚洲日本中文| 欧美日韩日本视频| 在线亚洲欧美视频| 午夜精品久久久久久久99热浪潮| 国产精品日韩精品欧美精品| 欧美一区二区三区视频| 欧美99在线视频观看| 亚洲精品偷拍| 欧美视频四区| 欧美在线看片a免费观看| 麻豆91精品| 亚洲最快最全在线视频| 国产精品夜夜夜一区二区三区尤| 午夜性色一区二区三区免费视频| 麻豆视频一区二区| 亚洲精品欧美专区| 国产精品99免费看| 欧美一级在线视频| 亚洲大片在线观看| 夜夜嗨av色一区二区不卡| 欧美性猛交一区二区三区精品| 亚洲免费小视频| 久久一区二区视频| 一本一本a久久| 国产欧美一区二区三区在线老狼 | 久久久91精品国产一区二区三区| 国产美女精品| 蜜臀av国产精品久久久久| 9久re热视频在线精品| 久久午夜激情| av成人免费在线| 影音欧美亚洲| 欧美视频在线观看 亚洲欧| 午夜影院日韩| 99热在这里有精品免费| 欧美.www| 欧美一级成年大片在线观看| 亚洲激情偷拍| 午夜欧美大片免费观看| 亚洲国产精品久久久久秋霞影院| 午夜精品福利视频| 亚洲国产成人精品久久久国产成人一区| 欧美激情中文不卡| 亚洲中字黄色| 亚洲国产精品高清久久久| 久久国产免费| 亚洲综合成人在线| 99国产精品国产精品久久| 伊人婷婷欧美激情| 国产日韩成人精品| 国产精品vvv| 欧美日本高清一区| 免费亚洲一区| 久久午夜影视| 久久九九国产| 午夜在线视频观看日韩17c| 亚洲小说区图片区| 一区二区三区四区在线|