2023-01-29 01:07:26 +01:00
|
|
|
.Dd January 1, 1980
|
2023-02-22 16:30:04 +01:00
|
|
|
.Dt nixos-build-vms 8
|
|
|
|
.Os
|
2023-01-29 01:07:26 +01:00
|
|
|
.Sh NAME
|
|
|
|
.Nm nixos-build-vms
|
|
|
|
.Nd build a network of virtual machines from a network of NixOS configurations
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm nixos-build-vms
|
|
|
|
.Op Fl -show-trace
|
|
|
|
.Op Fl -no-out-link
|
|
|
|
.Op Fl -help
|
|
|
|
.Op Fl -option Ar name value
|
|
|
|
.Pa network.nix
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
.
|
|
|
|
This command builds a network of QEMU\-KVM virtual machines of a Nix expression
|
|
|
|
specifying a network of NixOS machines. The virtual network can be started by
|
|
|
|
executing the
|
|
|
|
.Pa bin/run-vms
|
|
|
|
shell script that is generated by this command. By default, a
|
|
|
|
.Pa result
|
|
|
|
symlink is produced that points to the generated virtual network.
|
|
|
|
.
|
|
|
|
.Pp
|
|
|
|
A network Nix expression has the following structure:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
{
|
|
|
|
test1 = {pkgs, config, ...}:
|
|
|
|
{
|
|
|
|
services.openssh.enable = true;
|
|
|
|
nixpkgs.localSystem.system = "i686-linux";
|
|
|
|
deployment.targetHost = "test1.example.net";
|
|
|
|
|
|
|
|
# Other NixOS options
|
|
|
|
};
|
|
|
|
|
|
|
|
test2 = {pkgs, config, ...}:
|
|
|
|
{
|
|
|
|
services.openssh.enable = true;
|
|
|
|
services.httpd.enable = true;
|
|
|
|
environment.systemPackages = [ pkgs.lynx ];
|
|
|
|
nixpkgs.localSystem.system = "x86_64-linux";
|
|
|
|
deployment.targetHost = "test2.example.net";
|
|
|
|
|
|
|
|
# Other NixOS options
|
|
|
|
};
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.
|
|
|
|
.Pp
|
|
|
|
Each attribute in the expression represents a machine in the network
|
|
|
|
.Ns (e.g.
|
|
|
|
.Va test1
|
|
|
|
and
|
|
|
|
.Va test2 Ns
|
|
|
|
) referring to a function defining a NixOS configuration. In each NixOS
|
|
|
|
configuration, two attributes have a special meaning. The
|
|
|
|
.Va deployment.targetHost
|
|
|
|
specifies the address (domain name or IP address) of the system which is used by
|
|
|
|
.Ic ssh
|
|
|
|
to perform remote deployment operations. The
|
|
|
|
.Va nixpkgs.localSystem.system
|
|
|
|
attribute can be used to specify an architecture for the target machine, such as
|
|
|
|
.Ql i686-linux
|
|
|
|
which builds a 32-bit NixOS configuration. Omitting this property will build the
|
|
|
|
configuration for the same architecture as the host system.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.Sh OPTIONS
|
|
|
|
.Bl -tag -width indent
|
|
|
|
.It Fl -show-trace
|
|
|
|
Shows a trace of the output.
|
|
|
|
.
|
|
|
|
.It Fl -no-out-link
|
|
|
|
Do not create a
|
|
|
|
.Pa result
|
|
|
|
symlink.
|
|
|
|
.
|
|
|
|
.It Fl h , -help
|
|
|
|
Shows the usage of this command to the user.
|
|
|
|
.
|
|
|
|
.It Fl -option Ar name Va value
|
|
|
|
Set the Nix configuration option
|
|
|
|
.Va name
|
|
|
|
to
|
|
|
|
.Va value Ns
|
|
|
|
\&. This overrides settings in the Nix configuration file (see
|
|
|
|
.Xr nix.conf 5 Ns
|
|
|
|
).
|
|
|
|
.El
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.Sh AUTHORS
|
|
|
|
.An -nosplit
|
|
|
|
.An Eelco Dolstra
|
|
|
|
and
|
|
|
|
.An the Nixpkgs/NixOS contributors
|