Host Filters

Overview

The Host Filter Editor window

Host filters define a set of hosts by specifying any number of criteria. The set of hosts defined by a filter is dynamic: Changes made to the properties of hosts are automatically reflected in the hostlist a filter evaluates to. Every time a filter is used, the criteria defining it are evaluated from scratch. Hence, host filters provide a powerful tool to classify hosts into groups, in a way that will dynamically take into account changes made to the cluster. They can be used in various ways within QluMan:

Host Filter Editor

Selecting a filter for editing

The filter editor window is split into two areas. At the top, the definition of the currently selected filter is shown. You can select the filter to be displayed from the drop-down menu. At the bottom, the hosts that currently pass all the filters are displayed in the compact hostlist format. This format is used by a number of other programs including pdsh and SLURM (the pdsh Wiki has a detailed discussion on the syntax).

Adding a specific sub-filter

Creating a new host filter

Creating a new host filter

Select New filter from the drop-down menu to start defining a new filter. Then add specific sub-filters from the context menu, until the desired subset of hosts is displayed in the bottom half of the window. Using their context-menu, filters can be edited or removed and sub-filters be added.

Naming the filter

Saving the filter

The Reset filter menu item clears the filter, so one can start from scratch. To finally create (save) the new filter click Save as and enter a name for it.

Editing a Filter

Editing a filter is similar to creating a new one. First select the filter from the drop-down menu to display it’s current definition. Then add, edit or remove individual filters as desired. Finally click Save as to save the altered filter, Using an existing name will replace the old filter. Using a different name will create a new filter.

Types of Filters

Adding a specific sub-filter

A filter can be added from the context menu (right mouse click) in the top area. For a host to show up in the filtered list (bottom part), it must pass all the filters added. Each filter may narrow down the list. Any number of filters can be added and they do not have to be unique. For example you can add a Hostname filter that selects all hosts that begin with beo and a Host Template filter that selects all Demo VM nodes. A host has to pass all top-level filters to show up. Currently, QluMan provides six top-level filters: Hostname, HostTemplate, Enclosure, HEADNODE, HEADNODES and ONLINE. Additional ones will be added in the future.

Hostname Filter

The configured host sub-filter

Adding a host sub-filter

Defining the hostnames

Adding a Hostname filter opens up a pop-up dialog asking for the hostname or a regular expression to filter for. The input must be a regular expression in python syntax and is matched against the beginning of the hostname. If a match against the full hostname is desired then "$" should be added at the end. A ".*" can be added to the front, to match anywhere in the hostname instead of matching against the beginning.

Multiple hostname patterns can be added to a Hostname filter through the context menu. This is additive: If a host matches at least one pattern, it will be included in the resulting list.

Host Template Filter

Adding a specific Host Template

Adding a Host Template sub-filter

A new Host Template sub-filter

Adding a Host Template filter does not pop up a dialog. Instead it adds an empty Host Template filter. This simply selects all hosts with an assigned Host Template. Hosts that do not have a Host Template will not pass this filter. The filter can be made more specific by adding Host Template patterns to it through the context menu.

Final Host Template sub-filter

Selecting the Host Template

This opens up a pop-up dialog, from where an existing Host Template name can be selected. The result is a list of hosts, for which the associated Host Template matches the given pattern. Adding multiple Host Template names is again additive, just like with Hostname patterns.

Enclosure Filter

A new Enclosure sub-filter

Adding an Enclosure sub-filter

Adding an Enclosure filter does not bring up a dialog either. Like a Host Template filter, it selects all hosts that are part of an enclosure. Unlike the Hostname and Host Template filters though, an Enclosure filter allows for two different specifications: The name and/or the type of an enclosure can be matched. Just like Hostname and Host Template filters the Enclosure filter is additive.

Final Enclosure sub-filter

Filter on type or name

 Adding sub-filters for both the Enclosure name and the Enclosure type will filter hosts that
match at least one of those criteria. To filter for hosts that match both, an Enclosure name
and an Enclosure type, two separate Enclosure filters have to be used to get the intersection
of both filters. The first one to filter the name and the second one to filter the type.
Property/Config Set Filter

Add more sets

Final Set sub-filters

Filter on Set

The Host Template filter selects hosts that have a very specific config. On the other hand, the Generic/Hardware Property and Config Set filters allow filtering for just one branch of the overall configuration. They also work when a set is assigned via the Global Host Template or assigned directly to a host. Adding one of these filters opens up a pop-up dialog asking for the set to filter for.

Only the relevant set of a host is used to evaluate the filter. This set is (in this order) either a directly assigned one, the one of an assigned Host Template or if none of these are assigned, the one of the Global Host Template.

Multiple sets can be added to a Set filter via the context-menu. This is additive: If a host is assigned to any one of these sets, it will be included in the resulting list.

Property/Config Filter

Final Property / Config sub-filters with values

Add Property / Config value

Final Property / Config sub-filters

Filter on Property or Config

The Generic/Hardware Property and Config Filter allow filtering for even more selective configurations options. Adding one of these filters opens up a pop-up dialog asking for the type of property or config class to filter for. This will select hosts that have any value configured for the selected property or config class.

This can be further restricted to only filter for hosts that have set a specific value for the property or config class by selecting Add Value from the context menu.

A property or config class can be set from the Global Host Template, the Host Template, from a directly assigned set or a direct assignment. While some properties or config classes allow assigning multiple values, only the value(s) assigned from the relevant level take effect and are used for the filter.

Multiple values can be added to a Generic/Hardware Property or Config filter through the context-menu. This is additive: If a host has set any one of these values, it will be included in the resulting list.

Inverting a Filter

An inverted pattern

An inverted filter

Inverting the pattern or filter

Every filter, sub-filter and pattern can be inverted through the context menu. The context menu for a pattern contains menu entries for both, the pattern and the enclosing filter separated by a line. The first Invert entry will invert the specific pattern that was selected, while the second Invert will invert the whole filter.

Besides the obvious, this can also be useful in finding hosts that are not configured correctly. For example, adding an empty Host Template filter and inverting it, will show all hosts without a Host Template. Adding a second filter, that selects all switches, power controllers and other special devices (they usually don’t need a Host Template) and also inverting that, results in a list of all hosts, that are neither properly configured nodes (missing Host Template) nor special devices.

Additive versus subtractive

Subtractive hostname filters

When constructing a filter, it is important to remember, that all top-level filters are subtractive. A host must pass all top-level filters to show up in the result. On the other hand, all patterns and sub-filters are additive. Matching any one of them within a top-level filter adds the host to the result of that filter. Hence, when subtractive behavior is desired for patterns or sub-filters, each pattern or sub-filter must be added to its own top-level filter. For example, to select all hosts that start with beo as well as end on "1", two Hostname filters have to be added.

Using temporary Filters

Selecting a command with temporary filter

Execute and Selection buttons

A filter remains temporary unless it is saved. But it can already be used directly from the Filter Editor using the Execute or Selection buttons.

The Execute button is a shortcut to the Remote Execution Engine and will use the current filter results to fill in the Execute on part of the selected command.

Modifying selected hosts with temporary filter

Running command on filtered hosts

The Selection button allows modifying the selection of hosts in the Enclosure View. The selection can be set to the filter result itself, the filtered hosts can be added to or removed from an existing selection or the intersection of the filtered hosts and the current selection can be constructed.