东亚银行、岚图汽车带你解锁 AIGC 时代的数字化人才培养各赛道新模式! 了解详情
写点什么

文章:运用 Ruby 纤程进行异步 I/O

  • 2008-10-10
  • 本文字数:630 字

    阅读完需:约 2 分钟

纤程(Fibers)慢慢地进入了Ruby 开发者们的视线中,将作为新的并发原语而广为使用。通过对纤程和非阻塞(或者说异步)I/O 这两种方法的组合,可以解决用户空间线程问 题或者Ruby 1.9 的巨型解释器锁(Giant Interpreter Lock,简称GIL)的问题,这个问题使得Ruby 语言线程每次只能有一个是激活的。

最大的问题要数和使用那些阻塞的系统调用了,尤其是I/O 方面的。阻塞的系统调用,就拿读取来说,直到数据准备好的时候才会返回。在用户态的线程系统中,这 意味着这个进程中的所有线程也都会阻塞。解决方法是将I/O 系统与阻塞I/O 的方式进行解耦。有一种方法是在引发一个阻塞的系统调用以前捕捉它,以一种非 阻塞的方式来处理这个I/O 请求,然后挂起这个纤程,给另外的纤程运行的机会。一旦系统收到这个I/O 请求的回应的话,纤程会再度被调度。

纤程提供了一个好用的并发工具来实现这个概念,而不会让使用者去忍受些什么不愉快。目前,两个程序库都着重于使用纤程实现解决方案。比较新的解决方案是NeverBlock 程序库(Github 代码库包括 NeverBlock NeverBlock PG 支持ActiveRecord 的NeverBlock PG 适配器,以及支持异步操作的MySQLPlus MySQL 适配器)。更加通用的解决方案是建立在诸如Actor 和进程通信等Erlang 的思想之上的,来自Tone Arcieri 的Revactor 程序库。我们对来自NeverBlock 项目的 Mohammad A. Ali 来自 Revactor 项目的 Tone Arcieri 进行了访谈。

详情请参阅文章:运用 Ruby 纤程进行异步 I/O:NeverBlock 和 Revactor

2008-10-10 00:55932
用户头像

发布了 80 篇内容, 共 19.2 次阅读, 收获喜欢 5 次。

关注

评论

发布
暂无评论
发现更多内容

集群限流的两种模式

互联网架构师小马

Java 集群限流

为开发者打造的开源低代码开发平台

力软低代码开发平台

热点参数限流功能的实现与流量效果控制

互联网架构师小马

众多国央企专家齐聚一堂,探索财务共享未来模式

用友BIP

财务共享

科兴未来|第七届“红船杯”嘉兴全球创业创新大赛开启报名

科兴未来News

数字经济 新能源 生物医药 新材料 高端装备

大文件上传功能在标签服务的简单应用和代码实现

袋鼠云数栈

大数据 标签体系 企业号 6 月 PK 榜

积聚产业发展新动能|2023开放原子全球开源峰会OpenAtom OpenHarmony分论坛成功举办

开放原子开源基金会

开源 OpenHarmony 开放原子全球开源峰会 开放原子

科兴未来|第二届集成电路“太湖之芯”创业大赛,报名正式开始

科兴未来News

OpenInfra基金会在亚洲、欧洲正式设立运营中心

说山水

内网IM即时通讯软件WorkPlus,快速连接工作的沟通利器

WorkPlus

膜拜!Alibaba最新发布SprinBoot:进阶原理实战与面试题分析指南

互联网架构师小马

Java spring 微服务 Spring Boot 框架

浅析数智化转型深层次的挑战

用友BIP

数智平台

openEuler 开源汇智赢未来|2023开放原子全球开源峰会OpenAtom openEuler 论坛成功召开

开放原子开源基金会

开源 openEuler 开放原子全球开源峰会 开放原子

软件测试|超好用超简单的Python GUI库——tkinter

霍格沃兹测试开发学社

python 3.5+ GUI

业务与应用同步发展:应用现代化的策略建议

NGINX开源社区

开源赋能 工业铸魂|2023开放原子全球开源峰会开源工业软件分论坛圆满举行

开放原子开源基金会

开源 开放原子全球开源峰会 开源工业软件

透明LED显示屏报价方案

Dylan

方案 屏幕亮度 报价 像素 LED显示屏

GitHub收获70K+Star!阿里巴巴总结的「百亿级别并发设计手册」太香了

互联网架构师小马

Java 系统设计 高并发

【游戏行业部】重回游戏公平,向游戏打金工作室宣战!

网易智企

游戏 反外挂 游戏安全

假如你是CEO,遇到人才瓶颈又该如何破局?数智人力给您答案!

用友BIP

人力资源 数智人力

Sentinel支持异步调用链的实现原理

互联网架构师小马

Java sentinel

数智人力帮您搭建人才梯队,从此挖掘人才不再靠缘分!

用友BIP

数智人力

MaxCompute中如何处理异常字符

阿里云大数据AI技术

大数据 数据处理 企业号 6 月 PK 榜

爆赞!GitHub上首本IntelliJ IDEA操作手册,标星果然百万名不虚传

互联网架构师小马

Java IDEA

与 NGINX 团队直接交流 | 微服务之月火热报名中

NGINX开源社区

nginx 微服务 运维

活动预约!华为云企业快成长大数据技术创新论坛成都站6月16日举行

说山水

HummerRisk 开发手册:Restful Api 使用

HummerCloud

开源 云原生 云安全

集群限流功能是如何实现的?

互联网架构师小马

Java sentinel 集群限流

局域网办公的重要性,如何选择企业IM即时通讯APP?

WorkPlus

软件测试/测试开发丨学习笔记之Python函数

测试人

Python 程序员 软件测试 自动化测试 函数

架构训练营模块3作业——外包学生管理系统的架构文档

Geek_3d7c4d

#架构训练营

文章:运用Ruby纤程进行异步I/O_Ruby_Werner Schuster_InfoQ精选文章