.. _common_configuration_zone_aware_routing: How do I configure zone aware routing? ====================================== There are several steps required for enabling :ref:`zone aware routing <arch_overview_load_balancing_zone_aware_routing>` between source service ("cluster_a") and destination service ("cluster_b"). Envoy configuration on the source service ----------------------------------------- This section describes the specific configuration for the Envoy running side by side with the source service. These are the requirements: * Envoy must be launched with :option:`--service-zone` option which defines the zone for the current host. * Both definitions of the source and the destination clusters must have :ref:`EDS <envoy_v3_api_field_config.cluster.v3.Cluster.type>` type. * :ref:`local_cluster_name <envoy_v3_api_field_config.bootstrap.v3.ClusterManager.local_cluster_name>` must be set to the source cluster. Only essential parts are listed in the configuration below for the cluster manager. .. code-block:: yaml cluster_manager: local_cluster_name: cluster_a static_resources: clusters: - name: cluster_a type: EDS eds_cluster_config: ... - name: cluster_b type: EDS eds_cluster_config: ... Envoy configuration on the destination service ---------------------------------------------- It's not necessary to run Envoy side by side with the destination service, but it's important that each host in the destination cluster registers with the discovery service :ref:`queried by the source service Envoy <config_overview_management_server>`. :ref:`Zone <envoy_v3_api_msg_config.endpoint.v3.LocalityLbEndpoints>` information must be available as part of that response. Only zone related data is listed in the response below. .. code-block:: yaml locality: zone: us-east-1d Infrastructure setup -------------------- The above configuration is necessary for zone aware routing, but there are certain conditions when zone aware routing is :ref:`not performed <arch_overview_load_balancing_zone_aware_routing_preconditions>`. Verification steps ------------------ * Use :ref:`per zone <config_cluster_manager_cluster_per_az_stats>` Envoy stats to monitor cross zone traffic.