苹果开源Swift底层非阻塞I/O框架SwiftNIO



  • 本篇为转载,原文可见:链接

    在近日举行的try! Swift东京大会上,苹果宣布了SwiftNIO项目,这是一个用Swift编写的、类似Netty的非阻塞、跨平台I/O框架。

    SwiftNIO是一个为开发高性能服务器和客户端而设计的事件驱动的异步网络框架。目前,该框架在macOS (10.12+)和Linux(Ubuntu 14.04)上进行开发和测试。据苹果介绍:

    SwiftNIO是一个跨平台的、事件驱动的异步网络框架,用于开发可维护的高性能协议服务器&客户端。

    SwiftNIO旨在成为一个构建网络应用程序和框架的底层工具,致力于提供低开销的I/O原语和协议实现。因此,通常可以将SwiftNIO视为一个构造块,用于构建供应用程序使用的高层网络通信框架,或者是供有苛刻要求的应用程序直接使用的高性能框架。通过这种方法,针对大多数网络协议的支持在源码树外被实现出来。按照苹果SwiftNIO工程师Cory Benfield的说法,虽然HTTP/1.1协议的支持在源码树内,但TLS支持、Websocket和HTTP/2支持在源码树外。

    EventLoop是SwiftNIO提供的一个基本抽象。该对象会等待事件,并在事件发生时触发某个回调方法。在理想情况下,会有一个或者两个核心事件循环。为了在事件循环之间分配负载,可以使用EventLoopGroup。在EventLoop之上是Channel和ChannelPipeline。它们提供了一种友好的方式,可以在与特定文件描述符关联的事件到来时发送通知,并调度处理。ChannelHandler提供了管道顺序执行事件处理的步骤。所有的处理器都是在同一个线程中执行,不需要同步,实现起来更简单。这也意味着处理器不能阻塞。SwiftNIO提供的最高层抽象是Bootstrap,简化特定场景的通道创建,如ServerBootstrap、ClientBootstrap、DatagramBootstrap。要了解所有细节,请查阅官方文档

    在Package.swift中添加以下依赖项可以把SwiftNIO包含到自己的项目中:

    dependencies: [
        .package(url: "https://github.com/apple/swift-nio.git", from: "1.0.0")
    ]
    

    此外,SwiftNIO提供了两个示例NIOChat和NIOEcho,说明该框架的使用方法。


Log in to reply