Python网络编程(http协议,IO多路复用、select内核监听)
前言:
补充昨天HTTP:
- from socket import *
- # 接收请求
- # 查看请求
- # 返回客户端段请求内容
- def handleClient(connfd):
- request = connfd.recv(4096)
- # print("***********")
- # print(request)
- # print("************")
- # 按照行切割请求
- request_lines = request.splitlines()
- for line in request_lines:
- print(line.decode())
- try:
- f = open('index.html')
- except IOError:
- response = "HTTP/1.1 303 Not Found\r\n"
- response += "\r\n" # 空行
- response += '''
- **************************
- Sorry, not found the page.
- **************************
- '''
- else:
- response = "HTTP/1.1 200 OK\r\n"
- response += '\r\n'
- response += f.read()
- finally:
- # 发送给浏览器
- connfd.send(response.encode())
- # 创建套接字,调用handleClient完成功能
- def main():
- # 创建tcp套接字
- sockfd = socket()
- sockfd.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
- sockfd.bind(('0.0.0.0', 8000))
- sockfd.listen()
- while True:
- print("Listen the port 8000...")
- connfd, addr = sockfd.accept()
- # 处理浏览器发来的请求
- handleClient(connfd)
- connfd.close()
- if __name__ == "__main__":
- main()
- from socket import *
- from select import *
- s = socket()
- s.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
- s.bind(('0.0.0.0',8888))
- s.listen(5)
- #创建poll对象
- p = poll()
- #创建地图
- fdmap = {s.fileno():s}
- #添加关注
- p.register(s,POLLIN | POLLERR)
- while True:
- #进行IO监控
- #[(fileno,evnet),...]
- events = p.poll()
- for fd,event in events:
- if fd == s.fileno():
- #从地图中找到fd对应的对象
- c,addr = fdmap[fd].accept()
- print("Connect from",addr)
- #注册新的IO 维护地图
- p.register(c,POLLIN)
- fdmap[c.fileno()] = c
- else:
- data = fdmap[fd].recv(1024)
- if not data:
- p.unregister(fd) #从关注移除
- fdmap[fd].close()
- del fdmap[fd] #从地图删除
- else:
- print(data.decode())
- fdmap[fd].send('收到了'.encode())
- from socket import *
- from select import select
- # 创建套接字
- s = socket()
- # 设置端口重用
- s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
- # 绑定地址
- s.bind(('0.0.0.0', 8888))
- # 设置队列
- s.listen(5)
- # 注册监听套接字
- rlist = [s]
- wlist = []
- xlist = [s]
- while True:
- print("等待IO发生")
- rs, ws, xs = select(rlist, wlist, xlist)
- # 循环遍历rs准备就绪列表
- for r in rs:
- # 如果有新的客户端链接请求
- if r is s:
- # 链接客户端并返回客户端套接字
- connfd, addr = r.accept() # r==s 原套接字
- print("Connect from", addr)
- # 将绑定客户端套接字加入监听列表
- rlist.append(connfd)
- # 表示客户端连接套接字准备就绪
- else:
- # 如果是客户端套接字发送数据 则接收
- data = r.recv(1024)
- if not data: # 如果客户端断开链接
- # 从关注列表移除connfd
- rlist.remove(r)
- r.close() # 关闭套接字
- else:
- print("Receive:", data.decode())
- # 讲客户端套接字放入wlist
- wlist.append(r)
- # wlist列表会直接返回
- # 循环遍历ws准备就绪列表
- for w in ws:
- # 消息回复
- w.send("这是一条回复消息".encode())
- # 删除并取消监听已处理消息
- wlist.remove(w)
- # xs列表:待处理异常
- for x in xs:
- if x is s:
- s.close()

- from socket import *
- # 创建套接字
- sockfd = socket()
- # 发起连接
- sockfd.connect(('127.0.0.1', 8888))
- while True:
- # 消息收发
- msg = input("Msg>>")
- if not msg:
- break
- sockfd.sendall(msg.encode())
- data = sockfd.recv(1024)
- print(data.decode())
- sockfd.close()
- # myserver.py
- # 应用 :
- # select服务端,同时关注客户端连接
- # 客户端发送和终端输入。将客户端发送和终端输入的内容全都写入到一个文件中
- from socket import *
- from select import *
- from sys import stdin
- sock = socket()
- sock.getsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
- sock.bind(("127.0.0.1", 6666))
- sock.listen(5)
- rlist = [sock, stdin]
- wlist = []
- xlist = []
- file = open("selectdemo.txt", "w+b")
- while True:
- rs, ws, xs, = select(rlist, wlist, xlist)
- for r in rs:
- if r == sock:
- connfd, addr = r.accept()
- print("已连接......")
- rlist.append(connfd)
- elif r == stdin:
- data = stdin.readline()
- file.write(data.encode())
- file.flush()
- else:
- data = r.recv(4096)
- if not data:
- rlist.remove(r)
- r.close()
- else:
- file.write(data + "\n".encode())
- file.flush()
- print("已经接收内容并写如select>>>.txt文件内\n 内容:", data.decode())
- r.send("接收成功!".encode())
- file.close()
- from socket import *
- # 创建套接字
- sockfd = socket()
- # 发起连接
- sockfd.connect(('127.0.0.1', 6666))
- while True:
- # 消息收发
- msg = input("Msg>>")
- if not msg:
- break
- sockfd.sendall(msg.encode())
- data = sockfd.recv(1024)
- print(data.decode())
- sockfd.close()

Python网络编程(http协议,IO多路复用、select内核监听)的更多相关文章
- 网络编程socket 结合IO多路复用select; epool机制分别实现单线程并发TCP服务器
select版-TCP服务器 1. select 原理 在多路复用的模型中,比较常用的有select模型和epoll模型.这两个都是系统接口,由操作系统提供.当然,Python的select模块进行了 ...
- python 网络编程 -- Tcp协议
Socket是网络编程的一个抽象概念.通常我们用一个Socket表示“打开了一个网络链接”,而打开一个Socket需要知道目标计算机的IP地址和端口号,再指定协议类型即可. 客户端 大多数连接都是可靠 ...
- python网络编程-TCP协议中的三次握手和四次挥手(图解)
建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 先来看看如何建立连接的. 首先Client端发送连接请求报文,Server段接受连接后回复ACK报文,并为这次连接分配资 ...
- Python网络编程:IO多路复用
io多路复用:可以监听多个文件描述符(socket对象)(文件句柄),一旦文件句柄出现变化,即可感知. sk1 = socket.socket() sk1.bind(('127.0.0.1',8001 ...
- python网络编程——SocketServer/Twisted/paramiko模块
在之前博客C/S架构的网络编程中,IO多路复用是将多个IO操作复用到1个服务端进程中进行处理,即无论有多少个客户端进行连接请求,服务端始终只有1个进程对客户端进行响应,这样的好处是节省了系统开销(se ...
- 第五十五节,IO多路复用select模块加socket模块,伪多线并发
IO多路复用select模块加socket模块,伪多线并发,并不是真正的多线程并发,实际通过循环等待还是一个一个处理的 IO多路复用,lo就是文件或数据的输入输出,IO多路复用就是可以多用户操作 IO ...
- python网络编程——IO多路复用之select
1 IO多路复用的概念 原生socket客户端在与服务端建立连接时,即服务端调用accept方法时是阻塞的,同时服务端和客户端在收发数据(调用recv.send.sendall)时也是阻塞的.原生so ...
- python 网络编程 IO多路复用之epoll
python网络编程——IO多路复用之epoll 1.内核EPOLL模型讲解 此部分参考http://blog.csdn.net/mango_song/article/details/4264 ...
- Python实战之IO多路复用select的详细简单练习
IO多路复用 I/O多路复用指:通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作. select 它通过一个select()系统调用来 ...
随机推荐
- A. Round House_数学问题
A. Round House time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- Poj(1125),Floyd,
题目链接:http://poj.org/problem?id=1125 多源点最短路中的,最长路的,最短路. 看到这里就懵逼了,解释一下,找到一个源点,使得路最短,(遍历源点),路最短怎么求呢? 就是 ...
- sql server 基础
1 .左连接 select a.* ,b.* from student as aleft join hobby as bon a.hobbyid=b.hobbyid 2. 右 连接 select a. ...
- 如何提高mysql的安全性?
1.如果 MySQL 客户端和服务器端的连接需要跨越并通过不可信任的网络,那么需要使用 ssh 隧道来加密该连接的通信.2.使用 set password 语句来修改用户的密码,先“mysql -u ...
- AngularJS 重复HTML元素
data-ng-repeat指令会重复一个HTML元素 <!DOCTYPE html><html><head><meta http-equiv="C ...
- 一篇SSM框架整合友好的文章(三)
###一.SpringMVC理论 它始终是围绕 handler. 数据模型 model. 页面view进行开发的. 运行流程图: 通过mvc配置文件,配置"中央处理器"dispat ...
- 2017年10月26日 git上传文件失败的文件
最近几天因为项目要用git,于是学习了一下git.今天上传项目到码云的时候,却发现总有一些文件夹上传不上去,git 也显示everything is update.找了一圈办法,都没有用,最后突然发现 ...
- Redis高可用
redis高可用只要在于三个方面 主从复制 哨兵机制 集群机制 主从复制 主从复制作用: 1.数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式.2.故障恢复:当主节点出现问题时,可 ...
- 基于Xtrabackup恢复单个innodb表
Preface We all know that Xtrabackup is a backup tool of percona for innodb or Xtradb.It's us ...
- kubernetes基础架构及原理
kubernetes简称“k8s” 其中“8”代表的是“k”和“s”中间的8个字母. k8s是Google公司开发的Borg项目中独立出来的容器编排工具,然后将其捐献给CNCF这个组织,然后发扬光大. ...