1.A
是的,您可以将Nix视为使用/ nix / store作为缓存的构建工具. Nix是一个包管理器只是这种设计的副作用.
1.B
你的nix表达式取决于你的设置.为了弄清楚这一点,请查看$NIX_PATH变量,该变量指向nixpkgs repo副本所在的位置.那些副本(有时仍然是)由nix-channel工具管理,但将来你可以指向nixpkgs,如:
export NIX_PATH=nixpkgs=https://github.com/NixOS/nixpkgs/archive/16.03.tar.gz
您可以在这篇关于nix search paths的博客文章中阅读有关NIX_PATH的更多信息
1.C
是的,可以在机器之间复制包.实际上,已经有了一个工具:nix-copy-closure.
2.A
我相信你在这里谈论你用nix-env管理的Nix环境.我们通常将这些称为nix配置文件.我在第1点中对nix搜索路径(NIX_PATH变量)所说的并不真正适用于nix-env.
nix-env工具使用〜/ .nix-defexpr,默认情况下它是NIX_PATH的一部分,但这只是巧合.如果你清空NIX_PATH,由于〜/ .nix-defexpr,nix-env仍然可以找到派生.
2.B
用户配置文件只是一个nix环境(在2.a中描述),您可以将其更改为其他任何内容,例如:
nix-env --switch-profile ./result
其中./result是/ nix / store中的东西或指向/ nix / store的东西.然后上面的命令将使用./result切换〜/ .nix-profile符号链接.
2.C
nix-shell实际上更接近nix-build命令.那么让我先解释一下nix-build的功能.
nix-build用于构建.nix文件(也是派生,但为此我必须解释派生是什么).如何使用nix-build的示例:
nix-build something.nix
上面的命令会生成一个./result符号链接,指向/ nix / store中的某个内容. Nix命令将实现构建并将输出存储到/ nix / store中.
另一方面,nix-shell将完全执行nix-build所做的操作,除非它不会触发构建器脚本并将您带入该环境.这样你最终会得到一个可以用来开发nix表达式的环境,它也可以在nixpkgs存储库之外(例如你的私有项目).
3.A
Nix安装二进制文件,NixOS为该二进制文件创建配置,并将其与init系统(当前为systemd)挂钩.
3.B
不.这是其他配置管理员所做的事情.尼克斯反过来工作.在blog post中很好地描述了方法的不同之处.
3.C
如3.a所述,nix只会安装二进制文件,而nixos也会确保二进制文件正在运行.
4.A / B / C
基本上没有限制,你认为如何适合你.一旦您了解了基本概念,您就会找到最适合您的概念.看看别人的dotfiles /配置并有意见.
我使用my collection的nixos配置为我的家人管理笔记本电脑
system.auto升级服务.
为了创建一个(构建)可重现的环境,我前段时间写过a blog post.
5.
我个人最喜欢的工具(或已经在这里)是vulnix.这将检查您当前的系统/项目是否存在当前漏洞(CVE).这使得nix与其他人脱颖而出,特别是因为它易于使用(没有企业设置).
我在nix中找到的另一个用例是使用dockerTools helpers构建可重现的docker镜像.