[READ ONLY MIRROR] Envoy REST/proto API definitions and documentation. (grpc依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

60 lines
1.7 KiB

.. _config_cluster_manager_sds_api:
Service discovery service REST API
==================================
Envoy expects the service discovery service to expose the following API (See Lyft's
`reference implementation <https://github.com/lyft/discovery>`_):
.. http:get:: /v1/registration/(string: service_name)
Asks the discovery service to return all hosts for a particular `service_name`. `service_name`
corresponds to the :ref:`service_name <config_cluster_manager_cluster_service_name>` cluster
parameter. Responses use the following JSON schema:
.. code-block:: json
{
"hosts": []
}
hosts
*(Required, array)* A list of :ref:`hosts <config_cluster_manager_sds_api_host>` that make up
the service.
.. _config_cluster_manager_sds_api_host:
Host JSON
---------
.. code-block:: json
{
"ip_address": "...",
"port": "...",
"tags": {
"az": "...",
"canary": "...",
"load_balancing_weight": "..."
}
}
ip_address
*(required, string)* The IP address of the upstream host.
port
*(required, integer)* The port of the upstream host.
.. _config_cluster_manager_sds_api_host_az:
az
*(optional, string)* The optional zone of the upstream host. Envoy uses the zone for various
statistics and load balancing tasks documented elsewhere.
canary
*(optional, boolean)* The optional canary status of the upstream host. Envoy uses the canary
status for various statistics and load balancing tasks documented elsewhere.
load_balancing_weight
*(optional, integer)* The optional load balancing weight of the upstream host, in the range
1 - 100. Envoy uses the load balancing weight in some of the built in load balancers.