jonasbhjulstad

jonasbhjulstad

Adding code to child nodes

Hi!
I have been able to figure out how to spawn child nodes, but I’m not able to make the child nodes do anything. This is my current code:

:os.cmd('epmd -daemon')
    {:ok, parent} = Node.start(:parent@localhost, :shortnames)
:child.start(:localhost, 'child_1')

Spawning a function in the child node results in an error:

Node.spawn(:child_1@localhost, fn -> IO.puts "test" end)

IO.puts appears as undefined for the child node. How do i load code into child nodes?

Marked As Solved

benwilson512

benwilson512

Author of Craft GraphQL APIs in Elixir with Absinthe

A good example might be to checkout what Phoenix does in its pubsub test suite which includes some multi node cases phoenix_pubsub/test/phoenix/distributed_pubsub_test.exs at main · phoenixframework/phoenix_pubsub · GitHub

Also Liked

garrison

garrison

With :peer, which replaced the now-deprecated :slave:

opts = %{name: ~c"foo", host: ~c"localhost", connection: :standard_io}
{:ok, peer_pid, _name} = :peer.start_link(opts)

:peer.call(peer_pid, :code, :add_paths, [:code.get_path()])
:peer.call(peer_pid, IO, :puts, ["test"])
# "test"
hauleth

hauleth

Problem there is that slave node was spawned without any extra libraries outside the Erlang standard distribution. That mean that module IO (Elixir.IO to be exact) do not exists on that module. With save module started like this you can use only Erlang standard library, so to achieve what you want you need to use fn -> :io.format("test") end.

jonasbhjulstad

jonasbhjulstad

Thanks for the help!
I had a look into some of the code, and was able to find the correct commands which let me load the code path into the slave:

:os.cmd('epmd -daemon')
Node.start(:master@localhost, :shortnames)
:slave.start(:localhost, 'slave')
:rpc.block_call(:test@localhost, :code, :add_paths, [:code.get_path()])
...
Node.spawn(:slave@localhost, fn -> IO.puts "test" end)
...
#PID<10741.85.0>
iex(master@localhost)9> test

It worked!

Where Next?

Popular in Questions Top

Darmani72
If I have a post route which an argument: post /my_post_route/:my_param1, MyController.my_post_handler How would get the post params ...
New
mcarvalho
What is the difference between System.get_env and Application.get_env? For example, what are best practices to use one versus another.
New
earth10
Hi, I’m just starting to build a side-project with Elixir and Phoenix and doing some basic test with Elixir alone. What strikes me is th...
New
Patoshizzle
After calling mix ecto.create I get this error: 17:00:32.162 [error] GenServer #PID&lt;0.412.0&gt; terminating ** (Postgrex.Error) FATAL...
New
jaysoifer
Is there a way to rollback a specific migration and only that one (“skipping” all the other ones)? Would mix ecto.rollback -v 200809061...
New
myronmarston
The Elixir Typespec docs show the following syntax for keyword lists in typespecs: # ... | [key: type] # keyword lists...
New
JeremM34
Hello, how can I check the Phoenix version ? Thanks !
New
electic
Hi, I am new to Elixir. I am trying to use the DateTime component to insert a date into MySQL however the there seems to be no way to fo...
New
vegabook
I’m brand new to Phoenix and I have stripped one of the demo applications to the bone. I just want to get an svg up on the screen. Here i...
New
lucidguppy
I have a super simple question about elixir - how would I take a file like this foo bar baz and output a new file that enumerates th...
New

Other popular topics Top

skosch
To my knowledge, put_in, Map.update etc. all have the one limitation of not automatically creating intermediate keys when needed (for exa...
New
aesmail
Hello guys, I have finally made it. I created an admin interface for a framework. It’s been on my todo list for years and with the curre...
New
New
bsollish-terakeet
Credo is smart enough to check for (something like) this: assert length(the_list) == 0 with this response: Checking if an enum is empt...
New
baxterw3b
Hi guys, i’m new in the Elixir world, and i have to say, that i love it! i’m having some problem to understand anonymous functions with ...
New
nobody
Hi! In PHP: $_SERVER[‘SERVER_ADDR’] - in Elixir? Searched the docs for ip address and the web, no good results. Thanks!
New
AstonJ
Please see the new poll here: Which code editor or IDE do you use? (Poll) (2022 Edition) It’s been a while since we first asked this, I...
208 31142 143
New
romenigld
I am trying to run a deploy with docker and I successfully runned with this command: docker build -t romenigld/blog-prod . but when I t...
New
marick
I had some trouble figuring out how to make many-to-many associations work. Once I got it working, I wrote a blog post. Because I’m a nov...
New
sergio
Kind of like when jquery came out, it was super necessary. Existing drag and drop libraries have a bunch of baggage to support old browse...
New

We're in Beta

About us Mission Statement