我目前正在与 Julia (1.0) 合作在 HPC 的集群上运行一些并行代码。 HPC 由 PBS 管理。我试图找到一种在所有进程中广播环境变量的方法,即一种自动广播特定环境变量列表的方法,以便在每个 Julia worker 中访问它们。
#!/bin/bash
#PBS ...
export TOTO=toto
julia --machine-file=$PBS_NODEFILE my_script.jl
在这个例子中,我将无法访问每个 julia worker 中的变量 TOTO(通过 ENV["TOTO"])。
我发现做我想做的唯一方法是在我的 .bashrc 中设置变量,但我希望这是特定于脚本的。另一种方法是放入我的 startup.jl 文件:
@everywhere ENV["TOTO"] = $(ENV["TOTO"])
但它不是特定于脚本的,因为我必须事先知道我要发送哪些变量。如果我对 ENV 键进行循环,那么我将广播所有变量,然后覆盖我不想要的变量。
我尝试使用
DotEnv.jl
但它不起作用。谢谢你的时间。
最佳答案
显而易见的方法是首先在 script.jl
中设置变量.您还可以将初始化放在单独的文件中,例如environment.jl
,并使用 -L
在所有进程上加载它旗帜:
julia --machine-file=$PBS_NODEFILE -L environment.jl my_script.jl
哪里
environment.jl
在这种情况下,将包含ENV["TOTO"] = "toto"
等等。
关于environment-variables - 在 Julia 中设置整个进程的环境变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56169168/