Project Icon

libxev

高性能跨平台事件循环库

libxev是一个用Zig语言开发的跨平台事件循环库,为非阻塞IO、定时器、信号和事件提供统一抽象。支持macOS、Linux、WebAssembly等平台,并提供C语言兼容API。采用Proactor模式设计,无运行时内存分配,同时支持高级和低级API。虽然仍处于alpha阶段,但功能已较为丰富,适合需要轻量级事件循环的项目使用。

libxev

libxev 是一个跨平台的事件循环库。它为非阻塞 IO、定时器、信号、事件等提供了统一的事件循环抽象,可在 macOS、Windows、Linux 和 WebAssembly(浏览器和 WASI)上运行。该库使用 Zig 编写,但导出了兼容 C 的 API(这进一步使其与任何可与 C API 通信的语言兼容)。

项目状态:🐲 不稳定,alpha 质量。 在多个平台上的功能列表相当不错,但仍有许多缺失的功能。该项目尚未在实际环境中得到充分测试,还有很多性能优化的低垂果实。目前我也不承诺任何 API 兼容性。如果你需要一个生产就绪、高质量、通用的事件循环实现,请查看 libuv、libev 等。

为什么要开发新的事件循环库? 有几个原因。首先,我认为 Zig 缺少一个在功能上可与 libuv 相媲美的通用事件循环("通用"是这里的关键词)。其次,我想围绕 io_uring 的设计模式构建这样一个库,甚至在其他操作系统原语之上模仿其风格(感谢这篇出色的博客文章)。第三,我想要一个可以构建到 WebAssembly(包括 WASI 和独立环境)的事件循环库,而这并不太适合现有库的 API 风格和目标,除非引入像 Emscripten 这样的重量级工具。不过,开发这个库的主要动机是满足我自己的需求!

特性

跨平台。 支持 Linux(io_uringepoll)、macOS(kqueue)、WebAssembly + WASI(poll_oneoff,线程和非线程运行时)。(Windows 支持已计划,即将推出)

Proactor API 工作被提交到 libxev 事件循环,调用者会收到工作完成的通知,而不是工作就绪的通知。

零运行时内存分配。 这有助于使运行时性能更可预测,并使 libxev 非常适合嵌入式环境。

定时器、TCP、UDP、文件、进程。 提供高级平台无关的 API,用于与定时器、TCP/UDP 套接字、文件、进程等进行交互。对于不支持异步 IO 的平台,文件操作会自动调度到线程池。

通用线程池(可选)。 你可以创建一个通用线程池,配置其资源利用,并使用它来执行自定义后台任务。某些后端使用线程池来执行没有可靠非阻塞 API 的非阻塞任务(例如使用 kqueue 的本地文件操作)。线程池可以在多个线程和事件循环之间共享,以优化资源利用。

低级和高级 API。 高级 API 是平台无关的,但有一些固定的行为和有限的灵活性。推荐使用高级 API,但低级 API 始终可作为备选方案。低级 API 是特定于平台的,为 libxev 用户提供了一种机制来榨取最大性能。低级 API 在操作系统接口之上提供了恰到好处的抽象,使其更易于使用,同时不会牺牲明显的性能。

树摇(Zig)。 这是 Zig 的一个特性,但对 libxev 这样的库有实质性的好处。Zig 只会包含你实际使用的函数调用和特性。如果你不使用某种特定类型的高级监视器(如 UDP 套接字),那么与该抽象相关的功能根本不会被编译到你的最终二进制文件中。这使得 libxev 可以支持可选的"锦上添花"功能,在某些情况下可能被认为是"臃肿"的,但最终用户不必为此付出代价。

无依赖。 libxev 在运行时除了内置的操作系统 API 外没有其他依赖。C 库依赖于 libc。这使得交叉编译变得非常容易。

路线图

还有许多缺失的功能,我仍然想要添加:

  • 管道高级 API
  • 信号处理器
  • 文件系统事件
  • Windows 后端
  • 通过外部事件循环(即浏览器)支持独立的 WebAssembly

等等...

性能

还有很多性能改进的空间,我想明确表示我还没有做太多优化工作。尽管如此,性能表现看起来不错。我尝试将许多 libuv 基准测试 移植到使用 libxev API。

在我有更好的环境运行它们之前,我不会发布具体的基准测试结果。作为一个非常广泛的概括,使用 libxev 与其他主要事件循环相比,你不应该注意到明显的速度下降。这可能因功能而异,如果你能在问题中展示真正糟糕的性能,我很有兴趣解决它!

示例

下面的示例展示了使用 Zig 和 C 编写的相同程序,它们都使用 libxev 运行一个 5 秒的定时器。这个例子简单得近乎愚蠢,但旨在传达库的整体感觉,而不是实际的用例。

Zig C
const xev = @import("xev");

pub fn main() !void {
    var loop = try xev.Loop.init(.{});
    defer loop.deinit();

    const w = try xev.Timer.init();
    defer w.deinit();

    // 5秒定时器
    var c: xev.Completion = undefined;
    w.run(&loop, &c, 5000, void, null, &timerCallback);

    try loop.run(.until_done);
}

fn timerCallback(
    userdata: ?*void,
    loop: *xev.Loop,
    c: *xev.Completion,
    result: xev.Timer.RunError!void,
) xev.CallbackAction {
   _ = userdata;
   _ = loop;
   _ = c;
   _ = result catch unreachable;
   return .disarm;
}
#include <stddef.h>
#include <stdio.h>
#include <xev.h>

xev_cb_action timerCallback(xev_loop* loop, xev_completion* c, int result, void *userdata) {
    return XEV_DISARM;
}

int main(void) {
    xev_loop loop;
    if (xev_loop_init(&loop) != 0) {
        printf("xev_loop_init 失败\n");
        return 1;
    }

    xev_watcher w;
    if (xev_timer_init(&w) != 0) {
        printf("xev_timer_init 失败\n");
        return 1;
    }

    xev_completion c;
    xev_timer_run(&w, &loop, &c, 5000, NULL, &timerCallback);

    xev_loop_run(&loop, XEV_RUN_UNTIL_DONE);
xev_timer_deinit(&w); xev_loop_deinit(&loop); return 0; } ```

安装(Zig)

**这些说明仅适用于Zig下游用户。**如果你正在使用libxev的C API,请参阅"构建"部分。

此软件包适用于Zig 0.11中引入的Zig包管理器。创建一个如下所示的build.zig.zon文件:

.{
    .name = "my-project",
    .version = "0.0.0",
    .dependencies = .{
        .libxev = .{
            .url = "https://github.com/mitchellh/libxev/archive/<git-ref-here>.tar.gz",
            .hash = "12208070233b17de6be05e32af096a6760682b48598323234824def41789e993432c",
        },
    },
}

在你的build.zig中:

const xev = b.dependency("libxev", .{ .target = target, .optimize = optimize });
exe.addModule("xev", xev.module("xev"));

文档

🚧 文档正在编写中。🚧

目前,文档有三种形式:man页面示例代码注释。未来,我计划以网站形式编写详细的指南和API文档,但目前尚不可用。

Man页面

man页面相当详细!xev(7)将为你提供整个库的概览。xev-zig(7)xev-c(7)分别提供Zig和C API的概览。此外,还有特定API的man页面,如xev_loop_init(3)。这是目前最好的文档。

浏览man页面有多种方式。最直接友好的方式是在网络浏览器中浏览docs/目录中的原始man页面源文件。man页面源文件采用类似markdown的语法,所以通过GitHub在浏览器中呈现效果还不错。

另一种方法是运行zig build -Dman-pages,man页面将在zig-out中可用。这需要安装scdoc(大多数包管理器中都有)。构建man页面后,你可以按路径渲染它们:

$ man zig-out/share/man/man7/xev.7

最后一种方法是通过你喜欢的包管理器安装libxev(如果可用),这应该会将man页面放入你的man路径中,这样你就可以直接使用man 7 xev

示例

examples/文件夹中提供了示例。示例有C和Zig两种版本,你可以通过文件扩展名区分它们。

要构建示例,请使用以下命令:

$ zig build -Dexample-name=_basic.zig
...
$ zig-out/bin/example-basic
...

-Dexample-name的值应该是包括扩展名在内的文件名。

代码注释

Zig代码有详细的注释。如果你习惯阅读代码注释,你可以从中获得很多见解。源代码在src/目录中。

构建

构建需要安装最新的Zig每日构建版libxev没有其他构建依赖项。

安装后,单独运行zig build install将构建完整的库,并在zig-out中输出一个符合FHS标准的目录。你可以使用--prefix标志自定义输出目录。

测试

libxev有一个庞大且不断增长的测试套件。要运行当前平台的测试:

$ zig build test
...

这将运行当前主机平台支持的所有功能的所有测试。例如,在Linux上,这将同时运行完整的io_uring和epoll测试套件。

你可以为其他平台构建和运行测试,方法是交叉编译测试可执行文件,将其复制到目标机器并执行。例如,下面展示了如何从Linux交叉编译并构建macOS的测试:

$ zig build -Dtarget=aarch64-macos -Dinstall-tests
...

$ file zig-out/bin/xev-test
zig-out/bin/xev-test: Mach-O 64-bit arm64 executable

**WASI是一个特殊情况。**如果你安装了wasmtime,你可以运行WASI的测试:

$ zig build test -Dtarget=wasm32-wasi -Dwasmtime
...
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号