-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
spawn on multiple computer nodes #6152
Comments
It will probably not be included as part of the core language (rust is more geared towards single process parallelism), but something like that should be possible with library code. The hard part will be sending arbitrary closures/functions, but even that should ultimately be possible with some kind of compiletime reflexion, (de)serialization, and jit compiliation on the other end. Of course, whether that's as performant as a language that supports it natively is another question... |
Naively, I feel like it should be possible to extend the existing task scheduler API such that instead of only being able to say things like "spawn one task for each system core" you could also say "spawn tasks across all available compute nodes". |
To clarify, by "compute nodes" I'm including the possibility of heterogenous distributed compute clusters. I originally thought the Julia documentation was referring to these, but it looks like it's really just referring to scaling across multiple cores. |
flatpipes already enables part of this. Probably the first thing that is needed to build something like this is to create something akin to Erlang's distribution protocol and node finding. |
I imagine one could build a cross-process spawning framework. You |
Tagging this as an interesting project in case anyone feels inspired. |
Implementation of Erlang/OTP node in Go ( https://github.com/goerlang/node ) another project which use it is https://github.com/goerlang/eclus . Here are even parts from erlang written in GO ( https://github.com/goerlang ). Could maybe be converted to Rust. |
Added a few tags. This would be great to have. I also think this will need a fairly tight coupling with the runtime to do well. A naive approach is to just extend workstealing to allow steals accross physical machines, as long as the "work being stolen" is appropriately flagged. It would be interesting to provide good "hooks" in the runtime to do this without it being "part" of the runtime, but we aren't ready to think about that yet. |
Bug triage. An interesting project, but not a blocker. |
Here is a talk about Cloud Haskell http://skillsmatter.com/podcast/home/haskell-cloud/js-4179 |
This project http://www.gocircuit.org/ extends the reach of Go's linguistic environment to multi-host/multi-process applications. |
Visiting for triage. Besides the comments and suggestions here, nothing else seems to have been done. |
This would be an interesting project, but it's not in the scope of the standard libraries. There are far too many design compromises involved to provide a standard solution to distributed computing. It would also imply cryptography (TLS) in the standard library, which has been rejected. Go dropped the experimental support for netchan from the standard library because the problem space is too complex to tackle there. |
Fixes ICE 6139 Fixes rust-lang#6139 Kind of hacky, but this should be fine. changelog: none
Hi, any plans to support spawn on multiple computer nodes similar like Julia ( http://docs.julialang.org/en/latest/manual/parallel-computing/#parallel-map-and-loops ) does it:
The above code perform some trials on two machines, and add together the results.
The above computation is automatically distributed across all available compute nodes, and the result, reduced by summation (+), is returned at the calling node.
I read about raspberry pi supercomputer (
http://www.tomshardware.com/news/Raspberry-Pi-Supercomputer-Legos-Linux,17596.html ) and just wondering whether Rust could do the same?
Mic
The text was updated successfully, but these errors were encountered: