Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[doc][yba] Installing python and YBA nodes #25563

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ The following built-in roles are available:

- **Super Admin** is the first user that is created during installation. This role has the highest level of privilege and allows all read and write actions on all YugabyteDB Anywhere resources. There can be only one Super Admin. Super Admin can perform the following:

- Manage all resources, including universes, nodes, backup, restore, and cloud providers.
- Manage all resources, including universes, nodes, backup, restore, and provider configurations.
- Manage the user access control by creating and managing users.

For more information, see [Create admin user](../../install-yugabyte-platform/create-admin-user/).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -214,7 +214,7 @@ In cases of failover, the previous active instance may be unavailable or unreach

Afterwards, follow the steps in [Failover](#failover) to ensure that the old active does not come back up or that it goes into standby mode when it does come up.

You should be able to see that all of the data has been restored into the instance, including universes, users, metrics, alerts, task history, cloud providers, and so on.
You should be able to see that all of the data has been restored into the instance, including universes, users, metrics, alerts, task history, provider configurations, and so on.

### Verify promotion

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Configure the AWS cloud provider
title: Configure the AWS provider configuration
headerTitle: Create cloud provider configuration
linkTitle: Cloud providers
description: Configure the Amazon Web Services (AWS) provider configuration.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Configure the Microsoft Azure cloud provider
title: Configure the Microsoft Azure provider configuration
headerTitle: Create cloud provider configuration
linkTitle: Cloud providers
description: Configure the Microsoft Azure provider configuration
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Configure the GCP cloud provider
title: Configure the GCP provider configuration
headerTitle: Create cloud provider configuration
linkTitle: Cloud providers
description: Configure the Google Cloud Platform (GCP) cloud provider.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Configure the Kubernetes cloud provider
title: Configure the Kubernetes provider configuration
headerTitle: Create Kubernetes provider configuration
linkTitle: Kubernetes
description: Configure the Kubernetes provider configuration
Expand Down Expand Up @@ -425,9 +425,9 @@ spec:

Refer to [Multi-Region YugabyteDB Deployments on Kubernetes with Istio](https://www.yugabyte.com/blog/multi-region-yugabytedb-deployments-on-kubernetes-with-istio/) for a step-by-step guide and an explanation of the options being used.

### Configure the cloud provider for MCS
### Configure the provider configuration for MCS

After you have the cluster set up, follow the instructions in [Configure the Kubernetes cloud provider](#provider-settings), and refer to this section for region and zone configuration required for multi-region universes.
After you have the cluster set up, follow the instructions in [Create a provider](#create-a-provider), and refer to this section for region and zone configuration required for multi-region universes.

#### Configure region and zone for GKE MCS

Expand All @@ -452,7 +452,7 @@ For example, if your cluster membership name is `yb-asia-south1`, then the **Add

#### Configure region and zones for OpenShift MCS

Follow the instructions in [Configure the OpenShift cloud provider](../openshift/) and [Create a provider](#create-a-provider). For all the zones from your OpenShift clusters connected via MCS (Submariner), add a region as follows:
Follow the instructions in [Create OpenShift provider configuration](../openshift/) and [Create a provider](#create-a-provider). For all the zones from your OpenShift clusters connected via MCS (Submariner), add a region as follows:

1. Specify fields such as Region, Zone, and so on as you would normally.
1. Set the **Cluster DNS Domain** to `clusterset.local`.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -115,4 +115,4 @@ After the instances are available in the **Instances** list, validate them by pe

YugabyteDB Anywhere runs the check and displays the status in the **Preflight Check** column. Click in the column to view details; you can also view the results under **Tasks**.

If all your instances successfully pass the preflight check, your on-premises cloud provider configuration is ready, and you can begin [deploying universes](../../create-deployments/).
If all your instances successfully pass the preflight check, your on-premises provider configuration is ready, and you can begin [deploying universes](../../create-deployments/).
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
---
title: Configure the OpenShift cloud provider
title: Configure the OpenShift provider configuration
headerTitle: Create Kubernetes provider configuration
linkTitle: Kubernetes
description: Configure the OpenShift provider configuration
headContent: For deploying universes on OpenShift
headContent: For deploying universes on Kubernetes
aliases:
- /preview/deploy/enterprise-edition/configure-cloud-providers/openshift
menu:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
---
title: Configure the VMware Tanzu cloud provider
title: Configure the VMware Tanzu provider configuration
headerTitle: Create Kubernetes provider configuration
linkTitle: Kubernetes
description: Configure the VMware Tanzu provider configuration
headContent: For deploying universes on VMware Tanzu
headContent: For deploying universes on Kubernetes
aliases:
- /deploy/pivotal-cloud-foundry/
- /preview/deploy/pivotal-cloud-foundry/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ To create a multi-cloud universe, you would need to do the following:
* [Set up node instance virtual machines](#set-up-instance-vms) in each cloud (AWS, GCP, and Azure)
* [Set up VPC peering](#set-up-vpc-peering) through a VPN tunnel across these 3 clouds
* [Install YugabyteDB Anywhere](#install-yugabytedb-anywhere) on one of the nodes
* [Configure the on-premises cloud provider](#configure-the-on-premises-cloud-provider)
* [Configure the on-premises provider configuration](#configure-the-on-premises-provider-configuration)
* [Create a universe](#create-a-universe) using the provider
* [Run the TPC-C benchmark](#run-the-tpc-c-benchmark)

Expand Down Expand Up @@ -59,7 +59,7 @@ All public cloud providers enable VPN tunneling across VPCs and their subnet to

Follow steps provided in [Install YugabyteDB Anywhere](../../install-yugabyte-platform/) to deploy YugabyteDB Anywhere on a new VM on one of your cloud providers. You will use this node to manage your YugabyteDB universe.

## Configure the on-premises cloud provider
## Configure the on-premises provider configuration

To deploy a multi-cloud universe, you first need to create an on-premises provider configuration. Refer to [Create provider configuration](../../configure-yugabyte-platform/on-premises/) for more information.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,11 @@ Before you start creating a universe, ensure that you have created a provider co

## Create a universe

After you have configured a cloud provider, such as, for example [Google Cloud Provider](../../configure-yugabyte-platform/gcp/) (GCP), navigate to **Universes**, click **Create Universe**, and enter the following sample values:
After you have created a provider configuration, such as, for example [Google Cloud Provider](../../configure-yugabyte-platform/gcp/) (GCP), navigate to **Universes**, click **Create Universe**, and enter the following sample values:

- In the **Name** field, enter **helloworld2**.

- In the **Provider** field, select the cloud provider you configured.
- In the **Provider** field, select the provider you configured.

- Use the **Regions** field to select the regions where you want to deploy nodes.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,17 +32,17 @@ A Kubernetes-based installation of YugabyteDB Anywhere requires you to address c

The core dump collection in Kubernetes requires special care due to the fact that `core_pattern` is not isolated in cgroup drivers.

You need to ensure that core dumps are enabled on the underlying Kubernetes node. Running the `ulimit -c` command within a Kubernetes pod or node must produce a large non-zero value or the `unlimited` value as an output. For more information, see [How to enable core dumps](https://www.ibm.com/support/pages/how-do-i-enable-core-dumps).
You need to ensure that core dumps are enabled on the underlying Kubernetes node. Running the `ulimit -c` command in a Kubernetes pod or node must produce a large non-zero value or the `unlimited` value as an output. For more information, see [How to enable core dumps](https://www.ibm.com/support/pages/how-do-i-enable-core-dumps).

To be able to locate your core dumps, you should be aware of the fact that the location to which core dumps are written depends on the sysctl `kernel.core_pattern` setting. For more information, see [Linux manual: core(5)](https://man7.org/linux/man-pages/man5/core.5.html#:~:text=Naming%20of%20core%20dump%20files).

To inspect the value of the sysctl within a Kubernetes pod or node, execute the following:
To inspect the value of the sysctl in a Kubernetes pod or node, execute the following:

```sh
cat /proc/sys/kernel/core_pattern
```

If the value of `core_pattern` contains a `|` pipe symbol (for example, `|/usr/share/apport/apport -p%p -s%s -c%c -d%d -P%P -u%u -g%g -- %E`), the core dump is being redirected to a specific collector on the underlying Kubernetes node, with the location depending on the exact collector. To be able to retrieve core dump files in case of a crash within the Kubernetes pod, it is important that you understand where these files are written.
If the value of `core_pattern` contains a `|` pipe symbol (for example, `|/usr/share/apport/apport -p%p -s%s -c%c -d%d -P%P -u%u -g%g -- %E`), the core dump is being redirected to a specific collector on the underlying Kubernetes node, with the location depending on the exact collector. To be able to retrieve core dump files in case of a crash in the Kubernetes pod, it is important that you understand where these files are written.

If the value of `core_pattern` is a literal path of the form `/var/tmp/core.%p`, no action is required on your part, as core dumps will be copied by the YugabyteDB node to the persistent volume directory `/mnt/disk0/cores` for future analysis.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ To change the configuration of a universe, do the following:

YugabyteDB automatically ensures that new nodes start hosting the tablet leaders for a set of tablets in such a way that the tablet leader count remains evenly balanced across all the available nodes.

To change the number of nodes of universes created with an on-premises cloud provider and secured with third-party certificates obtained from external certification authorities, you must first add the certificates to the nodes you will add to the universe. Refer to [Add certificates](../../security/enable-encryption-in-transit/add-certificate-ca/). Ensure that the certificates are signed by the same external CA and have the same root certificate. In addition, ensure that you copy the certificates to the same locations that you originally used when creating the universe.
To change the number of nodes of universes created with an on-premises provider and secured with third-party certificates obtained from external certification authorities, you must first add the certificates to the nodes you will add to the universe. Refer to [Add certificates](../../security/enable-encryption-in-transit/add-certificate-ca/). Ensure that the certificates are signed by the same external CA and have the same root certificate. In addition, ensure that you copy the certificates to the same locations that you originally used when creating the universe.

## Smart resize

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ To achieve network connectivity across multiple Kubernetes clusters, you can set

GKE MCS allows clusters to be combined as a fleet on Google Cloud. These fleet clusters can export services, which enables you to do cross-cluster communication. For more information, see [Multi-cluster Services](https://cloud.google.com/kubernetes-engine/docs/concepts/multi-cluster-services) in the Google Cloud documentation.

To enable MCS on your GKE clusters, see [Configuring multi-cluster Services](https://cloud.google.com/kubernetes-engine/docs/how-to/multi-cluster-services). Note down the unique membership name of each cluster in the fleet, it will be used during the cloud provider setup in YBA.
To enable MCS on your GKE clusters, see [Configuring multi-cluster Services](https://cloud.google.com/kubernetes-engine/docs/how-to/multi-cluster-services). Note down the unique membership name of each cluster in the fleet, it will be used during the provider setup in YBA.

### Prepare OpenShift clusters for MCS

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,15 @@ aliases:
- /preview/yugabyte-platform/configure-yugabyte-platform/supported-os-and-arch/
- /preview/yugabyte-platform/install-yugabyte-platform/prepare-on-prem-nodes/
type: indexpage
showRightNav: true
---

The Linux OS and other software components on each database cluster node must meet the following minimum software requirements.

Depending on the [provider type](../../yba-overview/#provider-configurations) and permissions you grant, you may have to install all of these requirements manually, or YugabyteDB Anywhere will install it all automatically.

{{< warning title="Using disk encryption software with YugabyteDB" >}}
If you are using third party disk encryption software, such as Vormetric or CipherTrust, the disk encryption service must be up and running on the node before starting any YugabyteDB services. If YugabyteDB processes start _before_ the encryption service, restarting an already encrypted node can result in data corruption.
If you are using third party disk encryption software (such as Vormetric or CipherTrust), the disk encryption service must be up and running on the node before starting any YugabyteDB services. If YugabyteDB processes start _before_ the encryption service, restarting an already encrypted node can result in data corruption.

To avoid problems, [pause the universe](../../manage-deployments/delete-universe/#pause-a-universe) _before_ enabling or disabling the disk encryption service on universe nodes.
{{< /warning >}}
Expand All @@ -35,18 +36,35 @@ AlmaLinux OS 8 disk images are used by default, but you can specify a custom dis

YugabyteDB Anywhere requires the following additional software to be pre-installed on nodes:

- Python 3.6-3.8
- Install the python selinux package corresponding to your version of python. For example, using pip, you can install as follows:

`python3 -m pip install selinux`

Alternately, if you are using the default version of python3, you might be able to install the python3-libselinux package.

- OpenSSH Server. Allowing SSH is recommended but optional. Using SSH can be skipped in some on-premises deployment approaches; all other workflows require it. [Tectia SSH](../../create-deployments/connect-to-universe/#enable-tectia-ssh) is also supported.
- tar
- unzip
- policycoreutils-python-utils

#### Python

Python 3.6-3.12 must be installed on the nodes.

Install the python selinux package corresponding to your version of python. You can use pip to do this. Ensure the version of pip matches the version of Python.

For example, you can install Python as follows:

```sh
sudo yum install python38
sudo pip3.8 install selinux
sudo ln -s /usr/bin/python3.8 /usr/bin/python
sudo rm /usr/bin/python3
sudo ln -s /usr/bin/python3.8 /usr/bin/python3
python3 -c "import selinux; import sys; print(sys.version)"
```

```output
> 3.8.19 (main, Sep 11 2024, 00:00:00)
> [GCC 11.5.0 20240719 (Red Hat 11.5.0-2)]
```

Alternately, if you are using the default version of python3, you might be able to install the python3-libselinux package.

### Additional software for airgapped deployment

Additionally, if not connected to the public Internet (that is, airgapped); and not connected to a local Yum repository that contains the [additional software](#additional-software), database cluster nodes must also have the following additional software pre-installed:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,9 +41,9 @@ Take the time now to prepare the Linux disk image.

| Save for later | To configure |
| :--- | :--- |
| SSH-enabled, root-privileged user name | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged Private Key Content PEM file | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| Disk image IDs | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged user name | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged Private Key Content PEM file | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |
| Disk image IDs | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |

## Custom Linux version without Internet connectivity

Expand All @@ -60,6 +60,6 @@ Take the time now to prepare the Linux disk image.

| Save for later | To configure |
| :--- | :--- |
| SSH-enabled, root-privileged user name | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged Private Key Content PEM file | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| Disk image IDs | [Cloud provider](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged user name | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |
| SSH-enabled, root-privileged Private Key Content PEM file | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |
| Disk image IDs | [Cloud provider configuration](../../../configure-yugabyte-platform/aws/) |
Original file line number Diff line number Diff line change
Expand Up @@ -78,25 +78,25 @@ The following instructions use user-level systemd to provide the necessary acces

## Verify the python version installed on the node

Verify that Python 3.5-3.8 is installed on the node. v3.6 is recommended.
Verify that Python 3.6-3.12 is installed on the node. v3.6 is recommended.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would leave 3.8 as recommended, and honestly just keep this as 3.8+ I think that's going to be more correct going forward. If somebody complains we can tell them 3.6 still should work but I don't think we want to officially document supporting it bc then people will try to install it.


In case there is more than one Python 3 version installed, ensure that `python3` refers to the right one. For example:

```sh
sudo alternatives --set python3 /usr/bin/python3.6
sudo alternatives --set python3 /usr/bin/python3.8
sudo alternatives --display python3
python3 -V
```

If you are using Python later than v3.6, install the [selinux](https://pypi.org/project/selinux/) package corresponding to your version of python. For example, using [pip](https://pip.pypa.io/en/stable/installation/), you can install as follows:
Install the [selinux](https://pypi.org/project/selinux/) package corresponding to your version of python. For example, using [pip](https://pip.pypa.io/en/stable/installation/), you can install as follows:

```sh
python3 -m pip install selinux
```

Refer to [Ansible playbook fails with libselinux-python aren't installed on RHEL8](https://access.redhat.com/solutions/5674911) for more information.

If you are using Python later than v3.7, set the **Max Python Version (exclusive)** Global Configuration option to the python version. Refer to [Manage runtime configuration settings](../../../administer-yugabyte-platform/manage-runtime-config/). Note that only a Super Admin user can modify Global configuration settings.
Set the **Max Python Version (exclusive)** Global runtime configuration option to the python version. Refer to [Manage runtime configuration settings](../../../administer-yugabyte-platform/manage-runtime-config/). Note that only a Super Admin user can modify Global configuration settings.

## Set up time synchronization

Expand Down
Loading