首页
/ 使用nixos-generators从NixOS配置生成ISO镜像

使用nixos-generators从NixOS配置生成ISO镜像

2025-07-04 06:23:28作者:田桥桑Industrious

本文将详细介绍如何利用nixos-generators工具从现有的NixOS配置生成可启动的ISO镜像。nixos-generators是一个强大的工具,它允许用户将NixOS系统配置转换为多种格式,包括ISO、虚拟机镜像等。

基本配置结构

在Nix flakes中,我们通常会有nixosConfigurations来定义系统配置。要使用nixos-generators,首先需要在系统配置中导入相关模块:

nixosConfigurations.my-machine = nixpkgs.lib.nixosSystem {
  modules = [
    ./configuration.nix
    nixos-generators.nixosModules.all-formats
  ];
};

生成ISO镜像

配置完成后,可以通过以下方式将ISO镜像添加到flake的输出中:

packages.x86_64-linux.my-iso = self.nixosConfigurations.my-machine.config.formats.iso;

这样就能通过nix build .#packages.x86_64-linux.my-iso命令来构建ISO镜像。

跨架构构建

当需要在不同架构上构建镜像时,需要注意以下几点:

  1. 确保在nixosSystem中正确设置了hostPlatform:
nixpkgs.hostPlatform = "aarch64-linux";
  1. 在构建主机上启用binfmt支持以进行跨架构构建:
boot.binfmt.emulatedSystems = [ "aarch64-linux" ];

常见问题解决

  1. 缺少formats属性:确保正确导入了nixos-generators模块,并且该导入确实被包含在nixosSystem的modules列表中。

  2. 架构不匹配:当构建主机与目标架构不同时,需要设置好交叉编译环境或使用binfmt模拟。

  3. Darwin系统上的构建:在MacOS上构建Linux镜像时,可能需要额外的配置来支持跨平台构建。

高级用法

除了ISO格式外,nixos-generators还支持多种输出格式:

# 生成虚拟机镜像
packages.x86_64-linux.my-vm = self.nixosConfigurations.my-machine.config.formats.vm;

# 生成无GUI的虚拟机镜像
packages.x86_64-linux.my-vm-nogui = self.nixosConfigurations.my-machine.config.formats.vm-nogui;

通过合理配置nixos-generators,可以轻松地将NixOS系统配置转换为各种可部署的格式,极大简化了系统部署和分发的流程。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
9
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
64
19
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
392
3.89 K
flutter_flutterflutter_flutter
暂无简介
Dart
671
156
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
JavaScript
261
322
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
661
311
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.2 K
654
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1