[Python]Socket高级 -- select I/O复用模型(二)
2013-04-23 17:36
525 查看
代码:
客户端:
#!/usr/bin/env python
#coding:utf8
#python2.73 lession7_1_s.py
"""
这是一个多客户端 用来测试
有5个用户 7个消息 一共发送35次
"""
import socket
from time import sleep
msg = ['cs111','cs222','cs333','cs444','cs555','cs666','cs777']
ss = [] #客户端集合
saddr = ('localhost',30001)
for i in range(5):
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
ss.append(s)
for s in ss:
s.connect(saddr)
counts = 0
for m in msg:
for s in ss:
#向服务端发送信息
s.send("client num: %s meg: %s"%(counts,m))
counts+=1
for s in ss:
#从服务端获得返回信息
data = s.recv(1024)
print "%s echo %s"%(s.getpeername(),data)
if not data:
s.close()
服务端:
#!/usr/bin/env python
#coding:utf8
#python2.73 lession7_1_s.py
import socket
import select
import Queue
saddr = ('localhost',30001)
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sock.setblocking(False) #设置socket是非阻塞的
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind(saddr)#绑定地址
sock.listen(10)
#conn,addr = s.accept()
rlists = [sock] #select参数 可写状态集合
wlists = [] #select参数 可读状态集合
msg_que = {}
timeout = 20
#print 'connented with addr:',addr
while rlists:
rs,ws,es = select.select(rlists, wlists, rlists, timeout)
if not (rs or ws or es):
print 'timeout...'
continue
#大体思路就是对所有的返回组进行循环 查看状态作出动作
for s in rs:
if s is sock: #是否是服务端的sock
conn,addr = s.accept()
print 'connect by',addr
conn.setblocking(False)
rlists.append(conn)
msg_que[conn] = Queue.Queue()
else: #客户段的sock接受数据
data = s.recv(1024)
if data:
print data
msg_que[s].put(data)
if s not in wlists:
wlists.append(s)
else:
if s in wlists:
wlists.remove(s)
rlists.remove(s)
s.close()
del msg_que[s]
for s in ws:
try:
msg = msg_que[s].get_nowait()
except Queue.Empty:
print 'msg empty'
wlists.remove(s)
else:
s.send(msg)
for s in es:
print 'except ',s.getpeername()
if s in rlists:
rlists.remove(s)
if s in wlists:
wlists.remove(s)
s.close()
del msg_que[s]
客户端:
#!/usr/bin/env python
#coding:utf8
#python2.73 lession7_1_s.py
"""
这是一个多客户端 用来测试
有5个用户 7个消息 一共发送35次
"""
import socket
from time import sleep
msg = ['cs111','cs222','cs333','cs444','cs555','cs666','cs777']
ss = [] #客户端集合
saddr = ('localhost',30001)
for i in range(5):
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
ss.append(s)
for s in ss:
s.connect(saddr)
counts = 0
for m in msg:
for s in ss:
#向服务端发送信息
s.send("client num: %s meg: %s"%(counts,m))
counts+=1
for s in ss:
#从服务端获得返回信息
data = s.recv(1024)
print "%s echo %s"%(s.getpeername(),data)
if not data:
s.close()
服务端:
#!/usr/bin/env python
#coding:utf8
#python2.73 lession7_1_s.py
import socket
import select
import Queue
saddr = ('localhost',30001)
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sock.setblocking(False) #设置socket是非阻塞的
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind(saddr)#绑定地址
sock.listen(10)
#conn,addr = s.accept()
rlists = [sock] #select参数 可写状态集合
wlists = [] #select参数 可读状态集合
msg_que = {}
timeout = 20
#print 'connented with addr:',addr
while rlists:
rs,ws,es = select.select(rlists, wlists, rlists, timeout)
if not (rs or ws or es):
print 'timeout...'
continue
#大体思路就是对所有的返回组进行循环 查看状态作出动作
for s in rs:
if s is sock: #是否是服务端的sock
conn,addr = s.accept()
print 'connect by',addr
conn.setblocking(False)
rlists.append(conn)
msg_que[conn] = Queue.Queue()
else: #客户段的sock接受数据
data = s.recv(1024)
if data:
print data
msg_que[s].put(data)
if s not in wlists:
wlists.append(s)
else:
if s in wlists:
wlists.remove(s)
rlists.remove(s)
s.close()
del msg_que[s]
for s in ws:
try:
msg = msg_que[s].get_nowait()
except Queue.Empty:
print 'msg empty'
wlists.remove(s)
else:
s.send(msg)
for s in es:
print 'except ',s.getpeername()
if s in rlists:
rlists.remove(s)
if s in wlists:
wlists.remove(s)
s.close()
del msg_que[s]
相关文章推荐
- 状态集合[Python]Socket高级 -- select I/O复用模型(二)
- 参数文件描述符[Python]Socket高级 -- select I/O复用模型(一)
- [Python]Socket高级 -- select I/O复用模型(一)
- select的socket server多路复用模型
- Linux高级编程复习 第十一章 select TCP编程模型_Socket选项_OOB_HTTP协议
- 深入研究socket编程(6)——高级I/O复用(select、poll 、 epoll)
- Unix Socket编程--I/O复用之select模型
- Linux下的socket编程实践(七) I/O多路复用技术之select模型
- Unix Socket编程--I/O复用之select模型
- python socket Select模型
- python实现select和epoll模型socket网络编程 推荐
- Linux下的socket编程实践(七) I/O多路复用技术之select模型
- UNIX环境高级编程学习之第十六章网络IPC:套接字 - 非阻塞的Socket通信Select模型(多路复用), 实用Socket通信模板。
- python实现select和epoll模型socket网络编程
- Unix Socket编程--I/O复用之select模型
- socket的select模型【摘】
- I/O复用-select模型
- Python网络编程中的select 和 poll I/O复用的简单使用
- Python select实现socket并发
- 在python中编写socket服务端模块(一):使用select