Skip to content

Latest commit

 

History

History
284 lines (185 loc) · 14.7 KB

README.md

File metadata and controls

284 lines (185 loc) · 14.7 KB

geneos

The geneos program will help you manage your Geneos environment.

The reference documentation, included in the program as help text, for all commands and their options is here

Important

geneos is currently unable to manage ARM 64 releases as seen with Geneos 7.1. There is also a chance that installation or upgrade of existing gateway and licd packages on RHEL9 (only) could result in an aarch64 package being installed. We are working on ensuring this is not possible and will release a patch ASAP.

Aims

Features

  • Initialise a new installation with a single command
  • Download, install and update Geneos software
  • Adopt an existing installation created using older tools
  • Operate Geneos across a group of servers with a single command
  • Manage certificates for Secure Connections (TLS) between Geneos components
  • Create Geneos compatible AES256 encoded passwords and manage other credentials
  • Change instance settings from the command line
  • Simple installation of Self-Announcing and Floating Netprobes

Getting Started

First download the latest binary to your user's bin directory and make it executable

mkdir -p ${HOME}/bin && cd ${HOME}/bin
curl -OL https://github.com/ITRS-Group/cordial/releases/latest/download/geneos
chmod +x ./geneos

You can also build from source. For more details see the Installation documentation.

If you are on a system (or in a container) without an existing Geneos installation and with Internet access, you can try this:

geneos init demo -u email@example.com

You will be prompted for your download password and then, after a short while, you will have a running Geneos Demo environment.

💡 Replace email@example.com with your registered email for downloading ITRS software. If you need to register go here

Adopting An Existing Installation

If you have a running Geneos environment and you currently use older ITRS tools like gatewayctl and netprobectl to manage it, then you can start using the new geneos program straight away. There are a couple of options, but the simplest is to tell geneos where the existing Geneos installation is:

geneos config set geneos=/path/to/geneos

The path you need to use above is the one with the bin directory that contains the existing gatewayctl etc., typically /opt/itrs or /home/geneos. If you happen to have an environment variable ITRS_HOME already set then you can skip the above step altogether. You can just try listing existing Geneos instances like this, without any risk of changes:

geneos list

If this works then you are all set.

Legacy Command Emulation

To help you migrate from older tools to geneos, the program will emulate the syntax of the older command (with some restrictions, such as no create command emulation) if invoked using the same names. This allows your users or existing automations to continue to work as before.

To back-up your old scripts and create the links to the new geneos program just run:

geneos migrate -X    # mnemonic: -X means "executables"

This will rename any *ctl programs for Geneos components to an .orig suffix and then create symbolic links to the current location of the geneos program.

To reverse this simply run:

geneos revert -X

This works by taking the first part of the executable name and mapping it to the component type, so for example a legacy command TYPEctl NAME COMMAND becomes geneos COMMAND TYPE NAME, e.g. gatewayctl all start is translated to geneos start gateway all.

The word all instead of a specific instance name is supported as per the original shell scripts.

Command Structure

For typical commands the command line will look something like this:

geneos COMMAND [flags] [TYPE] [NAMES...]

  • COMMAND is the one or two word name of the command
  • flags are dash or double-dash prefixed options. Many of these options will require arguments and the details for each command will be in the help text.
  • TYPE is the optional component type
  • NAMES is an optional list of instance names. They can have an optional @HOST suffix which restricts the match to only the configured HOST.

The overall goal when choosing command names and their flags/options has been to make things more intuitive, rather than less. This is not always possible and so some options will be different between commands while performing the same task; One examples is the -f (follow) flags for logs which has similar functionality to the -l (logs) flag for init commands.

Concepts & Terminology

We assumes some familiarity with the ITRS Geneos product family. Please take the time to review the Geneos Architecture documentation.

Many of the terms used by the geneos program have been inherited from earlier systems and may not be as intuitive as we would like.

Components

A Component is a stand-alone software release that forms one part of the ITRS Geneos product.

The currently supported Component types are listed in Recognised Component Types.

A Component can also refer to a specific variety of another parent Component type. The most common one is a Self-Announcing Netprobe which can be a variety of Netprobe or Fix Analyser 2 Netprobe.

Components are normally referred to as a TYPE in command help and documentation.

Components (more specifically the software releases that they are made up of) are managed through the package sub-system.

Instances

An Instance is a runnable copy of a Component. An Instance is made up of a working directory, a configuration file and other related files. The geneos utility uses these to manage the lifecycle of a Component independently of other Instances of the same Component TYPE.

Instances are referred to as NAME in the command help and documentation.

Each Instance must have a unique, case-insensitive, name for that Component TYPE and on that HOST (see below) and must not be one of the reserved names.

Reserved name are those that would be ambiguous on the command line and include Component names and the aliases, command names and their aliases and some special terms (such as all or any).

An Instance name can have a suffix that refers to the HOST it is located on in the form NAME@HOST. If not specified then commands will apply to all Instances of NAME across all hosts.

Hosts

A Host is the location that components are installed and can be managed. There is always a localhost. There is also a special all host keyword that is implied when no specific host is specified.

Normally commands will apply to all Hosts. Operations can be limited using the global option --host/-H for most commands.

Hosts are managed through the hosts sub-system.

Instance Protection

Individual instances can be protected again being stopped or deleted by setting the protected parameter.

geneos protect gateway IMPORTANT_GW

This also applies to any command that stops an instance, such as the more obvious ones like restart but also disable and others. The copy command, because it must be given the name for a source, does not check this setting. For most commands that check the protection setting before running there is a --force flag to override the protection. The delete command already requires that an instance be disabled or must be called with the --force flag.

If you run geneos delete -H HOSTNAME with the --stop flag to stop instance on the remote host first, then the protected settings is also checked and the command will terminate on the first error. This does however mean that unprotected instances on that host may have been stopped in the meantime.

The update command will not run if any protected instance is using the base link that would be updated.

Instance Settings

Every instance has a configuration file stored in it's directory. This is the most basic requirement for an instance. New instances that you create will have a configuration file named after the component type plus the file type extension .json. Older instances which you have adopted from previous scripts will have a configuration file with the extension .rc

JSON Configuration Files

The .json configuration files share common parameters as well as component type specific settings. For simplicity some of these parameters have different meanings depending on the component type they apply to.

While editing the configuration files directly is possible, it is best to use the set and unset commands to ensure the syntax is correct.

Special parameters

All instances support custom environment variables being set or unset. This is done through the set and unset commands.

Some component types, Gateways, SANs and Floating Netprobes, support other special parameters through options to the various commands that create or edit instance configurations. See the help text for the set and unset commands for more details as well as add and the init subsystem.

To set an environment variable use this syntax:

geneos set netprobe example1 -e PATH_TO_SOMETHING=/file/path

If an entry already exists it is overwritten.

To remove an entry, use unset, like this

geneos unset netprobe example1 -e PATH_TO_SOMETHING

You can specify multiple entries by using the flag more than once:

geneos set netprobe example1 -e JAVA_HOME=/path -e ORACLE_HOME=/path2

If the value of the environment variable contains spaces then use quotes to prevent those spaces being caught by the shell. In bash you can do any of these to achieve the same result:

geneos set netprobe example1 -e MYVAR="a string with spaces"
geneos set netprobe example1 -e "MYVAR=a string with spaces"

You can review the environment for any instance using the show command:

geneos show netprobe example1

Also, output is available from the command command to show what would be run when calling the start command:

geneos command netprobe example1

Other special parameters behave in similar ways. Please see the command documentation for details.

File and URLs

Most configuration file values support URLs, e.g. importing certificate and keys, license files, etc.

The primary exception is for Gateway include files used in templated configurations. If these are given as URLs then they are used in the configuration as URLs.

Legacy Configuration Files

Historical (i.e. legacy) .rc files have a simple format like this:

GatePort=1234
GateUser=geneos

Where the prefix (here: Gate) also implies the component type and the suffix (Port) is the parameter. Any lines that do not contain the prefix are treated as environment variables and are evaluated and passed to the program on start-up. Parameter values that contain environment variables in the format ${HOME} will be expanded at run time. If the configuration is migrated, either through an explicit geneos migrate command or if a setting is changes through geneos set or similar then the value of the environment variable will be carried over and continue to be expanded at run-time. The geneos show command can be passed a --raw flag to show the unexpanded values, if any.

While the geneos program can parse and understand the legacy .rc files above it will never update them, instead migrating them to their .json equivalents either when required or when explicitly told to using the migrate command.

For compatibility with earlier tools, the per-component configurations are loaded from .rc files in the working directory of each component. The configuration names are also based on the original names, hence they can be obscure. the migrate command allows for the conversion of the .rc file to a JSON format one, the original .rc file being renamed to end .rc.orig and allowing the revert command to restore the original (without subsequent changes).

If you want to change settings you should first migrate the configuration and then use set to make changes.

Note that execution mode (e.g. GateMode) is not supported and all components run in the background.

Instance Configuration File

These configuration files - in JSON format - should be found in sub-directories under the geneos base directory (typiocally /opt/itrs, /opt/itrs/geneos or /opt/geneos) as GENEOS_BASE_DIRECTORY/TYPE/TYPEs/INSTANCE/TYPE.json where:

  • GENEOS_BASE_DIRECTORY is the base directory for geneos.
  • TYPE is the component type (licd, gateway, netprobe, san, fa2, fileagent or webservcer).
  • TYPEs is the component type followed by the letter "s" (lowercase) to indicate a plural.
  • INSTANCE is the instance name.
  • TYPE.json is a the file name (e.g. licd.json, gateway.json, etc.).]

Directory Layout

%%{ init: { 'theme': 'neutral', 'flowchart': { 'curve': 'basis' } } }%%
flowchart LR
  root[.]
  root ---> Packages
    subgraph Packages
      direction LR
      packages ---> packages/downloads[downloads]
      packages ---> packages/gateway[gateway]
      packages ---> packages/netprobe[netprobe]
      packages ---> packages/licd[licd]
      packages ---> packages/webserver[webserver]
    end
    click packages href "https://www.itrsgroup.com"
  root ---> Gateways
    subgraph Gateways
      direction LR
      gateway ----> gateway/gateways[gateways]
      gateway ---> gateway_shared & gateway_config & gateway/templates[templates]
        gateway/gateways ---> gateway/gateways/example1[example1]
        gateway/gateways ---> gateway/gateways/example2[example2]
        gateway/gateways ---> gateway/gateways/example3[...]
    end
  root ---> Netprobes
    subgraph Netprobes
      direction LR
      netprobe ----> netprobe/netprobes[netprobes]
      netprobe ----> netprobe/sans[sans]
      netprobe ---> netprobe_shared & netprobe_config & netprobe/templates[templates]
        netprobe/netprobes ---> netprobe/netprobes/example1[example1]
        netprobe/netprobes ---> netprobe/netprobes/example2[example2]
        netprobe/netprobes ---> netprobe/netprobes/example3[...]
        netprobe/sans ---> netprobe/sans/example1[example1]
        netprobe/sans ---> netprobe/sans/example2[example2]
        netprobe/sans ---> netprobe/sans/example3[...]
    end
Loading