As mentioned in the :doc:`Warewulf Configuration <configuration>`
section, node configs are persisted to the nodes.conf
YAML file,
but generally it is best not to edit this file directly (however that
is supported, it is just prone to errors).
This method of using a YAML configuration file as a backend datastore is both scalable and very lightweight. We've tested this out to over 10,000 node entries which yielded update latencies under 1 second, which we felt was both tolerable and advantageous.
Creating a new node is as simple as running the following command:
# wwctl node add n001 -I 10.0.2.1
Added node: n001
Several nodes can be added with a single command if a node range is given. An additional IP address will incremented. So the command
# wwctl node add n00[2-4] -I 10.0.2.2
Added node: n002
Added node: n003
Added node: n004
# wwctl node list -n n00[1-4]
NODE NAME NAME HWADDR IPADDR GATEWAY DEVICE
n001 default -- 10.0.2.1 -- (eth0)
n002 default -- 10.0.2.2 -- (eth0)
n003 default -- 10.0.2.3 -- (eth0)
n004 default -- 10.0.2.4 -- (eth0)
has added 4 nodes with the incremented IP addresses.
For small clusters, you can use simple names (e.g. n0000
); but for
larger, more complicated clusters that are comprised of multiple
clusters and roles it is highly recommended to use node names that
include a cluster descriptor. In Warewulf, this is generally done by
using a domain name (e.g. n001.cluster01
). Warewulf will
automatically assume that the domain is the equivalent of the cluster
name.
This also means that you can address groups of nodes by the cluster
descriptor with globs. For example, you are able to refer to all nodes
in "cluster01" with the following string: *.cluster01
which is
valuable for other wwctl
commands.
Once you have configured one or more nodes, you can list them and their attributes as follows:
# wwctl node list
NODE NAME PROFILES NETWORK
n001 default
You can also see the node's full attribute list by specifying the
-a
option (all):
# wwctl node list -a n001
NODE FIELD PROFILE VALUE
n001 Id -- n001
n001 comment default This profile is automatically included for each node
n001 cluster -- --
n001 image default sle-micro-5.3
n001 ipxe -- (default)
n001 runtime -- (hosts,ssh.authorized_keys,syncuser)
n001 wwinit -- (wwinit,wwclient,fstab,hostname,ssh.host_keys,issue,resolv,udev.netname,systemd.netname,ifcfg,NetworkManager,debian.interfaces,wicked,ignition)
n001 root -- (initramfs)
n001 discoverable -- --
n001 init -- (/sbin/init)
n001 asset -- --
n001 kernelargs -- (quiet crashkernel=no net.ifnames=1)
n001 ipmiaddr -- --
n001 ipminetmask -- --
n001 ipmiport -- --
n001 ipmigateway -- --
n001 ipmiuser -- --
n001 ipmipass -- --
n001 ipmiinterface -- --
n001 ipmiwrite -- --
n001 profile -- default
n001 default:type -- (ethernet)
n001 default:onboot -- --
n001 default:netdev -- (eth0)
n001 default:hwaddr -- --
n001 default:ipaddr -- 172.16.1.11
n001 default:ipaddr6 -- --
n001 default:netmask -- (255.255.255.0)
n001 default:gateway -- --
n001 default:mtu -- --
n001 default:primary -- true
Note
The attribute values in parenthesis are default values and can be overridden in the next section, granted, the default values are generally usable.
Node configurations are set using the wwctl node set
command. To
see a list of all configuration attributes, use the command wwctl
node set --help
.
# wwctl node set --image rocky-8 n001
Are you sure you want to modify 1 nodes(s): y
And you can check that the image name is set for n001
:
# wwctl node list -a n001 | grep Image
n0000 Image -- rocky-8
To configure the network, we have to pick a network device name and provide the network information as follows:
# wwctl node set --netdev eno1 --hwaddr 11:22:33:44:55:66 --ipaddr 10.0.2.1 --netmask 255.255.252.0 n001
Are you sure you want to modify 1 nodes(s): y
You can now see that the node contains configuration attributes for image and network:
# wwctl node list -a n001
NODE FIELD PROFILE VALUE
n001 Id -- n001
n001 comment default This profile is automatically included for each node
n001 cluster -- --
n001 image default sle-micro-5.3
n001 ipxe -- (default)
n001 runtime -- (hosts,ssh.authorized_keys,syncuser)
n001 wwinit -- (wwinit,wwclient,fstab,hostname,ssh.host_keys,issue,resolv,udev.netname,systemd.netname,ifcfg,NetworkManager,debian.interfaces,wicked,ignition)
n001 root -- (initramfs)
n001 discoverable -- --
n001 init -- (/sbin/init)
n001 asset -- --
n001 kernelargs -- (quiet crashkernel=no net.ifnames=1)
n001 ipmiaddr -- --
n001 ipminetmask -- --
n001 ipmiport -- --
n001 ipmigateway -- --
n001 ipmiuser -- --
n001 ipmipass -- --
n001 ipmiinterface -- --
n001 ipmiwrite -- --
n001 profile -- default
n001 default:type -- (ethernet)
n001 default:onboot -- --
n001 default:netdev -- eno1
n001 default:hwaddr -- 11:22:33:44:55:66
n001 default:ipaddr -- 10.0.2.1
n001 default:ipaddr6 -- --
n001 default:netmask -- 255.255.252.0
n001 default:gateway -- --
n001 default:mtu -- --
n001 default:primary -- true
# wwctl node set --cluster cluster01 n001
Are you sure you want to modify 1 nodes(s): y
# wwctl node list -a n001 | grep cluster
n001 cluster -- cluster01
Note
Due to the way network interface names are assigned by the Linux kernel and overwritten by udev and systemd in the default warewulf configuration, the use of eth0/1/... as interface names can lead to issues. We recommend the use of the original predictable names assigned to the interfaces (eno1, ...), as otherwise an interface may remain unconfigured if its name conflicts with the name of an already existing interface during boot.
Additional networks for the node can also be configured. You will have provide all the necessary network information.
wwctl node set \
--netdev ib0 \
--hwaddr aa:bb:cc:dd:ee:ff \
--ipaddr 10.0.20.1 \
--netmask 255.255.252.0 \
--netname iband \
--type infiniband \
n001
Support for bonded / link aggregation network interfaces depends on the network overlay being used.
The ifcfg
and NetworkManager
overlays can configure a network bond like this:
network devices:
bond0:
type: Bond
device: bond0
ipaddr: 192.168.3.100
netmask: 255.255.255.0
en1:
device: en1
hwaddr: e6:92:39:49:7b:03
tags:
master: bond0
en2:
device: en2
hwaddr: 9a:77:29:73:14:f1
tags:
master: bond0
You can set the type also to vlan
.
Some network configuration systems use the network device name
(e.g., of the form eno1.100
)
to configure VLANs.
Other network systems need additional network tags:
vlan_id
: configures the VLAN ID of the interfaceparent_device
: configures which physical interface to use
wwctl node set \
--netdev vlan42 \
--ipaddr 10.0.42.1 \
--netmask 255.255.252.0 \
--netname iband \
--type vlan \
--nettagadd "vlan_id=42,parent_device=eth0" \
n001
The included Warewulf network overlays support the configuration of static routes
using a network tag of the form route<N>=<dest>,<gateway>
.
wwctl node set n001 \
--nettagadd "route1=192.168.2.0/24,192.168.1.254"
The hwaddr of a node can be automatically discovered by setting
--discoverable
on a node. If a node attempts to provision against
Warewulf using an interface that is unknown to Warewulf, that address
is associated with the first discoverable node. (Multiple discoverable
nodes are sorted lexically, first by cluster, then by ID.)
Once a node has been discovered its "discoverable" flag is automatically cleared.
If you wish to unset
a particular value, set the value to
UNDEF
. For example:
And to unset this configuration attribute:
# wwctl node set --cluster UNDEF n001
Are you sure you want to modify 1 nodes(s): y
# wwctl node list -a n001 | grep Cluster
n001 Cluster -- --
Warewulf nodes (and profiles) support generic "resources" that may hold arbitrarily complex YAML data. This data, along with tags, may be used by both distribution and site overlays.
nodeprofiles:
default:
resources:
fstab:
- spec: warewulf:/home
file: /home
vfstype: nfs
mntops: defaults
freq: 0
passno: 0
- spec: warewulf:/opt
file: /opt
vfstype: nfs
mntops: defaults,ro
freq: 0
passno: 0
Due to the arbitrary nature of generic resource data, it can only be managed with wwctl <node|profile> edit.