潭州课堂25班:Ph201805201 并发(非阻塞,epoll) 第十课 (课堂笔记)
# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2018/7/12 0012 20:29 import socket
server = socket.socket()
server.setblocking(False) server.bind(('',10000)) # 绑定ip,和端口,
server.listen(5)
con_l = []
while 1:
try:
con,addr = server.accept()
con.setblocking(False)
con_l.append(con)
except Exception:
pass del_l = [con for con in con_l]
for con in con_l:
try:
recv_data = con.recv(1024)
if recv_data:
print(recv_data)
con.send(recv_data)
else:
con.close()
con_l.remove(con)
except Exception:
pass
# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2018/7/13 0013 23:16
import socket,selectors
import tuling epoll_secret = selectors.DefaultSelector()
#根据平台选择最佳的IO多路机制,比如linux就会选择epoll sever = socket.socket()
sever.bind(('',10000))
sever.listen(1000) def read(conn):
try:
rec_data = conn.recv(1024)
# if rec_data: # 在 linux 中
print(rec_data.decode('utf-8'))
se = tuling.Tuling(rec_data.decode('utf-8'))
conn.send(se.encode('utf-8'))
except Exception:
# else:
epoll_secret.unregister(conn) # 如果客户端断开,就取消对应的注册事件 def accept(sever):
conn,addr = sever.accept()
print('客户端地址:', addr)
# 处理事件
epoll_secret.register( conn, selectors.EVENT_READ, read )
# return conn # 注册事件
epoll_secret.register( sever, selectors.EVENT_READ, accept )
# 3 个参数: 监听套接字, 可读, 回调函数
# 事件说明:当监听到有活跃客户端(可读)发生时,运行指定函数 while True:
# 开启事件
# 循环查询客户端事件,把连接的客户端写入列表 ,
events = epoll_secret.select()
# print(events) # # [(SelectorKey(fileobj=<socket.socket fd=608, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 9002)>, fd=608, events=1, data=<function accept at 0x000001A04AEE6A60>), 1)]
# events[0] 中有监听套接字,accept 的函数
for key,m in events:
sock = key.fileobj # 获取 对等连接套接字
callback = key.data # 获取 accept
callback( sock ) # == def accept(ser) 的调用
潭州课堂25班:Ph201805201 并发(非阻塞,epoll) 第十课 (课堂笔记)的更多相关文章
- 潭州课堂25班:Ph201805201 并发(通信) 第十三课 (课堂笔记)
from multiprocessing import Process # 有个 url 列表 ,有5个 url ,一次请求是1秒,5个5秒 # 要求1秒把 url 请求完, a = [] # 在进程 ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第四课 登录注册 (课堂笔记)
index.html 首页 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第三课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第二课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第一课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 第十课 类的定义,属性和方法 (课堂笔记)
类的定义 共同属性,特征,方法者,可分为一类,并以名命之 class Abc: # class 定义类, 后面接类名 ( 规则 首字母大写 ) cls_name = '这个类的名字是Abc' # 在类 ...
- C/S系统实现两数求和(非阻塞+epoll+心跳包检测用户在线状况+滚动日志+配置文件.)
C/S系统实现两数求和 任务要求: 实现配置文件 实现日志滚动 设置非阻塞套接字,EPOLL实现 检测客户端的连接,设置心跳检测 主线程 + 心跳检测线程 + EPOLL的ET模式处理事务线程 注意事 ...
- 潭州课堂25班:Ph201805201 并发(协程) 第十五课 (课堂笔记)
#斐波那契 def fid(n): res = [] indx = 0 a = 0 b = 1 while indx < n : res.append(b) a,b = b,a+b indx + ...
- 潭州课堂25班:Ph201805201 并发(进程,线程) 第十一课 (课堂笔记)
线程,进程,是实现并发的方法, 并行: 在同一时刻,同时运行多个任务,CPU 的数量大于等于任务数量, 并发: 在同一时间间隔内, 同时处理多个任务, 并行是并发. 进程:表示一个正在执行的程序, 操 ...
随机推荐
- freeRTOS中文实用教程1--任务
1.前言 FreeRTOS是小型多任务嵌入式操作系统,硬实时性.本章主要讲述任务相关特性及调度相关的知识. 2. 任务的总体特点 任务的状态 (1)任务有两个状态,运行态和非运行态 (2)任务由非运行 ...
- win10 安装硕正
提示权限不够,解决方法:根据提示路径手动在路径下建立文件夹
- KVM -> 虚拟机在线热添加技术_04
热添加技术 1.KVM在线热添加硬盘
- .net core定时任务
1.HangFire HangFire官网 Hangfire项目实践分享 : 讲解的比较详细 2.Quartz.NET https://www.cnblogs.com/best/p/7658573. ...
- SQL数据库基础知识
- java多线程快速入门(一)
1.什么是进程 比如:QQ.QQ游戏.eclipse都是进程,可以通过任务管理器查看进程 2.进程和线程区别 线程是进程的一部分,一个进程可以包含多个线程,一个线程只能属于一个进程 进程是所有线程的集 ...
- [转] Nginx 配置 SSL 证书 + 搭建 HTTPS 网站教程
一.HTTPS 是什么? 根据维基百科的解释: 超文本传输安全协议(缩写:HTTPS,英语:Hypertext Transfer Protocol Secure)是超文本传输协议和SSL/TLS的组合 ...
- Bitmap在Java中的应用
一.40亿数据排序问题 给定一个最多包含40亿个随机排列的32位整数的顺序文件,找出一个不在文件中的32位整数(在文件中至少缺失这样一个数——为什么?).在具有足够内存的情况下,如何解决该问题?(编程 ...
- Codeforces 327E Axis Walking 状压dp
这题真的有2500分吗... 难以置信... #include<bits/stdc++.h> #define LL long long #define fi first #define s ...
- HDU3306 Another kind of Fibonacci 矩阵
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - HDU3306 题意概括 A0=1,A1=1,AN=X*AN-1+Y*AN-2(N>=2).求SN,SN ...