Skip to content
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

Option to use Julia-provided MPI in machine setup #278

Merged
merged 2 commits into from
Nov 8, 2024

Conversation

johnomotani
Copy link
Collaborator

Occasionally it can be useful to use the Julia-provided MPI instead of the system MPI, for example to use Julia-provided binaries for external libraries that depend on MPI (e.g. the MUMPS library that provides MPI-parallelised LU). This PR adds an option to choose the Julia-provided MPI in the machine_setup.sh script.

When using the Julia-provided MPI, you have to use the corresponding mpiexec command. MPI.jl provides a function to generate a link to this command - the machine setup script generates this link in the project directory, so you would run an MPI job like, for example,

./mpiexecjl -np 8 julia --project -O3 --check-bounds=no run_moment_kinetics examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split3.toml

@johnomotani johnomotani added the enhancement New feature or request label Oct 9, 2024
@mrhardman
Copy link
Collaborator

mrhardman commented Oct 9, 2024

Thanks for suggesting this feature? Perhaps making a comment in the manual setup to link to https://juliaparallel.org/MPI.jl/stable/usage/ and https://juliaparallel.org/MPI.jl/stable/configuration/#configure_jll_binary could also be helpful?

Have you sucessfully used the mpiexecjl command with a -Jmoment_kinetics.so system image? I am trying this now to see if this solves my issue #275. However, on the first attempt with

julia --project -O3 precompile.jl
.julia/bin/mpiexecjl --project=./ -n 2 julia --project -O3 -Jmoment_kinetics.so -e 'include("moment_kinetics/test/runtests.jl")'

no jobs start, seeming like a hang. I wonder if that is because mpiexecjl only supports -O0. Without the -Jmoment_kinetics.so, the tests run and pass as expected with mpiexecjl, showing that this option of using the native julia MPI should work for manual setup.

EDIT: The hang is only seen with the tests, any job using run_moment_kinetics.jl seems to execute as expected.

@johnomotani johnomotani merged commit 6fccead into master Nov 8, 2024
16 of 20 checks passed
@johnomotani johnomotani deleted the machine-setup-julia-mpi-option branch November 8, 2024 09:25
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants