在 Julia 中为整个进程设置环境变量
Set environment variables all over processes in Julia
我目前正在使用 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"
等等
我目前正在使用 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"
等等