【发布时间】:2017-12-05 14:07:40
【问题描述】:
部署我的 NixOps 机器需要很多时间,因为需要构建包。我想在我信任的私有 Hydra 实例上定期进行构建。
我目前的方法涉及到这个release.nix 文件,但效果不太好。
{ nixpkgs ? <nixpkgs>, onlySystem ? true, extraModules ? [] }:
let
nixos = import "${nixpkgs}/nixos";
buildEnv = conf: (nixos {
configuration = conf;
});
buildTarget = m: let build = buildEnv (buildConf m); in
if onlySystem then build.system else build.vm;
buildConf = module: { ... }:
{
imports = [ module ] ++ extraModules;
};
in
{
machine1 = buildTarget ./machine1/configuration.nix;
machine2 = buildTarget ./machine2/configuration.nix
machine3 = buildTarget ./machine3/configuration.nix
machine4 = buildTarget ./machine4/configuration.nix
}
这段代码我不是很懂,是从here复制过来的。
如果我在本地运行nix-build release.nix,这构建得很好,但在 hydra 上我永远不会得到完整的构建。有时构建不会出队(它们只是没有构建),有时它们会失败并显示各种错误消息。由于没有任何 hydra 问题是可重现的(事实上,我从未获得完整的构建),我想知道构建 NixOps 部署的最佳实践是什么。
请注意,我的部署中有 unfree 包。 nixpkgs.config.allowUnfree = true;这个选项是在hydra服务器上设置的。
这不是关于我的 hydra 故障的问题,而是关于使用 Hydra CI 构建 NixOps 部署的好方法。
【问题讨论】: