gpt4 book ai didi

http - Elixir:Async HTTP 有什么意义?

转载 作者:可可西里 更新时间:2023-11-01 15:14:25 28 4
gpt4 key购买 nike

我习惯了请求处理程序在线程上运行的语言,因此所有 I/O 函数都有一个异步版本以防止阻塞线程。

在 Elixir 中,每个请求都在一个轻量级进程(actor?)中处理,并且运行时可以在单个操作系统线程上多路复用数千个 actor。如果一个 actor 阻塞,运行时会交换另一个 actor 来使用 cpu。因为,actor 可以在不阻塞线程的情况下阻塞,所以我看不到 Elixir 中异步函数的意义。然而,我在 HTTPotion 文档中遇到了这个:

iex> HTTPotion.get "http://floatboth.com", [], [stream_to: self]
%HTTPotion.AsyncResponse{id: {1372,8757,656584}}

这里的异步函数有什么意义?

最佳答案

根据 HTTPotion 的自述文件,使用 stream_to 将导致消息发送到为每个 http 响应 block 提供的 Pid。您可以使用接收 block 来接受这些并相应地处理它们。

一般来说,说“在 Elixir 中,每个请求都被处理……”是没有意义的,因为请求意味着非常具体的事情。假设这与网络应用程序和入站请求有关。

在 Elixir 中,每个进程都是按顺序执行的代码块。当那段代码完成时,进程就结束了。 一个 异步响应在 HTTPotion 中的使用是选择性接收,您希望尽可能快地处理内容,但匹配特定模式的消息可能优先。选择性接收是 Erlang 处理并发的方式优于 Go 处理它 (CSP) 的方式的好处之一。

希望对您有所帮助。关键是,actor 可以在不阻塞 OS 级线程的情况下进行阻塞,但有时您希望给定消息优先,在这种情况下,从邮箱中选择性接收具有重要值(value)。例如,想象其中一条可能的消息相当于“shucks,因为这个值,我知道我根本不关心这个 http 响应。”然后,您可以关闭该进程,而不会浪费 CPU 来处理已在邮箱中排队的(较早收到的 CPU 密集型)消息。

关于http - Elixir:Async HTTP 有什么意义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23957925/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com