V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
rockyliang
V2EX  ›  程序员

菜鸟问一个 nginx 和协程相关的问题

  •  
  •   rockyliang · 2023-05-23 11:44:53 +08:00 · 1188 次点击
    这是一个创建于 610 天前的主题,其中的信息可能已经有所发展或是发生改变。

    nginx:一个 worker 进程可以接收多个请求,当一个请求遇到 IO 阻塞时,worker 会自动切换去处理其它没有 IO 阻塞的请求

    协程:一个进程可以运行多个协程,当一个协程遇到 IO 阻塞时,协程调度器会自动切换去处理其它没有 IO 阻塞的协程

    从效果上来看,上面两者都是一样的,都是“遇到 IO 阻塞时自动切换去处理下一个”。

    但据我所知,nginx 好像并不是用协程来实现这个效果的,那它是怎么实现的呢,是用了多路复用技术(epoll)吗?如果是的话,那用 epoll 实现和用协程实现,各有什么优缺点,分别适合用于什么场景呢

    5 条回复    2023-05-24 17:01:23 +08:00
    iamzuoxinyu
        1
    iamzuoxinyu  
       2023-05-23 13:58:58 +08:00   ❤️ 1
    > 但据我所知,nginx 好像并不是用协程来实现这个效果的,那它是怎么实现的呢,是用了多路复用技术(epoll)吗?如果是的话,那用 epoll 实现和用协程实现,各有什么优缺点,分别适合用于什么场景呢

    是用的 epoll 。你大概对协程的理解有误区,协程跟 IO 的阻塞非阻塞是正交的概念,协程并不能实现 ``自动切换``,这是调度器的工作,e.g. epoll 可以用来实现协程的调度器。协程是一种编程模型,epoll 是一种并发模型。

    实际上 nginx 有个分支叫 OpenResty ,就是用 nginx 的 epoll 模型实现了用 lua 的 coroutine 以更方便地写并发接口。
    rockyliang
        2
    rockyliang  
    OP
       2023-05-23 16:56:05 +08:00
    @iamzuoxinyu 感谢回答,那其实就是,协程调度器和 epoll 并不是两个完全不相关的技术,协程调度器也是基于 epoll 来实现的,只是 epoll 是更加底层的技术
    ruanimal
        3
    ruanimal  
       2023-05-23 17:12:17 +08:00
    协程调度器会自动切换去处理其它没有 IO 阻塞的协程, 这个也是用 epoll 实现的
    ch2
        4
    ch2  
       2023-05-23 21:46:57 +08:00
    nginx 是 C 语言写的,当时只有系统调用 epool 能用
    不是它不想用,是诞生的太早协程这个设计没有被发扬光大
    golang 就有高级封装好的协程语法,但是那是很多年后的事情了
    iamzuoxinyu
        5
    iamzuoxinyu  
       2023-05-24 17:01:23 +08:00
    @rockyliang 协程调度器可以不依赖 epoll 实现,只是协程用到的地方大部分都涉及到 IO 。抛开 IO ,调度器可以完全不依赖 epoll ,比如 Go 的运行时中抛开 netpoll 部分的调度。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1060 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:59 · PVG 06:59 · LAX 14:59 · JFK 17:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.