簡體   English   中英

無法使用erlang中的spawn(Node,Fun)在遠程節點上生成功能

[英]Can not spawn function on remote node with spawn(Node, Fun) in erlang

我嘗試使用分布式erlang,這是我所擁有的:

 loop()->
    receive {From, ping} ->
            io:format("received ping from ~p~n", [From]),
            From ! pong,
            loop();
        {From, Fun} when is_function(Fun) ->
            io:format("executing function ~p received from ~p~n", [Fun, From]),
            From ! Fun(),
            loop()
    end.

    test_remote_node_can_execute_sent_clojure()->
        Pid = spawn(trecias, fun([])-> loop() end),
        Pid ! {self(), fun()-> erlang:nodes() end},
        receive Result -> 
            Result = [node()]
        after 300 ->
                  timeout
        end.

得到: Can not start erlang:apply,[#Fun<tests.1.123107452>,[]] on trecias

我在與節點“ trecias”相同的機器上運行的節點上執行測試。 兩個節點都可以加載相同的代碼。

有什么主意嗎?

spawn調用中,您已將節點名稱指定為trecias ,但是您需要指定完整的節點名稱,包括主機名,例如trecias@localhost

同樣,傳遞給spawn/2的函數必須使用零個參數,但是上面代碼中的一個接受一個參數(如果該參數不是空列表,則會崩潰)。 寫成fun() -> loop() end

在遠程節點上生成匿名函數時,還需要確保模塊在兩個節點上均以相同的版本加載。 否則,您將收到badfun錯誤。

暫無
暫無

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

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