diff --git a/docs/major-upgrade.md b/docs/major-upgrade.md
index 9c7b5b92..383dca29 100644
--- a/docs/major-upgrade.md
+++ b/docs/major-upgrade.md
@@ -63,7 +63,7 @@ Run **all** commands as root or via **sudo**:
1. Install Percona Distribution for PostgreSQL 13 packages.
- * [Install percona-release :octicons-link-external-16:](https://docs.percona.com/percona-software-repositories/installing.html)
+ * [Install percona-release :octicons-link-external-16:](https://docs.percona.com/percona-software-repositories/installing.html). If you have installed it before, [update it to the latest version](https://docs.percona.com/percona-software-repositories/updating.html)
* Enable Percona repository:
diff --git a/docs/minor-upgrade.md b/docs/minor-upgrade.md
index 9a944541..f1b6d938 100644
--- a/docs/minor-upgrade.md
+++ b/docs/minor-upgrade.md
@@ -7,13 +7,13 @@ Though minor upgrades do not change the behavior, we recommend you to back up yo
Minor upgrade of Percona Distribution for PostgreSQL includes the following steps:
-1. Stopping the `postgresql` cluster;
+1. Stop the `postgresql` cluster;
+2. Update `percona-release`;
-2. Installing new version packages;
+3. Install new version packages;
-
-3. Restarting the `postgresql` cluster.
+4. Restart the `postgresql` cluster.
!!! note
@@ -43,11 +43,13 @@ Run **all** commands as root or via **sudo**:
$ sudo systemctl stop postgresql-13
```
+2. [Update `percona-release` to the latest version](https://docs.percona.com/percona-software-repositories/updating.html).
+
-2. Install new version packages. See [Installing Percona Distribution for PostgreSQL](installing.md).
+3. Install new version packages. See [Installing Percona Distribution for PostgreSQL](installing.md).
-3. Restart the `postgresql` service.
+4. Restart the `postgresql` service.
=== ":material-debian: On Debian / Ubuntu"
diff --git a/docs/telemetry.md b/docs/telemetry.md
index 977dca7d..6b384e14 100644
--- a/docs/telemetry.md
+++ b/docs/telemetry.md
@@ -1,53 +1,388 @@
-# Telemetry on Percona Distribution for PostgreSQL
+# Telemetry and data collection
-Percona telemetry fills in the gaps in our understanding of how you use Percona Distribution for PostgreSQL to improve our products. Participation in this anonymous program is optional. You can opt-out if you prefer to not share this information.
+Percona collects usage data to improve its software. The telemetry feature helps us identify popular features, detect problems, and plan future improvements. All collected data is anonymized so that it can't be traced back to any individual user.
+
+Currently, telemetry is added only to the Percona packages and to Docker images. It is enabled by default so you must be running the latest version of `percona-release` to install Percona Distribution for PostgreSQL packages or update it to the latest version.
## What information is collected
-Currently, telemetry is added only to the Percona packages and Docker images. It collects only information about the installation environment. Future releases may add additional telemetry metrics.
+Telemetry collects the following information:
+
+* The information about the installation environment when you install the software.
+* The information about the operating system such as name, architecture, the list of Percona packages. See more in the [Telemetry Agent section](#telemetry-agent).
+* The metrics from the database instance. See more in the [percona_pg_telemetry section](#percona_pg_telemetry).
+
+## What is NOT collected
+
+Percona protects your privacy and doesn't collect any personal information about you like database names, user names or credentials or any user-entered values.
+
+All collected data is anonymous, meaning it can't be traced back to any individual user. To learn more about how Percona handles your data, read the [Percona Privacy statement](https://www.percona.com/privacy-policy).
+
+You control whether to share this information. Participation in this program is completely voluntary. If don't want to share anonymous data, you can [disable telemetry](#disable-telemetry).
+
+## Why telemetry matters
+
+Benefits for Percona:
+
+| Advantages | Description |
+|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
+| See how people use your software | Telemetry collects anonymous data on how users interact with our software. This tells developers which features are popular, which ones are confusing, and if anything is causing crashes. |
+| Identify issues early | Telemetry can catch bugs or performance problems before they become widespread. |
+
+Benefits for users in the long run:
+
+| Advantages | Description |
+|---------------------------|---------------------------------------------------------------------------------------------------------------------|
+| Faster bug fixes | With telemetry data, developers can pinpoint issues affecting specific use cases and prioritize fixing them quickly. |
+| Improved features | Telemetry helps developers understand user needs and preferences. This allows them to focus on features that will be genuinely useful and improve your overall experience. |
+| Improved user experience | By identifying and resolving issues early, telemetry helps create a more stable and reliable software experience for everyone. |
+
+## Telemetry components
+
+Percona collects information using the following components:
+
+* Telemetry script that sends the information about the software and the environment where it is installed. This information is collected only once during the installation.
+
+* The `percona_pg_telemetry` extension collects the necessary metrics directly from the database and stores them in a Metrics File.
+
+* The Metrics File stores the metrics and is a standalone file located on the database host's file system.
+
+* The Telemetry Agent is an independent process running on your database host's operating system and carries out the following tasks:
+
+ * Collects OS-level metrics
+
+ * Reads the Metrics File, adds the OS-level metrics
+
+ * Sends the full set of metrics to the Percona Platform
+
+ * Collects the list of installed Percona packages using the local package manager
+
+The telemetry also uses the Percona Platform with the following components:
+
+* Telemetry Service - offers an API endpoint for sending telemetry. The service handles incoming requests. This service saves the data into Telemetry Storage.
+
+* Telemetry Storage - stores all telemetry data for the long term.
+
+### `percona_pg_telemetry`
+
+`percona_pg_telemetry` is an extension to collect telemetry data in PostgreSQL. It is added to Percona Distribution for PostgreSQL and is automatically loaded when you install a PostgreSQL server.
+
+`percona_pg_telemetry` collects metrics from the database instance daily to the Metrics File. It creates a new Metrics File for each collection. You can find the Metrics File in its [location](#location) to inspect what data is collected.
+
+Before generating a new file, the `percona_pg_telemetry` deletes the Metrics Files that are older than seven days. This process ensures that only the most recent week's data is maintained.
+
+The `percona_pg_telemetry` extension creates a file in the local file system using a timestamp and a randomly generated token as the name with a `.json` extension.
-Be assured that access to this raw data is rigorously controlled. Percona does not collect personal data. All data is anonymous and cannot be traced to a specific user. To learn more about our privacy practices, read the [Percona Privacy statement].
+### Metrics File
-The following is an example of the collected data:
+The Metrics File is a JSON file with the metrics collected by the `percona_pg_telemetry` extension.
+
+#### Locations
+
+Percona stores the Metrics File in one of the following directories on the local file system. The location depends on the product.
+
+* Telemetry root path - `/usr/local/percona/telemetry`
+
+* PostgreSQL root path - `${telemetry root path}/pg/`
+
+* Percona Server for MongoDB has two root paths since telemetry is enabled both for the `mongod` and `mongos` instances. The paths are the following:
+
+ * `mongod` root path - `${telemetry root path}/psmdb/`
+ * `mongos` root path - `${telemetry root path}/psmdbs/`
+
+* PS root path - `${telemetry root path}/ps/`
+
+* PXC root path - `${telemetry root path}/pxc/`
+
+Percona archives the telemetry history in `${telemetry root path}/history/`.
+
+#### Metrics File format
+
+The Metrics File uses the Javascript Object Notation (JSON) format. Percona reserves the right to extend the current set of JSON structure attributes in the future.
+
+The following is an example of the collected data generated by the `percona_pg_telemetry` extension:
+
+```{.json .no-copy}
+{
+"db_instance_id": "7310358902660071382",
+"pillar_version": "{{dockertag}}",
+"uptime": "36",
+"databases_count": "2",
+"settings": [
+ {
+ "key": "setting",
+ "value": [
+ {
+ "key": "name",
+ "value": "allow_in_place_tablespaces"
+ },
+ {
+ "key": "unit",
+ "value": "NULL"
+ },
+ {
+ "key": "setting",
+ "value": "off"
+ },
+ {
+ "key": "reset_val",
+ "value": "off"
+ },
+ {
+ "key": "boot_val",
+ "value": "off"
+ }
+ ]
+ },
+ ...
+],
+"databases": [
+ {
+ "key": "database",
+ "value": [
+ {
+ "key": "database_oid",
+ "value": "5"
+ },
+ {
+ "key": "database_size",
+ "value": "7820895"
+ },
+ {
+ "key": "active_extensions",
+ "value": [
+ {
+ "key": "extension_name",
+ "value": "plpgsql"
+ },
+ {
+ "key": "extension_name",
+ "value": "pg_tde"
+ },
+ {
+ "key": "extension_name",
+ "value": "percona_pg_telemetry"
+ }
+ ]
+ }
+ ]
+ }
+]
+}
+```
+
+
+### Telemetry Agent
+
+The Percona Telemetry Agent runs as a dedicated OS daemon process `percona-telemetry-agent`. It creates, reads, writes, and deletes JSON files in the [`${telemetry root path}`](#locations). You can find the agent's log file at `/var/log/percona/telemetry-agent.log`.
+
+The agent does not send anything if there are no Percona-specific files in the target directory.
+
+The following is an example of a Telemetry Agent payload:
```json
-[{"id" : "c416c3ee-48cd-471c-9733-37c2886f8231",
-"product_family" : "PRODUCT_FAMILY_POSTGRESQL",
-"instanceId" : "6aef422e-56a7-4530-af9d-94cc02198343",
-"createTime" : "2023-11-01T10:46:23Z",
-"metrics":
-[{"key" : "deployment","value" : "PACKAGE"},
-{"key" : "pillar_version","value" : "13.13"},
-{"key" : "OS","value" : "Oracle Linux Server 8.8"},
-{"key" : "hardware_arch","value" : "x86_64 x86_64"}]}]
+{
+ "reports": [
+ {
+ "id": "B5BDC47B-B717-4EF5-AEDF-41A17C9C18BB",
+ "createTime": "2023-09-01T10:56:49Z",
+ "instanceId": "B5BDC47B-B717-4EF5-AEDF-41A17C9C18BA",
+ "productFamily": "PRODUCT_FAMILY_POSTGRESQL",
+ "metrics": [
+ {
+ "key": "OS",
+ "value": "Ubuntu"
+ },
+ {
+ "key": "pillar_version",
+ "value": "{{dockertag}}"
+ }
+ ]
+ }
+ ]
+}
```
-## Disable telemetry
+The agent sends information about the database and metrics.
+
+| Key | Description |
+|---|---|
+| "id" | A generated Universally Unique Identifier (UUID) version 4 |
+| "createTime" | UNIX timestamp |
+| "instanceId" | The DB Host ID. The value can be taken from the `instanceId`, the `/usr/local/percona/telemetry_uuid` or generated as a UUID version 4 if the file is absent. |
+| "productFamily" | The value from the file path |
+| "metrics" | An array of key:value pairs collected from the Metrics File.
+
+The following operating system-level metrics are sent with each check:
+
+| Key | Description |
+|---|---|
+| "OS" | The name of the operating system |
+| "hardware_arch" | The type of process used in the environment |
+| "deployment" | How the application was deployed.
The possible values could be "PACKAGE" or "DOCKER". |
+| "installed_packages" | A list of the installed Percona packages.|
+
+The information includes the following:
+
+* Package name
+
+* Package version - the same format as Red Hat Enterprise Linux or Debian
+
+* Package repository - if possible
+
+The package names must fit the following pattern:
+
+* `percona-*`
-Starting with Percona Distribution for PostgreSQL 13.13, telemetry is enabled by default. If you decide not to send usage data to Percona, you can set the `PERCONA_TELEMETRY_DISABLE=1` environment variable for either the root user or in the operating system prior to the installation process.
+* `Percona-*`
+
+* `proxysql*`
+
+* `pmm`
+
+* `etcd*`
+
+* `haproxy`
+
+* `patroni`
+
+* `pg*`
+
+* `postgis`
+
+* `wal2json`
+
+## Disable telemetry
+
+Telemetry is enabled by default when you install the software. It is also included in the software packages (Telemetry Subsystem and Telemetry Agent) and enabled by default.
+
+If you don't want to send the telemetry data, here's how:
+
+### Disable the telemetry collected during the installation
+
+If you decide not to send usage data to Percona when you install the software, you can set the `PERCONA_TELEMETRY_DISABLE=1` environment variable for either the root user or in the operating system prior to the installation process.
=== "Debian-derived distribution"
- Add the environment variable before the install process.
+ Add the environment variable before the installation process.
```{.bash data-prompt="$"}
- $ sudo PERCONA_TELEMETRY_DISABLE=1 apt install percona-postgresql-{{pgversion}}
+ $ sudo PERCONA_TELEMETRY_DISABLE=1 apt install percona-ppg-server-13
```
=== "Red Hat-derived distribution"
- Add the environment variable before the install process.
+ Add the environment variable before the installation process.
```{.bash data-prompt="$"}
- $ sudo PERCONA_TELEMETRY_DISABLE=1 yum install percona-postgresql{{pgversion}}-server
+ $ sudo PERCONA_TELEMETRY_DISABLE=1 yum install percona-ppg-server13
```
-=== "DOCKER"
+=== "Docker"
Add the environment variable when running a command in a new container.
```{.bash data-prompt="$"}
- $ docker run --name container-name -e POSTGRES_PASSWORD=secret -e PERCONA_TELEMETRY_DISABLE=1 -d percona/percona-distribution-postgresql:tag
+ $ docker run -d --name pg --restart always \
+ -e PERCONA_TELEMETRY_DISABLE=1 \
+ percona/percona-distribution-postgresql:-multi
+ ```
+
+ The command does the following:
+
+ * `docker run` - This is the command to run a Docker container.
+ * `-d` - This flag specifies that the container should run in detached mode (in the background).
+ * `--name pg` - Assigns the name "pg" to the container.
+ * `--restart always` - Configures the container to restart automatically if it stops or crashes.
+ * `-e PERCONA_TELEMETRY_DISABLE=1` - Sets an environment variable within the container. In this case, it disables telemetry for Percona Distribution for PostgreSQL.
+ * `percona/percona-distribution-postgresql:-multi` - Specifies the image to use for the container. For example, `{{dockertag}}-multi`. The `multi` part of the tag serves to identify the architecture (x86_64 or ARM64) and use the respective image.
+
+
+## Disable telemetry for the installed software
+
+Percona software you installed includes the telemetry feature that collects information about how you use this software. It is enabled by default. To turn off telemetry, you need to disable both the Telemetry Agent and the Telemetry Subsystem.
+
+### Disable Telemetry Agent
+
+In the first 24 hours, no information is collected nor sent.
+
+You can either disable the Telemetry Agent temporarily or permanently.
+
+=== "Disable temporarily"
+
+ Turn off Telemetry Agent temporarily until the next server restart with this command:
+
+ ```{.bash data-prompt=$}
+ $ systemctl stop percona-telemetry-agent
+ ```
+
+=== "Disable permanently"
+
+ Turn off Telemetry Agent permanently with this command:
+
+ ```{.bash data-prompt=$}
+ $ systemctl disable percona-telemetry-agent
+ ```
+
+Even after stopping the Telemetry Agent service, a different part of the software (`percona_pg_telemetry`) continues to create the Metrics File related to telemetry every day and saves that file for seven days.
+
+### Telemetry Agent dependencies and removal considerations
+
+If you decide to remove the Telemetry Agent, this also removes the database. That's because the Telemetry Agent is a mandatory dependency for Percona Distribution for PostgreSQL.
+
+On YUM-based systems, the system removes the Telemetry Agent package when you remove the last dependency package.
+
+On APT-based systems, you must use the '--autoremove' option to remove all dependencies, as the system doesn't automatically remove the Telemetry Agent when you remove the database package.
+
+The '--autoremove' option only removes unnecessary dependencies. It doesn't remove dependencies required by other packages or guarantee the removal of all package-associated dependencies.
+
+### Disable the `percona_pg_telemetry` extension
+
+To disable the Metrics File creation, stop and drop the `percona_pg_telemetry` extension. Here's how to do it:
+
+1. Stop the extension and reapply the configuration for the changes to take effect:
+
+ ```sql
+ ALTER SYSTEM SET percona_pg_telemetry.enabled = 0;
+ SELECT pg_reload_conf();
+ ```
+
+2. Remove the `percona_pg_telemetry` extension from the database:
+
+ ```sql
+ DROP EXTENSION percona_pg_telemetry;
```
-[Percona Privacy statement]: https://www.percona.com/privacy-policy#h.e34c40q8sb1a
\ No newline at end of file
+3. Remove `percona_pg_telemetry` from the `shared_preload_libraries` configuration parameter:
+
+ ```sql
+ ALTER SYSTEM SET shared_preload_libraries = '';
+ ```
+
+ !!! important
+
+ If the `shared_preload_libraries parameter` includes other modules, specify them all for the `ALTER SYSTEM SET` command to keep using them.
+
+4. Restart the PostgreSQL server
+
+ === ":material-debian: On Debian and Ubuntu"
+
+ ```{.bash data-prompt="$"}
+ $ sudo systemctl restart postgresql.service
+ ```
+
+
+ === ":material-redhat: On Red Hat Enterprise Linux and derivatives"
+
+ ```{.bash data-prompt="$"}
+ $ sudo systemctl restart postgresql-13
+ ```
+
+
+!!! tip
+
+ If you wish to re-enable the Telemetry Subsystem, complete the above steps in the reverse order:
+
+ 1. Add the `percona_pg_telemetry` to the `shared_preload_libraries`,
+ 2. Set `percona_pg_telemetry.enabled` to `1`, and
+ 3. Restart the PostgreSQL server.