Before you begin
Before you begin the locality load balancing tasks, you must first install Istio on multiple clusters6. The clusters must span three regions, containing four availability zones. The number of clusters required may vary based on the capabilities offered by your cloud provider.
We will deploy several instances of the HelloWorld
application as follows:
Environment Variables
This guide assumes that all clusters will be accessed through contexts in the default Kubernetes configuration file7. The following environment variables will be used for the various contexts:
Variable | Description |
---|---|
CTX_PRIMARY | The context used for applying configuration to the primary cluster. |
CTX_R1_Z1 | The context used to interact with pods in region1.zone1 . |
CTX_R1_Z2 | The context used to interact with pods in region1.zone2 . |
CTX_R2_Z3 | The context used to interact with pods in region2.zone3 . |
CTX_R3_Z4 | The context used to interact with pods in region3.zone4 . |
Create the sample
namespace
To begin, generate yaml for the sample
namespace with automatic sidecar
injection enabled:
Add the sample
namespace to each cluster:
Deploy HelloWorld
Generate the HelloWorld
YAML for each locality, using the
locality as the version string:
Apply the HelloWorld
YAML to the appropriate cluster for each locality:
Deploy Sleep
Deploy the Sleep
application to region1
zone1
:
Wait for HelloWorld
pods
Wait until the HelloWorld
pods in each zone are Running
:
Congratulations! You successfully configured the system and are now ready to begin the locality load balancing tasks!
Next steps
You can now configure one of the following load balancing options: