2024-01-11 04:17:05 +01:00
|
|
|
# 使用 Justfile 简化 NixOS 相关命令
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-03-16 12:29:05 +01:00
|
|
|
在使用 NixOS 的过程中,我们会经常使用 `nixos-rebuild` 命令,经常需要输入一大堆参数,比较繁
|
|
|
|
琐。
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-01-11 04:17:05 +01:00
|
|
|
我使用了 [just](https://github.com/casey/just) 来管理我的 flake 配置相关的命令,简化使用。
|
2024-03-16 12:29:05 +01:00
|
|
|
你也可以使用其他类似的工具来干这个活(比如说 Makefile 或
|
|
|
|
[cargo-make](https://github.com/sagiegurari/cargo-make)),这里我仅介绍下我的用法以供参
|
|
|
|
考。
|
2024-01-11 04:17:05 +01:00
|
|
|
|
2024-01-11 05:44:43 +01:00
|
|
|
我的 Justfile 大概内容截取如下:
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-03-16 12:29:05 +01:00
|
|
|
> 我使用的 Justfile 最新版:
|
|
|
|
> [ryan4yin/nix-config/Justfile](https://github.com/ryan4yin/nix-config/blob/main/Justfile)
|
2024-01-11 05:44:43 +01:00
|
|
|
|
|
|
|
```Makefile
|
2024-01-11 04:17:05 +01:00
|
|
|
# just is a command runner, Justfile is very similar to Makefile, but simpler.
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
#
|
|
|
|
# Nix commands related to the local machine
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
deploy:
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild switch --flake . --use-remote-sudo
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
debug:
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild switch --flake . --use-remote-sudo --show-trace --verbose
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-01-11 06:30:33 +01:00
|
|
|
up:
|
2024-01-11 04:17:05 +01:00
|
|
|
nix flake update
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-01-11 06:30:33 +01:00
|
|
|
# Update specific input
|
|
|
|
# usage: make upp i=home-manager
|
|
|
|
upp:
|
|
|
|
nix flake lock --update-input $(i)
|
|
|
|
|
2023-06-23 16:22:13 +02:00
|
|
|
history:
|
2024-01-11 04:17:05 +01:00
|
|
|
nix profile history --profile /nix/var/nix/profiles/system
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-01-11 06:30:33 +01:00
|
|
|
repl:
|
|
|
|
nix repl -f flake:nixpkgs
|
|
|
|
|
|
|
|
clean:
|
2024-01-11 04:17:05 +01:00
|
|
|
# remove all generations older than 7 days
|
|
|
|
sudo nix profile wipe-history --profile /nix/var/nix/profiles/system --older-than 7d
|
2023-06-23 16:22:13 +02:00
|
|
|
|
2024-01-11 06:30:33 +01:00
|
|
|
gc:
|
2024-01-11 04:17:05 +01:00
|
|
|
# garbage collect all unused nix store entries
|
|
|
|
sudo nix store gc --debug
|
2024-01-11 06:30:33 +01:00
|
|
|
sudo nix-collect-garbage --delete-old
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
#
|
|
|
|
# Idols, Commands related to my remote distributed building cluster
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
add-idols-ssh-key:
|
2024-01-11 04:17:05 +01:00
|
|
|
ssh-add ~/.ssh/ai-idols
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
aqua: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#aquamarine --target-host aquamarine --build-host aquamarine switch --use-remote-sudo
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
aqua-debug: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#aquamarine --target-host aquamarine --build-host aquamarine switch --use-remote-sudo --show-trace --verbose
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
ruby: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#ruby --target-host ruby --build-host ruby switch --use-remote-sudo
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
ruby-debug: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#ruby --target-host ruby --build-host ruby switch --use-remote-sudo --show-trace --verbose
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
kana: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#kana --target-host kana --build-host kana switch --use-remote-sudo
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
kana-debug: add-idols-ssh-key
|
2024-01-11 04:17:05 +01:00
|
|
|
nixos-rebuild --flake .#kana --target-host kana --build-host kana switch --use-remote-sudo --show-trace --verbose
|
2023-06-23 16:22:13 +02:00
|
|
|
|
|
|
|
idols: aqua ruby kana
|
|
|
|
|
|
|
|
idols-debug: aqua-debug ruby-debug kana-debug
|
|
|
|
```
|
|
|
|
|
2024-03-16 12:29:05 +01:00
|
|
|
将上述 `Justfile` 文件存放到 NixOS 配置的根目录下,然后我们就可以使用 `just` 命令来执行相
|
|
|
|
关的命令了。比如说我这里 `just deploy` 就是部署 NixOS 配置到本地主机,`just idols` 就是部
|
|
|
|
署到我的远程主机集群。
|