NixOS Installation Guide/zh: Difference between revisions
Created page with "* 博客文章:如何在 [http://grahamc.com/blog/nixos-on-dell-9560 Dell 9560] 上安装 NixOS * 品牌服务器可能需要在 initrd 中包含额外的内核模块(在 configuration.nix 中配置 <code>boot.initrd.extraKernelModules</code>)。例如,HP Proliant 需要“hpsa”模块才能访问磁盘驱动器。" |
Updating to match new version of source page |
||
Line 1: | Line 1: | ||
<languages/> | |||
<div class="mw-translate-fuzzy"> | |||
这份指南是对[https://nixos.org/nixos/manual/index.html#ch-installation 官方手册]的一份参考指南. 它讲述了把[[NixOS]]作为完整操作系统的安装过程. 为了在一个已存在的操作系统内安装[[Nix]], 请见[[Nix Installation Guide|Nix安装指南]]. | 这份指南是对[https://nixos.org/nixos/manual/index.html#ch-installation 官方手册]的一份参考指南. 它讲述了把[[NixOS]]作为完整操作系统的安装过程. 为了在一个已存在的操作系统内安装[[Nix]], 请见[[Nix Installation Guide|Nix安装指南]]. | ||
</div> | |||
<div class="mw-translate-fuzzy"> | |||
除了讲述官方手册上的步骤, 它还提供了用于常见使用场景的已知良好指导. 当官方手册和这份指南之间出现矛盾时, 以官方手册中描述的情况为准. | 除了讲述官方手册上的步骤, 它还提供了用于常见使用场景的已知良好指导. 当官方手册和这份指南之间出现矛盾时, 以官方手册中描述的情况为准. | ||
</div> | |||
<span id="Installation_target"></span> | <span id="Installation_target"></span> | ||
Line 75: | Line 78: | ||
{{expansion|Troubleshooting steps, and details are lacking.}} | {{expansion|Troubleshooting steps, and details are lacking.}} | ||
<div class="mw-translate-fuzzy"> | |||
因为安装媒介是混合型的, 它通过legacy bios模式和UEFI模式都可以启动. | 因为安装媒介是混合型的, 它通过legacy bios模式和UEFI模式都可以启动. | ||
</div> | |||
无论使用哪种方式启动安装媒介, 你可能需要修改主板或者电脑的配置, 以允许从光盘驱动器(对于CD/DVD)或者从一个外部的USB驱动器启动. | 无论使用哪种方式启动安装媒介, 你可能需要修改主板或者电脑的配置, 以允许从光盘驱动器(对于CD/DVD)或者从一个外部的USB驱动器启动. | ||
Line 107: | Line 112: | ||
=== 无线网络 === | === 无线网络 === | ||
<div class="mw-translate-fuzzy"> | |||
Network Manager安装在图形界面ISO文件中, 这意味着可以在命令行中使用<code>nmtui</code>来连接到网络. | Network Manager安装在图形界面ISO文件中, 这意味着可以在命令行中使用<code>nmtui</code>来连接到网络. | ||
</div> | |||
使用左上方的"Applications(应用)"标签页或者在底部的启动栏, 打开一个终端应用, 在那里启动 <code>nmtui</code>. 这可以让你'activate(激活)'一个(无线)连接 - 你应该可以在列表里看到你那里的SSID(无线网络名称), 除此之外你还可以添加一个新的连接. 当无线连接处于活动状态, 并且你已经测试过了时, 一开始就启动的安装程序很可能还没有检测到新的连接. 关掉安装程序, 再重新从屏幕底部的启动栏打开它. 这时它应该会检测到新的网络连接而继续. | 使用左上方的"Applications(应用)"标签页或者在底部的启动栏, 打开一个终端应用, 在那里启动 <code>nmtui</code>. 这可以让你'activate(激活)'一个(无线)连接 - 你应该可以在列表里看到你那里的SSID(无线网络名称), 除此之外你还可以添加一个新的连接. 当无线连接处于活动状态, 并且你已经测试过了时, 一开始就启动的安装程序很可能还没有检测到新的连接. 关掉安装程序, 再重新从屏幕底部的启动栏打开它. 这时它应该会检测到新的网络连接而继续. | ||
<div class="mw-translate-fuzzy"> | |||
在最小化安装的ISO文件上(或者你更熟悉 <code>wpa_supplicant</code> ), 你也可以运行 <code>wpa_passphrase ESSID | sudo tee /etc/wpa_supplicant.conf</code>, 然后输入你的密码, 再运行<code>systemctl restart wpa_supplicant</code>. | 在最小化安装的ISO文件上(或者你更熟悉 <code>wpa_supplicant</code> ), 你也可以运行 <code>wpa_passphrase ESSID | sudo tee /etc/wpa_supplicant.conf</code>, 然后输入你的密码, 再运行<code>systemctl restart wpa_supplicant</code>. | ||
</div> | |||
<span id="Partitioning"></span> | <span id="Partitioning"></span> | ||
== Partitioning(分区操作) == | == Partitioning(分区操作) == | ||
<div class="mw-translate-fuzzy"> | |||
为了给连续存储进行分区, 运行 <code>sudo fdisk /dev/diskX</code> , 然后跟着针对DOS或(U)EFI的指示来做. | 为了给连续存储进行分区, 运行 <code>sudo fdisk /dev/diskX</code> , 然后跟着针对DOS或(U)EFI的指示来做. | ||
这里有一个非常简单的示例设置. | 这里有一个非常简单的示例设置. | ||
</div> | |||
<syntaxhighlight lang="console"> | |||
$ [ -d /sys/firmware/efi/efivars ] && echo "UEFI" || echo "Legacy" | |||
</syntaxhighlight> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
A very simple example setup is given here. | |||
</div> | |||
<span id="Legacy_Boot_(MBR)"></span> | |||
<div class="mw-translate-fuzzy"> | |||
=== DOS === | === DOS === | ||
</div> | |||
* o (dos硬盘标签) | * o (dos硬盘标签) | ||
Line 150: | Line 172: | ||
* w (写入) | * w (写入) | ||
<span id=" | <span id="Format_partitions"></span> | ||
<div class="mw-translate-fuzzy"> | |||
== Label partitions(给分区贴标签) == | == Label partitions(给分区贴标签) == | ||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
The example below uses the [[ext4]] filesystem format. If you wish to use other filesystem formats such as [[Btrfs]] or [[ZFS]]: | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
* [[Bcachefs#NixOS installation on bcachefs]] | |||
* [[Btrfs#Installation of NixOS on btrfs]] | |||
* [[LVM#Basic Setup]] | |||
* [[ZFS#Simple NixOS ZFS on root installation]] | |||
</div> | |||
<div class="mw-translate-fuzzy"> | |||
这对于有多个分区设置的情况很有用, 使分区更容易处理<syntaxhighlight lang="console"> | 这对于有多个分区设置的情况很有用, 使分区更容易处理<syntaxhighlight lang="console"> | ||
$ lsblk | $ lsblk | ||
Line 162: | Line 198: | ||
$ sudo mount /dev/disk/by-label/NIXBOOT /mnt/boot | $ sudo mount /dev/disk/by-label/NIXBOOT /mnt/boot | ||
</syntaxhighlight> | </syntaxhighlight> | ||
</div> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ | $ lsblk # lists current system block devices | ||
# mkfs.fat -F 32 -n boot /dev/sdX1 | |||
# mkfs.ext4 /dev/sdX2 -L nixos | |||
# mount /dev/disk/by-label/nixos /mnt | |||
# mkdir -p /mnt/boot | |||
# mount /dev/disk/by-label/boot /mnt/boot | |||
</syntaxhighlight> | </syntaxhighlight> | ||
<span id="NixOS_configuration"></span> | |||
<div class="mw-translate-fuzzy"> | |||
== NixOS配置 == | == NixOS配置 == | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
Line 177: | Line 217: | ||
$ sudo vim configuration.nix | $ sudo vim configuration.nix | ||
</syntaxhighlight>最重要的修改: | </syntaxhighlight>最重要的修改: | ||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
NixOS is configured through a [[Overview of the NixOS Linux distribution#Declarative Configuration|declarative configuration]] file. To generate a default config file, run [[nixos-generate-config]]: | |||
</div> | |||
<syntaxhighlight lang="console"> | |||
# nixos-generate-config --root /mnt | |||
# nano /mnt/etc/nixos/configuration.nix | |||
</syntaxhighlight> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
For information on working with a system configuration, see [[NixOS system configuration]]. For desktop-specific configurations, see [[NixOS as a desktop]]. | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
Most essential changes: | |||
</div> | |||
<div class="mw-translate-fuzzy"> | |||
* keyboard layout(键盘布局), 也就是<code>[[Keyboard Layout Customization|services.xserver.xkb.layout]]</code> | * keyboard layout(键盘布局), 也就是<code>[[Keyboard Layout Customization|services.xserver.xkb.layout]]</code> | ||
* <code>users.users.user</code> 和附加条目 <code>initialPassword = "pw123";</code> | * <code>users.users.user</code> 和附加条目 <code>initialPassword = "pw123";</code> | ||
Line 184: | Line 243: | ||
* 安装编辑器来编辑配置文件 | * 安装编辑器来编辑配置文件 | ||
* 修改硬件配置以使用标签 | * 修改硬件配置以使用标签 | ||
</div> | |||
具有自我说明性的NixOS选项可以在[https://search.nixos.org/options NixOS选项搜索]上搜索到. | 具有自我说明性的NixOS选项可以在[https://search.nixos.org/options NixOS选项搜索]上搜索到. | ||
<span id="Swap_file"></span> | |||
<div class="mw-translate-fuzzy"> | |||
== Swap文件 == | |||
<syntaxhighlight lang="console"> | |||
$ sudo dd if=/dev/zero of=/mnt/.swapfile bs=1024 count=2097152 (2GB size) | |||
$ sudo chmod 600 /mnt/.swapfile | |||
$ sudo mkswap /mnt/.swapfile | |||
$ sudo swapon /mnt/.swapfile | |||
</syntaxhighlight> | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
For additional methods of configuring swap, see [[Swap]]. The following example demonstrates how to create and enable a [[Swap#Swap file|swap file]]: | |||
</div> | |||
{{file|/mnt/etc/nixos/configuration.nix|nix| | |||
<nowiki> | |||
swapDevices = [{ | |||
device = "/var/lib/swapfile"; | |||
size = 16*1024; # 16 GB | |||
}]; | |||
</nowiki> | |||
}} | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
=== Bootloader === | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
NixOS supports multiple [[Bootloader|bootloaders]] such as [[GNU GRUB]] and [[Systemd/boot]]. | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
Systemd-boot is the recommended bootloader. The following example demonstrates how to enable systemd-boot in your configuration: | |||
</div> | |||
{{file|/mnt/etc/nixos/configuration.nix|nix| | |||
<nowiki> | |||
boot.loader.systemd-boot.enable = true; | |||
</nowiki> | |||
}} | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
You may also wish to configure [[Secure Boot]]. | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
=== Users === | |||
</div> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
For information on creating and managing users, see [[User management]] and the {{NixOS Manual|name=NixOS Manual: Chapter - Package Management|anchor=#sec-user-management}}. See an example below: | |||
</div> | |||
{{file|/mnt/etc/nixos/configuration.nix|nix| | |||
<nowiki> | |||
users.users.alice = { | |||
isNormalUser = true; | |||
initialPassword = "pw123"; | |||
}; | |||
</nowiki> | |||
}} | |||
<span id="NixOS_installation"></span> | |||
<div class="mw-translate-fuzzy"> | |||
== NixOS安装 == | == NixOS安装 == | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
Line 192: | Line 317: | ||
$ sudo nixos-install | $ sudo nixos-install | ||
</syntaxhighlight>安装完成后: 运行 <code>passwd</code> 来修改用户的密码. | </syntaxhighlight>安装完成后: 运行 <code>passwd</code> 来修改用户的密码. | ||
</div> | |||
<syntaxhighlight lang="console"> | |||
# cd /mnt | |||
# nixos-install | |||
</syntaxhighlight> | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
after installation: Run <code>passwd</code> to change user password. | |||
</div> | |||
<div class="mw-translate-fuzzy"> | |||
如果网络出现问题, 请尝试下面的一种方法:<syntaxhighlight lang="console"> | 如果网络出现问题, 请尝试下面的一种方法:<syntaxhighlight lang="console"> | ||
$ nixos-rebuild switch --option substitute false # 无下载 | $ nixos-rebuild switch --option substitute false # 无下载 | ||
Line 198: | Line 334: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
* 设置wpa_supplicant标志来连接到wifi. | * 设置wpa_supplicant标志来连接到wifi. | ||
</div> | |||
<syntaxhighlight lang="console"> | |||
# nixos-rebuild switch --option substitute false # no downloads | |||
# nixos-rebuild switch --option binary-caches "" # no downloads | |||
</syntaxhighlight> | |||
<div class="mw-translate-fuzzy"> | |||
<hr /> | |||
</div> | |||
<hr /> | <hr /> | ||
Line 210: | Line 356: | ||
<div lang="en" dir="ltr" class="mw-content-ltr"> | <div lang="en" dir="ltr" class="mw-content-ltr"> | ||
[[Category:Guide]][[Category:Deployment]] | [[Category:Guide]] | ||
[[Category:Deployment]] | |||
[[Category:NixOS]] | |||
</div> | </div> |
Revision as of 06:23, 8 October 2025
除了讲述官方手册上的步骤, 它还提供了用于常见使用场景的已知良好指导. 当官方手册和这份指南之间出现矛盾时, 以官方手册中描述的情况为准.
安装目标
NixOS可以安装在越来越多种类的硬件上:
- 常规(Intel或AMD)台式机, 笔记本电脑, 或是物理可访问的服务器, 该页面包含了它们
- 单板计算机(如树莓派)和其他ARM开发板, 见 NixOS on ARM
- 云服务器和远程服务器, 见 NixOS friendly hosters
安装方式
NixOS, 如同绝大部分基于Linux的操作系统一样, 可以通过多种方式进行安装.
- 传统方式, 通过安装媒介启动.(会在下面讲述.)
- 通过已存在的Linux安装启动媒介
制作安装媒介
从NixOS 14.11开始, 安装程序ISO(镜像文件)是混合型的. 这意味着它通过CD和USB驱动器都可以启动. 它也可以在EFI系统上启动, 如大多数现代主板和苹果系统. 接下来的指导将假设使用复制镜像文件到USB驱动器的标准方式. 当使用CD或者DVD时, 刻录到光盘的通常方式应当也适用于该iso文件.
"刻录"到USB驱动器
首先, 下载一个NixOS ISO镜像 或者 创建一个自定义ISO文件. 接着插入一个空间大到足够容纳镜像的USB. 然后遵循平台的指令:
在Linux上
- 通过
lsblk
或fdisk -l
找到正确的设备. 在接下来的步骤中, 把/dev/sdX
替换为正确的设备. - 复制到设备:
cp nixos-xxx.iso /dev/sdX
也可通过 dd if=nixos.iso of=/dev/sdX bs=4M status=progress conv=fdatasync
写入硬盘镜像
在macOS上
- 使用
diskutil list
找到正确的设备, 比如说diskX
. - 使用
diskutil unmountDisk diskX
取消挂载. - 使用
sudo dd if=path_to_nixos.iso of=/dev/diskX
进行刻录
rdiskX
而不是diskX
可以大幅改变速度. 你可以在另一个终端里使用iostat 2
检查写入速度.
在Windows上
- 下载USBwriter.
- 启动USBwriter.
- 选择下载的ISO文件作为'Source'
- 选择USB驱动器作为'Target'
- 点击'Write'
- 当USBWriter完成写入操作后, 安全拔出USB驱动器
可选的安装媒介指导
之前的方式是制作USB安装媒介的受支持方式.
这些方式也同样有记录, 它们可以使用USB驱动器启动多个发行版. 这种方式不被支持, 结果可能因人而异.
启动(Boot)安装媒介
因为安装媒介是混合型的, 它通过legacy bios模式和UEFI模式都可以启动.
无论使用哪种方式启动安装媒介, 你可能需要修改主板或者电脑的配置, 以允许从光盘驱动器(对于CD/DVD)或者从一个外部的USB驱动器启动.
Legacy bios启动
这是在没有EFI/UEFI的机器上唯一的启动方式.
UEFI启动
安装媒介的EFI引导加载程序未经过签名, 也没有使用经过签名的shim来启动. 这意味着只有禁用了Secure Boot(安全启动)才能启动.
连接到网络
安装过程几乎肯定需要有效的网络连接. 无网络的安装是可行的, 但是可用的软件包集合是受限的.
有线网络
对于内核提供的网络接口, DHCP(动态主机配置协议)解析应当在shell可用之前就已经完成.
有线连接(网络共享)
如果你无法通过网线或者wifi连接到网络, 你可以使用智能手机的网络共享能力. 依赖于你的手机的能力, 只需要内核自带的驱动就可以提供有效的网络连接.
无线网络
Network Manager安装在图形界面ISO文件中, 这意味着可以在命令行中使用nmtui
来连接到网络.
使用左上方的"Applications(应用)"标签页或者在底部的启动栏, 打开一个终端应用, 在那里启动 nmtui
. 这可以让你'activate(激活)'一个(无线)连接 - 你应该可以在列表里看到你那里的SSID(无线网络名称), 除此之外你还可以添加一个新的连接. 当无线连接处于活动状态, 并且你已经测试过了时, 一开始就启动的安装程序很可能还没有检测到新的连接. 关掉安装程序, 再重新从屏幕底部的启动栏打开它. 这时它应该会检测到新的网络连接而继续.
在最小化安装的ISO文件上(或者你更熟悉 wpa_supplicant
), 你也可以运行 wpa_passphrase ESSID | sudo tee /etc/wpa_supplicant.conf
, 然后输入你的密码, 再运行systemctl restart wpa_supplicant
.
Partitioning(分区操作)
为了给连续存储进行分区, 运行 sudo fdisk /dev/diskX
, 然后跟着针对DOS或(U)EFI的指示来做.
这里有一个非常简单的示例设置.
$ [ -d /sys/firmware/efi/efivars ] && echo "UEFI" || echo "Legacy"
A very simple example setup is given here.
DOS
- o (dos硬盘标签)
- n new
- p primary (4 primary in total)
- 1 (分区编号[1/4])
- 2048 first sector (alignment for performance)
- +500M last sector (引导扇区的大小)
- rm signature (Y), if ex. => warning of overwriting existing system, could use wipefs
- n
- p
- 2
- default (填满分区)
- default (填满分区)
- w (写入)
UEFI
- g (gpt硬盘标签)
- n
- 1 (分区编号[1/128])
- 2048 first sector
- +500M last sector (引导扇区的大小)
- t
- 1 (EFI系统)
- n
- 2
- default (填满分区)
- default (填满分区)
- w (写入)
Label partitions(给分区贴标签)
The example below uses the ext4 filesystem format. If you wish to use other filesystem formats such as Btrfs or ZFS:
$ lsblk
$ sudo mkfs.fat -F 32 /dev/sdX1
$ sudo fatlabel /dev/sdX1 NIXBOOT
$ sudo mkfs.ext4 /dev/sdX2 -L NIXROOT
$ sudo mount /dev/disk/by-label/NIXROOT /mnt
$ sudo mkdir -p /mnt/boot
$ sudo mount /dev/disk/by-label/NIXBOOT /mnt/boot
$ lsblk # lists current system block devices
# mkfs.fat -F 32 -n boot /dev/sdX1
# mkfs.ext4 /dev/sdX2 -L nixos
# mount /dev/disk/by-label/nixos /mnt
# mkdir -p /mnt/boot
# mount /dev/disk/by-label/boot /mnt/boot
NixOS配置
$ sudo nixos-generate-config --root /mnt
$ cd /mnt/etc/nixos/
$ sudo vim configuration.nix
NixOS is configured through a declarative configuration file. To generate a default config file, run nixos-generate-config:
# nixos-generate-config --root /mnt
# nano /mnt/etc/nixos/configuration.nix
For information on working with a system configuration, see NixOS system configuration. For desktop-specific configurations, see NixOS as a desktop.
Most essential changes:
- keyboard layout(键盘布局), 也就是
services.xserver.xkb.layout
users.users.user
和附加条目initialPassword = "pw123";
- networking (wifi), 如果出现问题, 请见下方的修复方法
boot.loader.grub.device = "/dev/sda"; #或者只用于efi的 "nodev"
- 安装编辑器来编辑配置文件
- 修改硬件配置以使用标签
具有自我说明性的NixOS选项可以在NixOS选项搜索上搜索到.
Swap文件
$ sudo dd if=/dev/zero of=/mnt/.swapfile bs=1024 count=2097152 (2GB size)
$ sudo chmod 600 /mnt/.swapfile
$ sudo mkswap /mnt/.swapfile
$ sudo swapon /mnt/.swapfile
For additional methods of configuring swap, see Swap. The following example demonstrates how to create and enable a swap file:
swapDevices = [{
device = "/var/lib/swapfile";
size = 16*1024; # 16 GB
}];
Bootloader
NixOS supports multiple bootloaders such as GNU GRUB and Systemd/boot.
Systemd-boot is the recommended bootloader. The following example demonstrates how to enable systemd-boot in your configuration:
boot.loader.systemd-boot.enable = true;
You may also wish to configure Secure Boot.
Users
For information on creating and managing users, see User management and the NixOS Manual: Chapter - Package Management. See an example below:
users.users.alice = {
isNormalUser = true;
initialPassword = "pw123";
};
NixOS安装
$ cd /mnt
$ sudo nixos-install
passwd
来修改用户的密码.
# cd /mnt
# nixos-install
after installation: Run passwd
to change user password.
$ nixos-rebuild switch --option substitute false # 无下载
$ nixos-rebuild switch --option binary-caches "" # 无下载
- 设置wpa_supplicant标志来连接到wifi.
# nixos-rebuild switch --option substitute false # no downloads
# nixos-rebuild switch --option binary-caches "" # no downloads
有关特定硬件的附加说明
这些是有关特定硬件问题的收集到的说明或链接.
- 博客文章:如何在 Dell 9560 上安装 NixOS
- 品牌服务器可能需要在 initrd 中包含额外的内核模块(在 configuration.nix 中配置
boot.initrd.extraKernelModules
)。例如,HP Proliant 需要“hpsa”模块才能访问磁盘驱动器。