Glossary

Object

Each configurable part of GatewayD is called an object, for example logger.

Configuration file

GatewayD has two YAML-based configuration files that are shipped with each release file and contains all the default values.

  • gatewayd.yaml: the global configuration file of GatewayD.
  • gatewayd_plugins.yaml: the plugins configuration file.

Configuration object

Each configuration file contains multiple configuration objects that correspond to GatewayD objects. For example, the global configuration file contains seven configuration objects: loggers, metrics, clients, pools, proxies, server and API.

Configuration group

To enable multi-tenancy, GatewayD supports configuring multiple instances of each (configuration) object using configuration groups. All the default configuration objects have a single configuration group called default, except the API.

Configuration block

Within each configuration group, GatewayD allows for further segmentation of settings through the use of configuration blocks. A configuration block represents a specific set of parameters within a configuration group, tailored to a particular instance.

Configuration blocks are supported for the following configuration objects: clients, pools and proxies.

Configuration parameter

A configuration object has one or many configuration parameters to set up the corresponding object. For example, the output parameter on the logger object is used to set the outputs by the default (configuration group) logger.

Connection

A connection is a TCP/UDP/UDS connection between GatewayD and a database client. GatewayD can have multiple connections at the same time.

Server

Server is an object that listens on an address:port pair and accepts connections from database clients.

Client

Client object is a client that can connect to the database servers over TCP, UDP and Unix Domain Socket.

Database client

Database clients are either database drivers for different programming languages or any other client that can talk the database language, aka. the wire protocol.

Database driver

A database driver is a library that allows a programming language to communicate with a database. For example, the PostgreSQL driver for Python is called psycopg.

Database language

The database language is the language that the database server understands. For example, the PostgreSQL database server understands the PostgreSQL wire protocol.

Wire protocol

The wire protocol is the language that the database client and the database server understand. For example, the PostgreSQL database server understands the PostgreSQL wire protocol.

Database server

A database server is a server that hosts a database. For example, PostgreSQL is a database server.

Database Management System (DBMS)

A database management system is a software that manages a database. For example, PostgreSQL is a database management system.

Event

The server works in an event-based manner and many events will fire during the lifetime of the server and the database client connections.

Proxy

The proxy object is responsible for handling the traffic between the database client and the database server and is directly connected to the server object.

Pool

The pool object is responsible for managing the client objects and is directly connected to the proxy object.

Connection health check

The proxy object will periodically check the connection health by disconnecting stale connections the database server and creating the same number of new connections to the database server.

Stale connection

A stale connection is a connection that has not been used for a long time and is considered unhealthy.

PostgreSQL wire protocol

The PostgreSQL wire protocol is the binary protocol that the PostgreSQL database server understands.