Project Icon

nix-direnv

优化Nix开发环境的持久化缓存工具

nix-direnv是direnv的扩展工具,为use_nix和use_flake提供更快速、持久化的实现。通过缓存nix-shell环境和符号链接保护构建依赖,它显著提升了Nix开发环境的效率。相比lorri,nix-direnv结构简单,无需外部守护进程,且支持flakes。它提供多种安装方式,包括home-manager、direnv的source_url和系统配置,为开发者优化Nix环境提供了便捷解决方案。

nix-direnv

测试

direnvuse_nixuse_flake的一个更快、持久化的实现,用于替代内置版本。

主要特点:

  • 通过缓存nix-shell环境,在首次运行后显著提高速度
  • 通过在用户的gcroots中创建结果shell派生的符号链接,防止构建依赖被垃圾回收(生命太短暂了,不能在没有网络连接的飞机上丢失项目的构建缓存)

为什么不使用lorri

lorri相比,nix-direnv更简单(不需要外部守护进程)并且支持flakes。此外,lorri有时会在每次更改时重新评估整个nixpkgs(导致持续高CPU负载)。

安装

注意:nix-direnv需要现代版本的Bash。macOS自带的是2007年的bash 3.2版本。作为解决方案,我们建议macOS用户通过Nix或Homebrew安装direnv。安装nix-direnv有多种方式,选择你喜欢的方式:

通过home-manager(推荐)

通过home-manager

请注意,虽然推荐使用home-manager集成,但某些用例可能需要只在特定版本的nix-direnv中存在的功能。使用这种方法很难控制安装的nix-direnv版本。如果你需要这种特定控制,请使用其他安装nix-direnv的方法。

$HOME/.config/home-manager/home.nix中添加

{
  # ...其他配置...

  programs = {
    direnv = {
      enable = true;
      enableBashIntegration = true; # 关于其他shell的注意事项见下文
      nix-direnv.enable = true;
    };

    bash.enable = true; # 关于其他shell的注意事项见下文
  };
}

查看当前的Home Manager选项以了解与Bash以外的shell的集成。确保也让home-manager管理你的shell,设置programs.<你的shell>.enable = true

Direnv的source_url

Direnv source_url

在你的.envrc中添加以下行:

if ! has nix_direnv_version || ! nix_direnv_version 3.0.5; then
  source_url "https://raw.githubusercontent.com/nix-community/nix-direnv/3.0.5/direnvrc" "sha256-RuwIS+QKFj/T9M2TFXScjBsLR6V3A17YVoEW/Q6AZ1w="
fi
通过NixOS的系统配置

通过NixOS的系统配置

对于NixOS 23.05+,只需要

{
  programs.direnv.enable = true;
}

其他可用选项有:

{ pkgs, ... }: {
  #设置为默认值
  programs.direnv = {
    package = pkgs.direnv;
    silent = false;
    loadInNixShell = true;
    direnvrcExtra = "";
    nix-direnv = {
      enable = true;
      package = pkgs.nix-direnv;
    };
  }
使用`nix profile`

使用nix profile

非root用户执行以下操作:

nix profile install nixpkgs#nix-direnv

然后将nix-direnv添加到$HOME/.config/direnv/direnvrc

source $HOME/.nix-profile/share/nix-direnv/direnvrc
从源码安装

从源码安装

将仓库克隆到某个目录,然后在你自己的~/.config/direnv/direnvrc中引用这个仓库中的direnvrc:

# 将此添加到 ~/.config/direnv/direnvrc
source $HOME/nix-direnv/direnvrc

使用示例

在项目目录中添加shell.nixdefault.nix

# 将此保存为shell.nix
{ pkgs ? import <nixpkgs> {}}:

pkgs.mkShell {
  packages = [ pkgs.hello ];
}

然后在你的envrc中添加use nix行:

$ echo "use nix" >> .envrc
$ direnv allow

如果你以前没有使用过direnv,请确保先将其挂钩到你的shell

使用非标准文件名

你可以在.envrc中传递文件名,使用不同于shell.nixdefault.nix的文件名,例如:

$ echo "use nix foo.nix" >> .envrc

Flakes支持

nix-direnv还提供了另一种use_flake实现。代码已经过测试并且可以正常工作,但上游flake API尚未最终确定,所以我们无法保证在nix升级后的稳定性。

use_nix类似,我们的use_flake将防止下载的包被垃圾回收,包括flake输入。

创建新的原生flake项目

这个仓库附带了一个flake模板,它提供了一个带有devShell集成和基本.envrc的基础flake。

要使用此模板,你可以执行以下命令:

$ nix flake new -t github:nix-community/nix-direnv <desired output path>

与现有flake集成

$ echo "use flake" >> .envrc && direnv allow

use flake行还可以接受一个额外的任意flake参数,因此你可以如下指向外部flakes:

use flake ~/myflakes#project

高级用法

use flake

在底层,use_flake调用nix print-dev-envuse_flake函数的第一个参数是要使用的flake表达式,其他所有参数都会传递给print-dev-env调用。你可以利用这一点进行一些更复杂的调用。

例如,如果你有一个在某些条件下需要不纯调用的flake,你可能希望向print-dev-env调用传递--impure参数,以便传入调用shell的环境。

你可以这样做:

$ echo "use flake . --impure" > .envrc
$ direnv allow

use nix

use flake类似,use nix现在也使用nix print-dev-env。由于历史原因,参数解析模仿了nix shell

这导致了我们在解析方面的一些限制。

目前,所有单词参数和一些众所周知的双参数将被解释或传递。

手动重新加载nix环境

为了避免在意外时间延迟和耗时重建,你可以在"手动重新加载"模式下使用nix-direnv。nix-direnv会在nix环境不再是最新时通知你。然后你可以自己决定何时重新加载nix环境。

要激活手动模式,在你的.envrc中使用nix_direnv_manual_reload,如下所示:

nix_direnv_manual_reload
use nix # 或 use flake

要重新加载你的nix环境,使用nix-direnv-reload命令:

$ nix-direnv-reload
已知参数
  • -p:开始要安装的包列表;消耗所有剩余参数
  • --include / -I:将以下路径添加到<...>文件名的查找位置列表中
  • --attr / -A:指定要使用的输出属性

--command--run--exclude--pure-i--keep被明确忽略。

所有单词参数(如-j4--impure等)都会传递给底层的nix调用。

跟踪的文件

为了方便,nix-direnv自动将常见文件添加到direnv的监视文件列表中。

额外跟踪的文件列表如下:

  • 对于use nix

    • ~/.direnvrc
    • ~/.config/direnv/direnvrc
    • .envrc
    • 单个nix文件。按优先顺序:
      • 传递给use nix的文件参数
      • 如果存在,则为default.nix
      • 如果存在,则为shell.nix
  • 对于use flake

    • ~/.direnvrc
    • ~/.config/direnv/direnvrc
    • .envrc
    • flake.nix
    • flake.lock
    • 如果存在,则为devshell.toml

用户可以自由使用direnv的内置watch_file函数来跟踪其他文件。watch_file必须在use flakeuse nix之前调用才能生效。

环境变量

nix-direnv设置以下环境变量供用户使用。所有其他环境变量要么是底层nix调用的产物,要么纯粹是偶然的,不应依赖。

  • NIX_DIRENV_DID_FALLBACK:当你的nix shell或flake的devShell的当前版本无效,并且nix-direnv已加载最后一个已知的工作shell时设置。

一般direnv提示

该领域的其他项目

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号