Skip to content

Commit

Permalink
Baseline import for TPA23.33
Browse files Browse the repository at this point in the history
Signed-off-by: Dj Walker-Morgan <[email protected]>
  • Loading branch information
djw-m committed Jun 19, 2024
1 parent f4a611d commit d8cb425
Show file tree
Hide file tree
Showing 82 changed files with 324 additions and 77 deletions.
2 changes: 2 additions & 0 deletions product_docs/docs/tpa/23/INSTALL-repo.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: Install from Source
description: Installing and running TPA from a copy of the source code repository.
title: Installing TPA from source
originalFilePath: INSTALL-repo.md

Expand All @@ -9,6 +10,7 @@ This document explains how to use TPA from a copy of the source code
repository.

!!! Note

EDB customers must [install TPA from packages](INSTALL/) in
order to receive EDB support for the software.

Expand Down
18 changes: 15 additions & 3 deletions product_docs/docs/tpa/23/INSTALL.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: Installation
description: Installing TPA packages and setting up the Python environment.
title: TPA installation
originalFilePath: INSTALL.md

Expand All @@ -16,6 +17,7 @@ See [Distribution support](reference/distributions/) for information
on what platforms are supported.

!!! Info

Please make absolutely sure that your system has the correct
date and time set, because various things will fail otherwise. We
recommend you use a network time, for example `sudo ntpdate
Expand Down Expand Up @@ -129,6 +131,7 @@ Next, run `tpaexec setup` to create an isolated Python environment and
install the correct versions of all required modules.

!!! Note

On Ubuntu versions prior to 20.04, please use `sudo -H tpaexec setup`
to avoid subsequent permission errors during `tpaexec configure`

Expand Down Expand Up @@ -167,9 +170,18 @@ If your internet-connected machine uses the same operating system as the
target, we recommend using `yumdownloader` (RHEL-like) or `apt download`
(Debian-like) to download the packages.

If this is not possible, please contact EDB support and we will provide
you with a download link or instructions appropriate to your
subscription.
Alternatively, you can download packages for any platform from your
browser by visiting [EDB Repos](https://www.enterprisedb.com/repos) and
selecting either 'Enterprise', 'Standard' or 'Community 360' under the
heading 'Download EDB software packages from your browser'.
To install TPA you need these packages:

- tpaexec
- tpaexec-deps
- edb-python39

Once you have transferred the downloaded packages to the target server,
you must install them using the appropriate tool for your platform.

### Installing without access to a Python package index

Expand Down
5 changes: 4 additions & 1 deletion product_docs/docs/tpa/23/ansible-and-sudo.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
---
title: TPA, Ansible, and sudo
description: >-
How TPA uses Ansible with sudo to execute tasks with elevated privileges on
target instances.
title: 'TPA, Ansible, and sudo'
originalFilePath: ansible-and-sudo.md

---
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/architecture-BDR-Always-ON.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Configuring a BDR-Always-ON cluster with TPA.
title: BDR-Always-ON
originalFilePath: architecture-BDR-Always-ON.md

Expand Down
22 changes: 12 additions & 10 deletions product_docs/docs/tpa/23/architecture-M1.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Configuring the M1 architecture with TPA.
title: M1
originalFilePath: architecture-M1.md

Expand Down Expand Up @@ -78,16 +79,17 @@ More detail on the options is provided in the following section.

#### Additional Options

| Parameter | Description | Behaviour if omitted |
| --------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------- |
| `--platform` | One of `aws`, `docker`, `bare`. | Defaults to `aws`. |
| `--location-names` | A space-separated list of location names. The number of active locations is equal to the number of names supplied, minus one for each of the witness-only location and the single-node location if they are requested. | A single location called "main" is used. |
| `--primary-location` | The location where the primary server will be. Must be a member of `location-names`. | The first listed location is used. |
| `--data-nodes-per-location` | A number from 1 upwards. In each location, one node will be configured to stream directly from the cluster's primary node, and the other nodes, if present, will stream from that one. | Defaults to 2. |
| `--witness-only-location` | A location name, must be a member of `location-names`. | No witness-only location is added. |
| `--single-node-location` | A location name, must be a member of `location-names`. | No single-node location is added. |
| `--enable-haproxy` | 2 additional nodes will be added as a load balancer layer.<br/>Only supported with Patroni as the failover manager. | HAproxy nodes will not be added to the cluster. |
| `--patroni-dcs` | Select the Distributed Configuration Store backend for patroni.<br/>Only option is `etcd` at this time. <br/>Only supported with Patroni as the failover manager. | Defaults to `etcd`. |
| Parameter | Description | Behaviour if omitted |
| --------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------ |
| `--platform` | One of `aws`, `docker`, `bare`. | Defaults to `aws`. |
| `--location-names` | A space-separated list of location names. The number of active locations is equal to the number of names supplied, minus one for each of the witness-only location and the single-node location if they are requested. | A single location called "main" is used. |
| `--primary-location` | The location where the primary server will be. Must be a member of `location-names`. | The first listed location is used. |
| `--data-nodes-per-location` | A number from 1 upwards. In each location, one node will be configured to stream directly from the cluster's primary node, and the other nodes, if present, will stream from that one. | Defaults to 2. |
| `--witness-only-location` | A location name, must be a member of `location-names`. | No witness-only location is added. |
| `--single-node-location` | A location name, must be a member of `location-names`. | No single-node location is added. |
| `--enable-haproxy` | 2 additional nodes will be added as a load balancer layer.<br/>Only supported with Patroni as the failover manager. | HAproxy nodes will not be added to the cluster. |
| `--enable-pgbouncer` | PgBouncer will be configured in the Postgres nodes to pool connections for the primary. | PgBouncer will not be configured in the cluster. |
| `--patroni-dcs` | Select the Distributed Configuration Store backend for patroni.<br/>Only option is `etcd` at this time. <br/>Only supported with Patroni as the failover manager. | Defaults to `etcd`. |

<br/><br/>

Expand Down
4 changes: 4 additions & 0 deletions product_docs/docs/tpa/23/architecture-PGD-Always-ON.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Configuring a PGD-Always-ON cluster with TPA.
title: PGD-Always-ON
originalFilePath: architecture-PGD-Always-ON.md

Expand Down Expand Up @@ -61,6 +62,8 @@ More detail on the options is provided in the following section.
| `--enable-camo` | Sets two data nodes in each location as CAMO partners. | CAMO will not be enabled. |
| `--bdr-database` | The name of the database to be used for replication. | Defaults to `bdrdb`. |
| `--enable-pgd-probes` | Enable http(s) api endpoints for pgd-proxy such as `health/is-ready` to allow probing proxy's health. | Disabled by default. |
| `--proxy-listen-port` | The port on which proxy nodes will route traffic to the write leader. | Defaults to 6432 |
| `--proxy-read-only-port` | The port on which proxy nodes will route read-only traffic to shadow nodes. | Defaults to 6433 |

<br/><br/>

Expand All @@ -79,6 +82,7 @@ regions, your own data centres, or any other designation to identify
where your servers are hosted.

!!! Note for AWS users

If you are using TPA to provision an AWS cluster, the locations will
be mapped to separate availability zones within the `--region` you
specify.
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/configure-cluster.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to configure a TPA cluster.
title: Cluster configuration
originalFilePath: configure-cluster.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/configure-instance.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Customising the deployment process on cluster instances.
title: Instance configuration
originalFilePath: configure-instance.md

Expand Down
2 changes: 2 additions & 0 deletions product_docs/docs/tpa/23/configure-source.mdx
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
---
description: How to build Postgres and other components from source with TPA.
title: Building from source
originalFilePath: configure-source.md

---

!!!Warning

This option is intended for developers and advanced users.
Only software built and tested by EDB is supported by EDB. Please refer to
[Self-Managed Supported Open Source Software](https://www.enterprisedb.com/product-compatibility/edb-supported-open-source-software.pdf).
Expand Down
3 changes: 3 additions & 0 deletions product_docs/docs/tpa/23/firstclusterdeployment.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: Tutorial
description: A simple tutorial to deploy a Postgres cluster with TPA on Docker.
title: A First Cluster Deployment
originalFilePath: firstclusterdeployment.md

Expand Down Expand Up @@ -38,11 +39,13 @@ newgrp docker
```

!!! Warning

Giving a user the ability to speak to the Docker daemon
lets them trivially gain root on the Docker host. Only trusted users
should have access to the Docker daemon.

!!! Note on RHEL 7 instances

To use RHEL 7 instances your host must be configured to run cgroups v1.
Refer to documentation for your system to verify and alter cgroups configuration,
or choose another operating system for your containers to follow this tutorial.
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/misc-configure-putty.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: PuTTY configuration
description: How to configure PuTTY to connect to a TPA cluster.
title: TPA - PuTTY Configuration guide
originalFilePath: misc-configure-putty.md

Expand Down
3 changes: 2 additions & 1 deletion product_docs/docs/tpa/23/misc-troubleshooting.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to troubleshoot TPA installations
title: Troubleshooting
originalFilePath: misc-troubleshooting.md

Expand Down Expand Up @@ -70,7 +71,7 @@ An easy way to smoketest an existing cluster is to run:
This will do a functional test of the cluster components, followed by a performance test of the cluster, using pgbench. As pgbench can take a while to complete, benchmarking can be omitted by running:

```
[tpa]$ tpaexec test <clustername> --excluded_tasks pgbench
[tpa]$ tpaexec test <clustername> --excluded_tasks=pgbench
```

### TPA server test
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/opensourcetpa.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: Open Source
description: Open source Trusted Postgres Architect (TPA) documentation.
title: Open source TPA
originalFilePath: opensourcetpa.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/platform-aws.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: AWS
description: Provisioning production clusters on AWS EC2 with TPA.
title: aws
originalFilePath: platform-aws.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/platform-bare.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
navTitle: Bare metal
description: Provisioning and managing bare(-metal) servers with TPA.
title: bare(-metal servers)
originalFilePath: platform-bare.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/platform-docker.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Provisioning and deploying to Docker containers with TPA.
title: Docker
originalFilePath: platform-docker.md

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How TPA uses 2ndQuadrant and EDB repositories.
title: How TPA uses 2ndQuadrant and EDB repositories
originalFilePath: 2q_and_edb_repositories.md

Expand Down Expand Up @@ -33,6 +34,7 @@ that you have [exported the token](#authenticating-with-package-sources)
before running `tpaexec deploy` or the operation will fail.

!!! Note

EDB is in the process of publishing all software through Repos 2.0,
and will eventually remove the older repositories.

Expand Down
3 changes: 3 additions & 0 deletions product_docs/docs/tpa/23/reference/INSTALL-docker.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
---
description: >-
How to run TPA itself from within a Docker container, for systems where TPA is
not supported natively.
title: Running TPA in a Docker container
originalFilePath: INSTALL-docker.md

Expand Down
2 changes: 2 additions & 0 deletions product_docs/docs/tpa/23/reference/air-gapped.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to manage clusters in a disconnected or air-gapped environment
title: Managing clusters in a disconnected or air-gapped environment
originalFilePath: air-gapped.md

Expand All @@ -19,6 +20,7 @@ follow the instructions below to either copy an existing cluster
configuration or create a new cluster.

!!! Note

If the air-gapped server does not already have TPA installed,
follow the instructions
[here](../INSTALL/#installing-tpa-without-internet-or-network-access-air-gapped)
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/apt_repositories.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Configuring APT repositories for Debian and Ubuntu systems.
title: Configuring APT repositories
originalFilePath: apt_repositories.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/artifacts.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Uploading files and directories to target instances with TPA.
title: Uploading artifacts
originalFilePath: artifacts.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/barman.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Configuring Barman for backup and recovery with TPA.
title: Barman
originalFilePath: barman.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/bdr.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to configure and deploy EDB Postgres Distributed (PGD) with TPA.
title: EDB Postgres Distributed configuration
originalFilePath: bdr.md

Expand Down
47 changes: 47 additions & 0 deletions product_docs/docs/tpa/23/reference/beacon-agent.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
---
title: Configuring the beacon agent
originalFilePath: beacon-agent.md

---

TPA installs and configures the beacon agent on nodes which have
the role `beacon-agent` in `config.yml`. If `--enable-beacon-agent` is
passed to `tpaexec configure`, then all of the postgres nodes in the
cluster have this role.

## beacon agent configuration

The beacon agent configuration contains two parameters which must be set
per-cluster, the access key and the project id.

The access key is kept encrypted in the cluster directory and can be
set or read using tpa's `store-password` and `show-password` commands:

```bash
$ tpaexec store-password . beacon_agent_access_key
Password:
```

```bash
$ tpaexec show-password . beacon_agent_access_key
```

If the environment variable BEACON_AGENT_ACCESS_KEY is set when `tpaexec
provision` is run, the access key is set from its value.

The project id is stored in `config.yml` under the
`beacon_agent_project_id` key in `cluster_vars`. If the
`--beacon_agent_project_id` argument is passed to `tpaexec configure`
then its value is written to `config.yml` appropriately.

## installing the beacon agent

TPA installs the beacon agent from EDB's repositories and creates an
operating system user called `beacon` and a database user called
`beacon`. A configuration file for the agent is written to
`.beacon/beacon_agent.yaml` in the beacon user's home directory.

## running the beacon agent

TPA installs a systemd service unit file to start the agent at
boot-time, running as the beacon user.
5 changes: 5 additions & 0 deletions product_docs/docs/tpa/23/reference/distributions.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: Which Linux distributions are supported by TPA.
title: Distribution support
originalFilePath: distributions.md

Expand All @@ -14,6 +15,10 @@ and is not suitable for production use.
Fully supported platforms are supported both as host systems for running
TPA and target systems on which TPA deploys the Postgres cluster.

## Debian ARM64

- Debian 12/bookworm is fully supported

## Debian x86

- Debian 12/bookworm is fully supported
Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/edb_repositories.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to configure EDB Repos 2.0 package repositories on any system.
title: Configuring EDB Repos 2.0 repositories
originalFilePath: edb_repositories.md

Expand Down
1 change: 1 addition & 0 deletions product_docs/docs/tpa/23/reference/efm.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to install and configure EFM with TPA.
title: Configuring EFM
originalFilePath: efm.md

Expand Down
2 changes: 2 additions & 0 deletions product_docs/docs/tpa/23/reference/git-credentials.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
---
description: How to authenticate to Git repositories during deployment.
title: Git credentials
originalFilePath: git-credentials.md

Expand All @@ -24,6 +25,7 @@ disk on the target instance:
before running `tpaexec deploy`.

!!! Note

When deploying to Docker on macOS, you should use only `https://`
repository URLs because Docker containers cannot be accessed by ssh
from the host in this environment.
Expand Down
Loading

0 comments on commit d8cb425

Please sign in to comment.