Skip to content

Latest commit

 

History

History

istio-install

Istio Install

This folder provides tools to setup a cluster with Istio for performance testing.

Resource Requirement

For load testing, the setup requires a very large cluster - at least 32 vCPUs reserved for Istio is recommended. The defaults values are 32vCP and at least 4 nodes.

For testing stability and e2e behavior in small clusters - 4vCPU per node and 1 node with autoscale enabled should work.

IBM Cluster Setup

Required environment:

export CLUSTER_NAME=istio14test1 - name of the cluster to setup
export ZONE=us-central1-a - zone where the cluster will be setup
export REGION=us-central2 - region where a regional cluster will be set up, overrides ZONE
export DNS_DOMAIN=test - domain to use for TLS cert testing

GKE Cluster Setup

Required environment:

export PROJECT_ID=istio-testing - GCP project id
export CLUSTER_NAME=istio14test1 - name of the cluster to setup
export ZONE=us-central1-a - zone where the cluster will be setup
export REGION=us-central2 - region where a regional cluster will be set up, overrides ZONE
export DNS_DOMAIN=test - domain to use for TLS cert testing
Optional environment:
export MACHINE_TYPE=n1-standard-4 - will use a small machine, for testing stability in small clusters
export IMAGE=UBUNTU - will use ubuntu instead of the recommended COS_CONTAINERD
export MIN_NODES=1 - will start with 1 instead of default 4
export ISTIO_VERSION - installed version of istio, will be set as a label on nodes

The script will create files to be used later in the setup in ConfigMap type:

  • ${CLUSTER_NAME}/google-cloud-key.json - will be used for authenticating control plane for GCP operations
  • ${CLUSTER_NAME}/kube.yaml - credentials for accessing k8s
  • ${CLUSTER_NAME}/configmap* - configmaps with GCP-specific configurations

Istio Setup

When installing storage for prometheus note that each cloud provider has its own labeling for storage. In the base/templates/prometheus-install.yaml file it has both the IBM cluster setup and GKE cluster setup. Before running the setup_istio.sh script please remove from the base/templates/prometheus-install.yaml the section that does not correspond to the cluster provider.

The setup_istio.sh scripts is a helper to install Istio with specific configurations for performance testing. The script provides a few ways to specify which version to install:

  • TAG: for example 1.6-dev. This will download the latest dev build for the tag.
  • DEV_VERSION: for example, 1.4-alpha.41dee99277dbed4bfb3174dd0448ea941cf117fd. This will download the specific dev build.
  • VERSION: for example, 1.2.3. This will download a specific release version specified.
  • RELEASE_URL: for example, https://example.com/istio.tar.gz. This will download an arbitrary tar.gz.
  • DNS_DOMAIN: for example, v104.qualistio.org. This will use for TLS cert testing.
  • GCS_URL: for example, gs://example/istio.tar.gz. Same as RELEASE_URL, but will use gsutil to download.

Additionally, installation values can be specified:

  • IOPS: used to specify file(s) for control plane install; defaults to istioctl_profiles/long-running.yaml,istioctl_profiles/long-running-gateway.yaml.

Architecture will be automatically detected, but can be overridden. For example, ARCH_SUFFIX=linux.

In addition to setting up the core Istio, the prometheus operator and gateways for the telemetry addons will be setup. Pass SKIP_EXTRAS to skip these.

Arguments to the script will be passed to istioctl during install. For example, to install the latest version with the default config file:

DNS_DOMAIN=v104.qualistio.org TAG=latest IOP=istioctl_profiles/custom-overlay.yaml ./setup_istio.sh