我们在 Kong API 网关后面有多个微服务实例,我们希望在其中平衡用户请求的负载。
假设微服务 1 在多个实例中相乘,这些实例保存在 KONG API 网关后面;在这种情况下,来自用户 1 的请求应该命中第一个实例,来自用户 2 的请求应该基于它们的可用性(负载平衡)命中同一服务的其他实例。(即)我是否可以在 kong 中为单个 API 提供多个上游 URL。我们不想使用 nginx 进行负载平衡。请建议我们如何解决它。
我们在 Kong API 网关后面有多个微服务实例,我们希望在其中平衡用户请求的负载。
假设微服务 1 在多个实例中相乘,这些实例保存在 KONG API 网关后面;在这种情况下,来自用户 1 的请求应该命中第一个实例,来自用户 2 的请求应该基于它们的可用性(负载平衡)命中同一服务的其他实例。(即)我是否可以在 kong 中为单个 API 提供多个上游 URL。我们不想使用 nginx 进行负载平衡。请建议我们如何解决它。
如果您不想要基于 DNS 的负载平衡,可以在 Kong 中使用环平衡器策略。详细请参考Kong负载均衡参考!
# create an upstream
$ curl -X POST http://kong:8001/upstreams \
--data "name=address.v1.service"
# add two targets to the upstream
$ curl -X POST http://kong:8001/upstreams/address.v1.service/targets \
--data "target=192.168.34.15:80"
--data "weight=100"
$ curl -X POST http://kong:8001/upstreams/address.v1.service/targets \
--data "target=192.168.34.16:80"
--data "weight=50"
# create an API targeting the Blue upstream
$ curl -X POST http://kong:8001/apis/ \
--data "name=address-service" \
--data "hosts=address.mydomain.com" \
--data "upstream_url=http://address.v1.service/address"
主机头设置为 address.mydomain.com 的请求现在将由 Kong 代理到两个定义的目标;2/3 的请求将转到http://192.168.34.15:80/address(权重=100),1/3 将转到http://192.168.34.16:80/address(权重=50)。
从 0.10 开始,您将能够创建一个命名的上游,并从中关联/删除目标。
例如,如果您有upstream_url=http://helloworld/
,您可以创建一个helloworld
上游并将目标关联到它:
curl -d "name=helloworld" 127.0.0.1:8001/upstreams
curl -d "host=some.host.com" 127.0.0.1:8001/upstreams/helloworld/targets/
curl -d "host=2.2.2.2" 127.0.0.1:8001/upstreams/helloworld/targets/