簡體   English   中英

Erlang-將每個“ erlang進程”映射到新的內核線程

[英]Erlang - map each “erlang process” to new kernel thread

我正在研究基於erlang的系統,並試圖分析系統中發生的事件的順序。 有沒有一種方法可以強制erlang運行時或elang vm每次調用“ spawn”時創建一個新的內核線程。 這會使系統變慢,但會使研究容易得多​​。 我已經嘗試過+ S標志,並且已經啟用了smp,但是我懷疑系統仍將多個進程映射到一個內核線程或erlang調度程序。 我缺少任何輸入/配置參數嗎?

不,不是Erlang VM的工作方式。 BEAM為每個核心生成線程並在其中運行調度程序。 每個Erlang進程都可以在任何調度程序上運行,甚至可以從調度程序遷移到調度程序,從而使它們從一個線程遷移到另一個線程。 默認情況下,這些調度程序甚至都沒有綁定到CPU內核,因此它們可以在內核之間遷移。 您可以使用-sbt開關綁定它們。 您還可以將Erlang進程綁定到特定的調度程序,該調度程序沒有文檔說明,強烈建議不要這樣做。 您不能從Erlang而是從NIF或端口生成線程,但是無論如何您都不能在此線程上運行Erlang進程。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM