python-twisted系列(1)
前言:
这不是一个入门教程。而是知识点的梳理。
开胃图:
这是一个TCP server的“交互图”。

reactor
它是Twisted事件处理的核心。包括一些处理网络通讯,线程和事件分派的接口。
一旦调用了其run方法,reactor就会一直监听事件,直到被终止(调用stop/crash,或者ctrl+c)
这个类比较重要。重要方法:
| 接口 | 方法 | 说明 |
| IReactorCore | resolve | 返回一个deffered对象用于解析主机名 |
| run | 触发'startup'系统事件,修改reactor的状态为'running',然后运行主事件循环(直到调用stop或者crash) | |
| stop | 触发'shutdown'系统事件,修改reactor状态为'stopped',并使得reactor.run()退出。 | |
| crash | 立即停止主事件循环而不出发任何事件。可能会丢数据。这个方式比较粗鲁。 | |
| iterate | 运行main loop的i/o轮询函数一会儿。(使用小心) | |
| fireSystemEvent | 触发系统事件。比较常见的有'startup','shutdown','persist' | |
| addSystemEventTrigger | 添加系统事件的处理函数。 | |
| removeSystemEventTrigger | 移除系统时间的处理函数。参数是上面函数的返回值。 | |
| callWhenRunning | reactor运行时调用某个函数。 | |
| IReactorTCP | listenTCP | 将某个协议的factory实例绑定到某个端口 |
| connectTCP | 连接TCP客户端 | |
| IReactorSSL | listenSSL | 将某个协议的factory实例绑定到某个TCP/IP端口,使用ssl链接。 |
| connectSSL | 将客户端协议连接到远程的SSL套接字 | |
| IReactorUDP | listenUDP | 将给定的报文协议连接到指定的UDP端口。 |
| IReactorSocket | adoptStreamPort | 将已存在的处于监听状态的SOCK_STREAM类型的套接字添加到reactor中以监控新的连接然后接受并处理他们。 |
| adoptStreamConnection | 将已经存在的连接上了的SOCK_STREAM类型的套接字添加到reactor中以检测数据。 | |
| adoptDatagramPort | 将已存在的处于监听状态的SOCK_DGRAM类型的套接字添加到reactor中以监控来为读写做好准备。 |
Factory
切确的说,它取名不太好,应该叫做FactoryOfProtocals,即协议工厂(也就是工厂模式),用来产生协议实例的。
Factory并不知道连接,它可能绑定多个host的多个端口。通常用来做数据的获取/保存等操作。
重要方法:
| 名称 | 备注 | |
| 属性 | protocal | 类。具体的协议类,定义了这个就不用重写buildProtocal方法了。 |
| 方法 | doStart | 确保startFactory被调用。用户不应该调用!! |
| doStop | 确保stopFactory被调用。用户不应该调用!! | |
| startFactory | 在监听端口或者Connector之前会被调用。仅被调用一次,哪怕工厂绑定到多个端口。因此适于做一些用户自定义的事情,比如链接数据库,打开文件等等。 | |
| stopFactory | 在所有端口/Connector结束监听之前会被调用。在这里做上面的擦屁股的事情,比如关闭数据库连接,关闭文件等等。 | |
| buildProtocol | 创建协议的实例。 |
Protocal
定义:Twisted的Protocol用异步的方式处理数据。当网络事件到达时,protocol会调用其方法来响应这些事件。每一个连接都会有一个Protocol与之对应。
命名空间:twisted.internet.protocol.Protocol
父类:BaseProtocol
| 名称 | 备注 | |
| 方法 | makeConnection | 为指定的server的transport对象产生连接。 |
| connectionMade | 当连接产生时被调用的方法。 |
| 名称 | 备注 | |
| 方法 | dataReceived | 收到数据时会被调用的方法 |
| connectionLost | 连接关闭时会被调用的方法 |
| 名称 | 备注 | |
| 属性 | delimiter | 行的结束符。默认为'\r\n'。 |
| MAX_LENGTH | 行的最大字符数,默认为16384。 | |
| 方法 | clearLineBuffer | 清除缓存数据。 |
| dataReceived | ||
| setLineMode | 设置接收器的行的模式。 | |
| setRawMode | 设置接收器的原始模式。之后接收的数据将被发给rawDataReceived函数而不是lineReceived。 | |
| rawDataReceived | 原始数据接收处理函数。 | |
| lineReceived | 按行发送的数据的处理 函数。 | |
| sendLine | 向连接的另外一端发送一行数据。 | |
| lineLengthExceeded | 行的最大字符数达到时的处理函数。 | |
|
继承方法 |
logPrefix | |
| connectionLost | 连接断开时的处理函数。 | |
| makeConnection | 为指定的server的transport对象产生连接。 | |
| connectionMade | 当连接产生时被调用的方法。 | |
| pauseProducing | ||
| resumeProducing | ||
| stopProducing |
、
默认实现了的协议:
amp
socks- v4
ftp
sip
postfix
telnet
转载请注明来自:http://www.cnblogs.com/Tommy-Yu/p/4092383.html,谢谢!
python-twisted系列(1)的更多相关文章
- Python Twisted系列教程3:初步认识Twisted
作者:dave@http://krondo.com/our-eye-beams-begin-to-twist/ 译者:杨晓伟(采用意译) 可以从这里从头开始阅读这个系列. 用twisted的方式实现前 ...
- Python Twisted系列教程1:Twisted理论基础
作者:dave@http://krondo.com/in-which-we-begin-at-the-beginning/ 译者:杨晓伟(采用意译) 前言: 最近有人在Twisted邮件列表中提出诸 ...
- Python Twisted系列教程21: Twisted和Haskell
作者:dave@http://krondo.com/twisted-and-haskell/ 译者: Cheng Luo 你可以从”第一部分 Twist理论基础“开始阅读:也可以从”Twisted ...
- Python Twisted系列教程20: Twisted和Erlang
作者:dave@http://krondo.com/twisted-and-erlang/ 译者: Cheng Luo 你可以从”第一部分 Twist理论基础“开始阅读:也可以从”Twisted 入 ...
- Python Twisted系列教程17:造”回调”的另一种方法
作者:dave@http://krondo.com/just-another-way-to-spell-callback/ 译者: Cheng Luo 你可以从”第一部分 Twist理论基础“开始阅 ...
- Python Twisted系列教程15:测试诗歌
作者:dave@http://krondo.com/tested-poetry/ 译者: Cheng Luo 你可以从”第一部分 Twist理论基础“开始阅读:也可以从”Twisted 入门!“浏览 ...
- Python Twisted系列教程12:改进诗歌下载服务器
作者:dave@http://krondo.com/a-poetry-transformation-server/ 译者:杨晓伟(采用意译) 你可以从这里从头阅读这个系列. 新的服务器实现 这里我们 ...
- Python Twisted系列教程9:第二个小插曲,Deferred
作者:dave@http://krondo.com/a-second-interlude-deferred/ 译者:杨晓伟(采用意译) 可以从这里从头来阅读这个系列 更多关于回调的知识 稍微停下来再思 ...
- Python Twisted系列教程8:使用Deferred的诗歌下载客户端
作者:dave@http://krondo.com/deferred-poetry/ 译者:杨晓伟(采用意译) 可以从这里从头开始阅读这个系列. 客户端4.0 我们已经对deferreds有些理解了 ...
- Python Twisted系列教程7:小插曲,Deferred
作者:dave@http://krondo.com/an-interlude-deferred/ 译者:杨晓伟(采用意译) 你可以从这里从头开始阅读这个系列 回调函数的后序发展 在第六部分我们认识这 ...
随机推荐
- 在eclipse中安装插件
1.在Eclipse中菜单help选项中选择install new software选项, 2.在work with 栏中输入 http://download.eclipse.org/releases ...
- 软工实践练习——使用git进行代码管理心得
一.在Github上注册账户.其中创建organization在小组成员的账户上创建,并在其账户上创建了小组的版本库.在创建organization的过程中,参考了助教提供的博客:http://sef ...
- Microsoft Office下载地址
文件名: cn_office_professional_plus_2016_x86_x64_dvd_6969182.iso 语言: Chinese – Simplified 文件大小:2.41 GB ...
- iOS边练边学--iOS中的(ARC下)单粒模式(GCD实现)
一.ARC中实现单粒模式 在.m 保留一个全局的static的实例 static id _名称; 重写allocWithZone:方法,在这里创建唯一的实例 提供一个类方法让外界访问唯一的实例 实现c ...
- Eclipse-将svn上的项目转化成相应的项目
这里假设svn上的项目为maven项目 首先从svn检出项目 其中项目名称code可自己定义更改新的名称 从svn检出的项目结构 然后将项目转化成相关的项目 转换加载中 加载/下载 maven相关内容 ...
- Java-对象池
对象池使用的基本思路是:将用过的对象保存起来,等下一次需要这种对象的时候,再拿出来重复使用,从而在一定程度上减少频繁创建对象所造成的开销. 并非所有对象都适合拿来池化――因为维护对象池也要造成一定开销 ...
- 15.Android中LinearLayout布局一些小记录
在App中,我们经常看到布局中会有分割线,直接上代码: <?xml version="1.0" encoding="utf-8"?> <Lin ...
- 求第N数大问题
问题: InputThe first line of input contains a single integer P, (1 ≤ P ≤ 1000), which is the number of ...
- 旅行(Dijkstra)问题
问题:输入: 输入数据有多组,每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个,草儿想去的地方有D个: 接着有T行,每行有三个整数a,b,time,表示a,b城市之间的车 ...
- TYVJ P1403 [NOIP2010]关押罪犯
TYVJ的编译器总是要搞点岔子出来,上次是double必须用f输出而不能用lf,这次又不知道为何CE 于是去了洛谷P1525测试,AC 题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1 ...