【发布时间】:2021-05-02 19:21:33
【问题描述】:
第一个问题,如果我在这里没有遵守任何既定规范,请对我大喊大叫:)
我第一次设置一个完整的 conda-build 管道,我有一个看起来像这样的 Makefile:
build:
echo "Building packages."
conda-build my_first_package/conda-recipe --output-folder /path/to/dev/channel
conda-build my_second_package/conda-recipe --output-folder /path/to/dev/channel
conda-build my_third_package/conda-recipe --output-folder /path/to/dev/channel
conda index /path/to/dev/channel
有问题的三个包彼此紧密相连,并且存储在同一个 repo 中,因此最好在同一个管道中构建每个包。我想做的是为每一个分离一个单独的进程并并行运行每个 conda-build 命令。不确定这是否是一个安全的操作,因为我真的不明白 conda-build 正在做什么来“构建”包。
我将在今天晚些时候测试这个想法并发布更新,但我真正担心的是它会产生一些意想不到的副作用,我不知道如何进行测试。所以我想我的问题是:conda-build 可以将多个包并行构建到同一个 conda 通道中吗?
【问题讨论】:
-
更新:经过一些广泛的实验,我发现它似乎有效。需要注意的是,如果第二个包依赖于第一个包,那么并行构建它们似乎会导致一些问题,因此最好按顺序运行依赖集。
-
虽然不典型,但在 Conda Forge 上肯定有具体的例子,其中原料构建多个包。例如,the
matplotlib-feedstock构建matplotlib-base、matplotlib和mpl-sample-data。 -
没有意识到他们是这样做的。很酷,一定要仔细看看。谢谢!
标签: python conda conda-build