## 服務發現
- [LbEndpoint](#lbendpoint)
- [LocalityLbEndpoints](#localitylbendpoints)
- [ClusterLoadAssignment](#clusterloadassignment)
- [ClusterLoadAssignment.Policy](#clusterloadassignmentpolicy)
### LbEndpoint
[LbEndpoint proto](https://github.com/envoyproxy/data-plane-api/blob/master/api/eds.proto#L62)
EndPoint是指Envoy可以將流量路由到的端口。
```
{
"endpoint": "{...}",
"metadata": "{...}",
"load_balancing_weight": "{...}"
}
```
- **endpoint**<br />
([Endpoint](../v2APIreference/Commontypes.md)) 上游主機標識符
- **metadata**<br />
([Metadata](../v2APIreference/Commontypes.md)) 負載均衡端口元數據是指可用于為請求選擇群集中的端口。過濾器名稱應該指定為`envoy.lb`。一個bool類型的鍵值對例子為`canary`,提供上游主機的可選`canary`狀態。這可以在路由的`ForwardAction` `metadata_match`字段中匹配,以在集群負載平衡中考慮的端口子集。
- **load_balancing_weight**<br />
([UInt32Value](https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#uint32value)) 上游主機的可選負載平衡權重,范圍為1~128. 在某些內置Envoy負載平衡器中,會使用負載平衡權重。端口的負載平衡權重除以本地所有端口權重的總和,以獲得端口的所占通信量百分比。然后這個百分比再由來自`LocalityLbEndpoints`的端點的本地負載平衡權重加權。如果沒有指定,每個主機被假定在一個地方具有相同的權重。
注意:當前128的限制是有些隨意,但是考慮當前實現的性能問題而使用,若解決這個問題是可以取消這個限制。
### LocalityLbEndpoints
[LocalityLbEndpoints proto](https://github.com/envoyproxy/data-plane-api/blob/master/api/eds.proto#L100)
一組端口歸屬一個局部負載均衡器。一個本地可以有多個局部負載均衡器,通常只有在不同的組之間需要負載平衡權重或不同的優先級時,才會使用多個組。
```
{
"locality": "{...}",
"lb_endpoints": [],
"load_balancing_weight": "{...}",
"priority": "..."
}
```
- **locality**<br />
([Locality](../v2APIreference/Commontypes.md)) 標識上游主機運行的位置。
- **lb_endpoints**<br />
([LbEndpoint](#lbendpoint)) 所屬的端口組配置。
- **load_balancing_weight**<br />
([UInt32Value](https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#uint32value)) 可選:配置每個端口組的優先級、`region`、`zone`、`sub_zone`權重,范圍1~128。一個端口組的負載均衡權重除以相同優先級的所有權重之和,獲得該端口組的承載業務有效百分比。
必須為相同優先級的所有局部端口組指定權重,若不指定,則認為每個局部在群集中具有相同的權重。
注意:當前128的限制是有些隨意,但是考慮當前實現的性能問題而使用,若解決這個問題是可以取消這個限制。
- **priority**<br />
([uint32](https://developers.google.com/protocol-buffers/docs/proto#scalar)) 可選:此局部負載均衡端口組的優先級。如果未指定,則默認為最高優先級(0)。
一般情況下,Envoy只會選擇最高優先級(0)的端口。如果該優先級的所有端口不可用/不健康,Envoy將快速故障恢復至下一個最高優先級的端口組。
優先級應該配置為從0(最高)到N(最低),中間沒有間隔。
### ClusterLoadAssignment
[ClusterLoadAssignment proto](https://github.com/envoyproxy/data-plane-api/blob/master/api/eds.proto#L244)
從RDS中獲取的路由,映射到單個集群或者使用RDS集群權重實現跨集群的流量拆分。
使用EDS,每個集群都有獨立的LB進行處理,將在集群內的產生局部LB,即在一個局部主機之間具有更細粒度的LB。對于給定的集群,主機的有效權重是其`load_balancing_weight`乘以其局部的LB權重`load_balancing_weight`。
```
{
"cluster_name": "...",
"endpoints": [],
"policy": "{...}"
}
```
- **cluster_name**<br />
([string](https://developers.google.com/protocol-buffers/docs/proto#scalar), REQUIRED) 集群的名稱。如果在集群[EdsClusterConfig](../v2APIreference/ClustersandCDS.md)中指定,則是`service_name`值。
- **endpoints**<br />
([LocalityLbEndpoints](#localitylbendpoints)) 對應的局部端口組列表。
- **policy**<br />
([ClusterLoadAssignment.Policy](#clusterloadassignmentpolicy)) 負載均衡策略設置。
### ClusterLoadAssignment.Policy
[ClusterLoadAssignment.Policy proto](https://github.com/envoyproxy/data-plane-api/blob/master/api/eds.proto#L255)
負載平衡策略設置。
```
{
"drop_overload": "..."
}
```
- **drop_overload**<br />
([double](https://developers.google.com/protocol-buffers/docs/proto#scalar)) 應該丟棄的流量(0-100)的百分比。如果上游主機無法從down機中恢復,或者無法進行自動調整,則需要對上游主機進行保護,因此需要修整整個傳入流量以保護它們。
注意:v2 API與v1 API存在差異,在v1中被稱為維護模式。
## 返回
- [上一級](../v2APIreference.md)
- [首頁目錄](../README.md)
- 首頁
- 簡介
- Envoy是什么
- 架構介紹
- 術語
- 線程模型
- 監聽器
- L3/L4網絡過濾器
- HTTP連接管理
- HTTP過濾器
- HTTP路由
- gRPC
- WebSocket支持
- 集群管理
- 服務發現
- 健康檢查
- 連接池
- 負載均衡
- 異常檢測
- 熔斷
- 全局限速
- TLS
- 統計
- 運行時配置
- 跟蹤
- TCP代理
- 訪問日志
- MongoDB
- DynamoDB
- Redis
- 熱重啟
- 動態配置
- 初始化
- 逐出
- 腳本
- 部署
- 業界對比
- 獲得幫助
- 歷史版本
- 編譯安裝
- 編譯
- 參考配置
- 演示沙箱
- 前端代理
- Zipkin跟蹤
- Jaeger跟蹤
- gRPC橋接
- 構建Envoy Docker鏡像
- 工具
- 配置參考
- V1 API 概述
- V2 API 概述
- 監聽器
- 網絡過濾器
- TLS客戶端身份認證
- Echo
- Mongo代理
- 速率限制
- Redis代理
- TCP代理
- HTTP連接管理器
- 路由匹配
- 流量轉移/分流
- HTTP頭部操作
- HTTP頭部清理
- 統計
- 運行時設置
- 路由發現服務
- HTTP過濾器
- 緩存
- CORS過濾器
- 故障注入
- DynamoDB
- gRPC HTTP/1.1 橋接
- gRPC-JSON 轉碼過濾器
- gRPC-Web 過濾器
- 健康檢查
- 速率限制
- 路由
- Lua
- 集群管理
- 統計
- 運行時設置
- 集群發現服務
- 健康檢查
- 熔斷
- 訪問日志
- 限速服務
- 運行時配置
- 路由表檢查工具
- 運維管理
- 命令行選項
- 熱重啟
- 管理接口
- 統計概述
- 運行時配置
- 文件系統
- 自定義擴展示例
- V1 API參考
- 監聽器
- 網絡過濾器
- TLS客戶端身份認證
- Echo
- HTTP連接管理
- Mongo代理
- 速率限制
- Redis代理
- TCP代理
- HTTP路由配置
- 虛擬主機
- 路由
- 虛擬集群
- 速率限制配置
- 路由發現服務
- HTTP過濾器
- 緩存
- CORS過濾器
- DynamoDB
- 故障注入
- gRPC HTTP/1.1 橋接
- gRPC-JSON 轉碼過濾器
- gRPC-Web 過濾器
- 健康檢查
- Lua
- 速率限制
- 路由
- 集群管理
- 集群
- 健康檢查
- 熔斷
- TLS上下文
- 異常值檢測
- HASH環負載均衡配置
- 異常檢測
- 集群發現服務
- 服務發現服務
- 訪問日志
- 管理接口
- 限速服務
- 運行時配置
- 跟蹤
- V2 API參考
- 啟動引導
- 監聽&監聽發現
- 集群&集群發現
- 服務發現
- 健康檢查
- HTTP路由管理&發現
- TLS配置
- 通用的類型
- 網絡地址
- 協議選項
- 發現API
- 限速組件
- 過濾器
- 網絡過濾器
- TLS客戶端身份認證
- HTTP連接管理
- Mongo代理
- 速率限制
- Redis代理
- TCP代理
- HTTP過濾器
- 緩存
- 故障注入
- 健康檢查
- Lua
- 速率限制
- 路由
- gRPC-JSON轉碼器
- 常見訪問日志類型
- 常見故障注入類型
- FAQ
- Envoy有多快?
- 我在哪里獲得二進制文件?
- 我如何設置SNI?
- 如何設置區域感知路由?
- 我如何設置Zipkin跟蹤?