Gateway Installation Guide
Overview Copied
This document describes the prerequisites for a Geneos Gateway, how to install and how to start using a Gateway.
For information describing the features of a Gateway, see Gateway Introduction. For more information on configuring Gateway, see Centralised Gateways User Guide.
Prerequisites Copied
Gateway System Requirements Copied
When Security-Enhanced Linux (SELinux) is running in Enforcing mode, it may deny certain functions of Geneos depending on the implemented configurations and policies.
To see which functions SELinux denies, check the audit log. The log is typically located in /var/log/audit.log, where the log type entry is AVC. The audit log provides the details of any denied access. For example, denied connection to the TCP port.
If you experience issues related to this mode, you may opt to disable SELinux, or create policy modules to grant the required access. Please contact your administrator or security team for assistance.
| Prerequisite | Description | 
|---|---|
| Gateway Machine | OS: RedHat Linux
											(Preferred), Suse Linux CPU: Dual CPU, Dual Core
										 Memory: 8GB
											(64-bit)
										 Network: 1 Network Card or
											2 bonded Network cards (100 mbps)
										 Disk: 500 MB* software
											only, does not include database table space
										 Hardware: Virtual or
											Physical
										 | 
| SSH Access | SSH access to the Gateway server is required for initial installation and configuration of the Geneos software. | 
| SCP Access | The Geneos software is installed in a nominated directory (/opt/geneos) or a user's home directory. This should be a common directory across all machines. SCP access to each server and directory is required to copy the Gateway binaries. | 
| Port 7039 | Default port for communication between the Gateway server and Active Console. | 
| SendMail | In order to perform actions such as e-mail alerts the Gateway server requires a sendmail daemon to be running so that outgoing messages can be properly routed. | 
When Security-Enhanced Linux (SELinux) is running in Enforcing mode, it may deny certain functions of Geneos depending on the implemented configurations and policies.
To see which functions SELinux denies, check the audit log. The log is typically located in /var/log/audit.log, where the log type entry is AVC. The audit log provides the details of any denied access. For example, denied connection to the TCP port.
If you experience issues related to this mode, you may opt to disable SELinux, or create policy modules to grant the required access. Please contact your administrator or security team for assistance.
Gateway licensing Copied
For the Gateway to function, an appropriate licensing method must be in place.
See Gateway Licensing.
Prerequisite considerations Copied
Beginning Geneos version 5.0.0, this component is only compatible with other Geneos components that are version 3.6.0 or higher. For more information, see the Geneos Compatibility Matrix.
Installation directory Copied
The Gateway files are installed into a directory. For new installations the following directory is recommended:
/usr/local/geneos/gateway
Port numbers Copied
Each installed Gateway must have a unique port to listen for client connections. The default gateway ports are:
- 7039for insecure channel.
- 7038for secure channel.
If these ports are unavailable or you are hosting multiple Gateways on a single machine, then you need to select available unique ports for the Gateway. See operatingEnvironment > listenPorts.
Gateway name Copied
Each installed Gateway must have a unique name. The name is important as it is used when selecting data and defining rules. Select a unique name that can be used to identify this Gateway’s purpose within your organisation.
Note
Changing the Gateway name once monitoring has begun is not recommended. You must select a suitable name from the outset.
Select log file and setup directories Copied
The Gateway generates a log file and requires at least one master setup file per running instance. As it is common to have multiple Gateway instances running on a single host, it is useful to organise these files.
Geneos can accommodate if your organisation has specific guidelines as to where configuration and log files must reside.
See Gateway Log File, Centralised Gateways User Guide.
Gateway resources Copied
The Gateway is shipped with a set of xslt resource files and a timezone file. The resources directory, or a symbolic link to it, must exist in the working directory of the Gateway at startup time because these files are part of the runtime source code.
The files should not be edited by users and doing so may result in unexpected behaviour. When a Gateway binary is upgraded the resource files must also be upgraded to the version supplied with the new Gateway.
The Gateway time zone resources file is also available separately as a package from ITRS Resources. The package contains the time zone file and a README file with installation instructions.
Procedure Copied
This section describes how to install a Gateway up to the point where the setup can be edited by a connected Gateway Setup Editor.
How to download and unpack Gateway Copied
Ensure you have machine set up with the prerequisites before installing the Gateway.
To download and unpack the Gateway Hub on to your installation machine, follow these steps:
- Download the Gateway binaries from the ITRS group website:
- The binaries are named geneos-gateway-<version number>.<platform>.tar.gz.
- Move the Gateway .tar.gz file into the desired installation directory.
- Unpack the Gateway binary using the command line.
- The binary contains the following:
| File | Description | 
|---|---|
| gateway2.<platform> | Executable binary file for the Gateway process | 
| kafkacat | See kafkacat in Gateway Publishing to Kafka and Nanomsg. | 
| lib64 | Contains required libraries. | 
| LICENCE | |
| LICENCE_README.txt | |
| NOTICES | |
| resources | Contains resources files for this version. | 
| templates | Contains template start up and files and scripts. | 
How to create a start script for Gateway Copied
- 
Copy gateway.setup.xml.tmplfrom thetemplates/folder to the working directory.
- 
Rename the copy of gateway.setup.xml.tmpltogateway.setup.xml.
- 
Edit gateway.setup.xmlto add a Gateway name: ```xmlexampleGatewayName 7039 
- 
Copy start_gateway2.tmplfrom thetemplates/folder to the working directory.
- 
Rename the copy of start_gateway2.tmpltostart_gateway2.
- 
Edit start_gateway2so that the Gateway runs in the background: ``` ### Run the gateway in the foreground #./gateway2.linux_64 ${SECURE_PARAMS}### Run the gateway in the background with logging nohup ./gateway2.linux\_64 ${SECURE_PARAMS} -log gateway2.log & ```
See Command line options for other command line options when starting the Gateway.
How to start and configure the Gateway Copied
- Run the start_gateway2script to start the Gateway process.
- Connect an Active Console to the Gateway.
- Open the Gateway Setup Editor.
You can now start adding monitoring configuration via the Gateway Setup Editor.
How to upgrade to a new Gateway version Copied
To upgrade to a later Gateway binary from an existing installation:
- Stop the current Gateway process.
- Copy the new binary and resources files into the installation directory.
- Restart the Gateway process.
Command line options Copied
The Gateway can be started with command line options. These options can be entered on the command line or read from a file.
By default, the Gateway attempts to read command line options from a file called gateway2.gci in the Gateway’s working directory. This file is not supplied with the Gateway and you must create it yourself. For example:
-<command line option>
-<command line option> <argument>
Alternatively, you can specify the file for the Gateway to read using the -config-file command line option.
Command line options in the file are processed before any on the command line, except for -config-file which is always processed first.
The following command line options are available:
| Option | Use | ||||||
|---|---|---|---|---|---|---|---|
| -app-key | Specifies the path to the file that contains the API key used to connect securely to SSO Agent, Gateway Hub, or Obcerv. For more information about using an API key, SSO Agent User Guide and Application Keys. | ||||||
| -ase256-encrypt
 | This option relates to storing passwords in the Gateway setup. It is explained in Secure Passwords. | ||||||
| -autolock | Forces a GSE connected to the Gateway to lock setup files (or include files) if a user wants to update them. Other connected GSEs are notified when a lock on a file becomes available and will have a chance to lock it. If GSE's are connected to different gateways that share an include file, they are only be prevented from updating the include file at the same time. For more information, see Autolock. | ||||||
| -config-file <path> |  Path to configuration file containing command line options. By default, the Gateway attempts to read from a file called  Command line options in the file are processed before any on the command line, except for  | ||||||
| -demo | Run the Gateway in a demo mode, without a license daemon, to trial the software. For more information, see Demo mode in Gateway Licensing. | ||||||
| -display-timezone-defaults | Prints the default timezone for timezone abbreviations by reading the timezone resources file. The defaults are mentioned in Time Zones and Time Formats. and marked with asterisk(*). | ||||||
| -dump-xml | Print the contents of the merged
						xml tree (Gateway setup) to the log file or stdout,
						then exit. Can be used with  The merged nodes have an additional attribute to
						specify which setup file this node came from. A node
						coming from main file has the attribute  This mode is intended for testing/debugging purposes. | ||||||
| -en
 | This option relates to storing passwords in the Gateway setup. It is explained in Secure Passwords. | ||||||
| -gateway-hub <URL> | URL of the Gateway Hub. Only one URL is supported. Example:  If provided, this takes precedence over the REST address provided in the Gateway Hub section in the GSE. See Gateway Hub Connection. | ||||||
| -gateway-hub-timeout | Number of seconds that the Gateway waits for a response from Gateway Hub after sending a validation or save request before timing out. The request may time out if the Gateway Hub is responding to other requests. Default value: 5 seconds. See Centralised Gateways User Guide for more information. | ||||||
| -gateway-name <name> | Name of the Gateway setup. If no setup file is specified, then Gateway fetches the named setup from Gateway Hub. See Centralised Gateways User Guide for more information. However, if a local setup file is specified then the Gateway starts using that setup and with the name specified on the command line. If the setup file specifies a Gateway name, it must match the name specified using the  If the  | ||||||
| -help [topic] | Displays help about the topic if specified, or this help message. Topic can be any of the parameters shown below. | ||||||
| -hooks-dir <resource-dir> | Specifies the location of the hooks directory. This directory contains the user defined hooks that are run at setup validation and after a setup change is applied by the Gateway. See Gateway Hooks. | ||||||
| -hooks-timeout | Changes the hooks timeout from the default of 2 minutes to the value specified. Values greater than the default result in a warning that Gateway performance may be degraded. See Gateway Hooks. | ||||||
| -kerberos-keytab <path> | Path to the keytab file. The principal must also be specified. | ||||||
| -kerberos-principal <principal> | A unique identity that Kerberos can assign tickets to. Examples:  | ||||||
| 
 | Specify a key file to encrypt all the AES passwords in your Gateway setup. For more information, see Secure Passwords. | ||||||
| -licence | Specifies the location of the temporary licence file that the Gateway uses in absence of a Licence Daemon. | ||||||
| -licd-host | Specifies the host name or IP address of the Licence Daemon the Gateway uses when requesting licences. Default:  | ||||||
| -licd-port | Specifies the port where the Licence Daemon is listening on. Default is 7041. | ||||||
| -licd-secure | Specifies that the Gateway connects to the Licence Daemon using TLS. If this is not used then an insecure protocol is used to transfer licences from the Licence Daemon to the Gateway. The Gateway and Licence Daemon must be identically configured. | ||||||
| -log <logfile> | -nolog | Used to specify the name of the Gateway log file. The  Running the Gateway with the  The Gateway sends its output to stdout if this option is not set. | ||||||
| -manual-failback | Prevents a primary Gateway from automatically taking over from a secondary Gateway upon restart. A Gateway command is available on the secondary Gateway to return control to the primary. This allows you to restart your Gateway and transfer control at a convenient time. Both Gateways must be started with this option to enable manual failback functionality. For more information, see Manual failback in Hot Standby. | ||||||
| -max-severity <none|warn|error> | Used to specify the maximum allowable setup severity. The maximum severity controls whether the Gateway allows a setup to be applied. For example, if the maximum severity is set to warn, and the setup file contains problems with a severity of warning or less, then the setup is applied, otherwise it is rejected. Possible severity settings are: 
 Default if not specified:  | ||||||
| -minTLSversion | Specifies the minimum TLS version. The accepted values are: 
 For more details, see Secure Communications. | ||||||
| -iax <URL> | URL of Obcerv. Required when using Centralised Configuration in Obcerv. Example:  | ||||||
| -iax-timeout | Number of seconds that the Gateway waits for a response from Obcerv after sending a validation or save request before timing out. The request may time out if Obcerv is responding to other requests. Default value: 5 seconds | ||||||
| -openssl-cipher <ciphers> | To set the available TLS ciphers use the `-openssl-cipher For more information, see TLS ciphers in Secure Communications. | ||||||
| -port <number> | Used to specify the port the Gateway listens on for other components. The option must be followed by the listen port, a positive integer in the range 1-65535 inclusive. Note: On some systems ports in the range 1-1024 are reserved, and the Gateway requires special permissions to listen on a port in this range. If  
 If only the secure listen port is configured in the
Gateway setup file, then  If only insecure listen port is
configured in the Gateway setup file, then  If both secure and
insecure listen ports are configured in the Gateway
setup file, then  Note: If you specified a port using  | ||||||
| -previous-key-file | Specify a fallback keyfile to encrypt AES passowrds. Allows Gateway to use two keys while you transition to a new key. For more information, see Secure Passwords | ||||||
| -process-dump-files | Starts a process to read all the database dump files that have been created by the Gateway and inserts them into the database. See Database dump files section. | ||||||
| -pw | This option relates to storing passwords in the Gateway setup. It is explained in Secure Passwords. | ||||||
| -resources-dir <resource-dir> | Specifies the location of the resource directory. This directory is provided as part of the Gateway package. By default it is the directory resources in the current working directory of the Gateway. If running multiple Gateways in multiple working directories from the same package, this is option can be used to provide access to the shared resource. | ||||||
| -roll-time <HH:MM> | Sets a predetermined file rollover time for the Gateway log file. When set, the log file roll over occurs when the first log message comes in after the requested rollover time. The format must be  | ||||||
| -setup <filename> | Used to specify the setup file Gateway should use. The option must be followed by the filename, which should not start with a - (dash) character. If  | ||||||
| -setup-comments <none|optional|required> | Controls if the Gateway Setup Editor (GSE) asks for comments when you change the setup file. There are three options: 
 Default if not specified:  | ||||||
| -skip-cache | Loads setup from files on disk instead of cache even if some setups are inactive (outside their active time). The cache contains setup files that the Gateway was running before shutdown. | ||||||
| -sso-agent <URL> | URL of the SSO Agent that is providing an SSO Token to use with Gateway Hub. This is only required if you are not using the SSO Agent on the default port of the Gateway Hub. See Centralised Gateways User Guide for more information. | ||||||
| -ssl-certificate | Specifies the file that contains the signed SSL server certificate in PEM (Privacy-enhanced Electronic Mail) format. | ||||||
| -ssl-certificate-chain | Specifies the file that contains the trusted certificate authority. | ||||||
| -ssl-certificate-key | Specifies the file that contains the
signed SSL server private key in PEM (Privacy-enhanced
Electronic Mail) format. If this is option is not
specified, but  | ||||||
| -stats | Enables Gateway load monitoring statistics collection from start-up. This flag can be useful in diagnosing gateway performance issues only seen on start-up, rather than those occurring during normal gateway operation. | ||||||
| -store-app-key | Generates an API key file from a provided  The command uses the format  For more information about using an API key, see Connect securely using SSO or API keys, SSO Agent User Guide, Gateway Hub SSO Agent , and Application Keys . | ||||||
| -validate | Used to validate setup files without
using ActiveConsole. It performs Gateway validation, see Validation types for more information. By default it validates the
default Gateway setup file  
 Returns: 
 | ||||||
| -validate-json-output <filename> | This option (which implicitly selects the
 | ||||||
| -v, -version | Used to display version information for the Gateway. It contains information about the exact version of the Gateway and all the libraries contained within. | 
Required libraries Copied
Required libraries Copied
RHEL 9 Copied
| Library Name | Package Name | 
|---|---|
| libcrypto.so.3 | openssl-libs | 
| libnsl.so.3 | libnsl2 | 
| libcrypt.so.2 | libxcrypt | 
| libresolv.so.2 | glibc | 
| libz.so.1 | zlib | 
| libstdc+.so.6 | libstdc+ | 
| libm.so.6 | glibc | 
| libgcc_s.so.1 | libgcc | 
| libc.so.6 | glibc | 
| libtirpc.so.3 | libtirpc | 
| libgssapi_krb5.so.2 | krb5-libs | 
| libkrb5.so.3 | krb5-libs | 
| libk5crypto.so.3 | krb5-libs | 
| libcom_err.so.2 | libcom_err | 
| libkrb5support.so.0 | krb5-libs | 
| libkeyutils.so.1 | keyutils-libs | 
| libselinux.so.1 | libselinux | 
| libpcre2 | pcre2 | 
| libcurl | libcurl | 
RHEL 8 Copied
| Library Name | Package Name | 
|---|---|
| libcrypto.so.3 | openssl-libs | 
| libnsl.so.3 | libnsl2 | 
| libcrypt.so.2 | libxcrypt | 
| libresolv.so.2 | glibc | 
| libz.so.1 | zlib | 
| libstdc+.so.6 | libstdc+ | 
| libm.so.6 | glibc | 
| libgcc_s.so.1 | libgcc | 
| libc.so.6 | glibc | 
| libtirpc.so.3 | libtirpc | 
| libgssapi_krb5.so.2 | krb5-libs | 
| libkrb5.so.3 | krb5-libs | 
| libk5crypto.so.3 | krb5-libs | 
| libcom_err.so.2 | libcom_err | 
| libkrb5support.so.0 | krb5-libs | 
| libkeyutils.so.1 | keyutils-libs | 
| libselinux.so.1 | libselinux | 
| libpcre2 | pcre2 | 
| libcurl | libcurl | 
SUSE 12 and 15 (64-bit) Copied
| Library Name | Package Name | 
|---|---|
| libutil.so.1 | glibc | 
| libnsl.so.1 | glibc or libnsl-2 on RHEL 8 and CentOS 8 | 
| libpthread.so.0 | glibc | 
| libdl.so.2 | glibc | 
| libcrypt.so.1 | glibc | 
| libresolv.so.2 | glibc | 
| librt.so.1 | glibc | 
| libm.so.6 | glibc | 
| libc.so.6 | glibc | 
| ld-linux.so.2 | glibc | 
| libz.so.1 | libz1 | 
| libstdc++.so.6 | libstdc++ | 
| libgcc_s.so.1 | libgcc-4 | 
Ubuntu 18 Copied
| Library Name | Package Name | 
|---|---|
| libutil.so.1 | libc6 | 
| libnsl.so.1 | libc6 | 
| libpthread.so.0 | libc6 | 
| libdl.so.2 | libc6 | 
| libcrypt.so.1 | libc6 | 
| libresolv.so.2 | libc6 | 
| libz.so.1 | zlib1g | 
| librt.so.1 | libc6 | 
| libm.so.6 | libc6 | 
| libgcc_s.so.1 | libgcc1 | 
| libc.so.6 | libc6 | 
Ubuntu 20 and 22 Copied
| Library Name | Package Name | 
|---|---|
| libutil.so.1 | libc6 | 
| libnsl.so.1 | libc6 | 
| libpthread.so.0 | libc6 | 
| libdl.so.2 | libc6 | 
| libcrypt.so.1 | libcrypt1 | 
| libresolv.so.2 | libc6 | 
| libz.so.1 | zlib1g | 
| librt.so.1 | libc6 | 
| libm.so.6 | libc6 | 
| libgcc_s.so.1 | libgcc-s1 | 
| libc.so.6 | libc6 |