专业IT网络知识平台,分享IT百科知识、生活百科知识解答!

易企推科技
易企推科技

Twisted是什么

来源:小易整编  作者:小易  发布时间:2023-08-19 01:33
摘要:Twisted是一个事件驱动的网络编程框架,它使用编程语言Python编写,并在MIT协议下开源。Twisted是用Python实现的基于事件驱动的网络引擎框架。Twisted诞生于2000年初,在当时的网络游戏开发者看来,无...

Twisted 是一个事件驱动的网络编程框架,它使用编程语言Python编写,并在MIT协议下开源。

Twisted是什么

Twisted 是用 Python 实现的基于事件驱动的网络引擎框架。Twisted 诞生于 2000 年初,在当时的网络游戏开发者看来,无论他们使用哪种语言,手中都鲜有可兼顾扩展性及跨平台的网络库。Twisted 的作者试图在当时现有的环境下开发游戏,这一步走的非常艰难,他们迫切地需要一个可扩展性高、基于事件驱动、跨平台的网络开发框架,为此他们决定自己实现一个,并从那些之前的游戏和网络应用程序的开发者中学习,汲取他们的经验教训。

Twisted 支持许多常见的传输及应用层协议,包括 TCP、UDP、SSL/TLS、HTTP、IMAP、SSH、IRC 以及 FTP。就像 Python 一样,Twisted 也具有“内置电池”(batteries-included)的特点。Twisted 对于其支持的所有协议都带有客户端和服务器实现,同时附带有基于命令行的工具,使得配置和部署产品级的 Twisted 应用变得非常方便。

为什么需要 Twisted

2000 年时,Twisted 的作者 Glyph 正在开发一个名为 Twisted Reality 的基于文本方式的多人在线游戏。这个游戏采用 Java 开发,里面尽是一堆线程——每个连接就有 3 个线程处理。处理输入的线程会在读操作上阻塞,处理输出的线程将在一些写操作上阻塞,还有一个“逻辑”线程将在等待定时器超时或者事件入队列时休眠。随着玩家们在虚拟世界中移动并交互时,线程出现死锁,缓存被污染,程序中的加锁逻辑几乎从来就没对过——采用多线程使得整个软件变得复杂、漏洞百出而且极难扩展。

为了寻求其他的解决方案,作者发现了 Python,特别是 Python 中用于对流式对象比如 socket 和 pipe 进行多路 I/O 复用的 select 模块(UNIX 规范第 3 版(SUSv3)描述了 select)。那时,Java 并没有提供操作系统的 select 接口或者任何其他的异步 I/O API(针对非阻塞式 I/O 的包 java.nio 已经在 J2SE 1.4 中加入了,2002 年发布)。通过用 Python 中的 select 模块快速搭建起游戏的原型,这迅速降低了程序的复杂度,并且比多线程版本要更加可靠。

Glyph 迅速转向了 Python、select 以及基于事件驱动的编程。他使用 Python 的 select 模块为游戏编写了客户端和服务器。但他想要的还不止于此。从根本上说,他希望能将网络行为转变为对游戏中的对象的方法调用。如果你能在游戏中收取邮件会怎样,就像 Nethack mailer 这种守护进程一样?如果游戏中的每位玩家都拥有一个主页呢?Glyph 发现他需要优秀的 IMAP 以及 HTTP 客户端和服务器的 Python 实现,而这些都要采用 select。

他首先转向了 Medusa,这是一个在 90 年代中期开发的平台,在这里可以采用 Python 中的 asyncore 模块来编写网络服务。asyncore 是一个异步化处理 socket 的模块,在操作系统的 select API 之上构建了一个调度器和回调接口。

这对于 Glyph 来说是个激动人心的发现,但 Medusa 有两个缺点:

这个项目到 2001 年就不再维护了,那正是 glyph 开发 Twisted Reality 的时候。asyncore 只是对 socket 的一个薄封装层,应用程序的编写者仍然需要直接操作 socket。这意味着程序可移植性的担子仍然落在程序员自己身上。此外,那时 asyncore 对 Windows 的支持还有问题,Glyph 希望能在 Windows 上运行一个带有图形用户界面的客户端。

Glyph 需要自己实现一个网络引擎平台,而且他意识到 Twisted Reality 已经打开了问题的大门,这和他的游戏一样有趣。

随着时间的推移,Twisted Reality 这个游戏就演化成了 Twisted 网络引擎平台。它可以做到当时 Python 中已有的网络平台所无法做到的事情:

使用基于事件驱动的编程模型,而不是多线程模型。跨平台:为主流操作系统平台暴露出的事件通知系统提供统一的接口。“内置电池”的能力:提供流行的应用层协议实现,因此 Twisted 马上就可为开发人员所用。符合 RFC 规范,已经通过健壮的测试套件证明了其一致性。能很容易的配合多个网络协议一起使用。可扩展。

Twisted 是一个事件驱动型的网络引擎。由于事件驱动编程模型在 Twisted 的设计哲学中占有重要的地位,因此这里有必要花点时间来回顾一下究竟事件驱动意味着什么。

事件驱动编程是一种编程范式,这里程序的执行流由外部事件来决定。它的特点是包含一个事件循环,当外部事件发生时使用回调机制来触发相应的处理。另外两种常见的编程范式是(单线程)同步以及多线程编程。


本文地址:IT问答频道 https://www.hkm168.com/itwenda/1030947.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


IT问答
小编:小易整编
相关文章相关阅读
  • 某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是cpu的字长,即cpu每次能处理64位二进制数据。字长是cpu的主要技术指标之一,指的是cpu一次能并行处理的二进制位数,字长总是8的整数倍,通常pc机的字长为32位,64位。本教程操作环境:w...

  • c语言是什么意思

    c语言是什么意思

    一:c语言是什么意思C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言,以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低...

  • skype是什么软件

    skype是什么软件

    skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话,它使用全新的p2p【对等】技术将您与其他skype用户相连接。Skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话。Sky...

  • 计算机的三类总线分别是什么?

    计算机的三类总线分别是什么?

    计算机的三类总线分别是:控制总线、地址总线和数据总线。控制总线用于将微处理器控制单元的信号,传送到周边设备;地址总线用来指定在ram之中储存的数据的地址;数据总线用于在cpu与ram之间来回传送需要处理或是需要储存的数据。总线(Bus)是计...

  • 2k屏幕是什么意思

    2k屏幕是什么意思

    2k屏幕是指分辨率能够达到2560*1440的屏幕。2k是一个通用术语,指屏幕或者内容的水平分辨率达约2000像素的分辨率等级;又因“16:9”的比例是高清晰度视频规格的国际标准,所以2k分辨率在视频制作、显示屏等领域常见格式为2560*1...

  • mysql中的不等于符号是什么

    mysql中的不等于符号是什么

    mysql中的不等于符号有两种:“!=”和“”;它们都可用于判断数字、字符串、表达式是否不相等。对于“!=”和“”,如果两侧操作数不相等,返回值为1,否则返回值为0;如果两侧操作数有一个是null,那么返回值也是null。本教程操作环境:w...

  • ipad a1822是什么型号

    ipad a1822是什么型号

    ipada1822是苹果ipad第5代的型号;ipad第5代是苹果公司于2017年03月21日在美国加利福尼亚州发布的平板电脑;该机型采用铝镁合金材质一体成型结构;前端外框为白色或黑色;有银色、金色和深空灰色3种外观颜色。本教程操作环境:...

  • html中浮动是什么

    html中浮动是什么

    在html中,浮动就是让元素可以向左或向右移动,直到它的外边距碰到其父级的内边距或者是上一个元素的外边距,只需要给元素设置“float:left|right|none|inherit”样式即可。本教程操作环境:windows7系统、CSS3...

  • 周排行
  • 月排行
  • 年排行

精彩推荐