3

我们在 Kong API 网关后面有多个微服务实例,我们希望在其中平衡用户请求的负载。

假设微服务 1 在多个实例中相乘,这些实例保存在 KONG API 网关后面;在这种情况下,来自用户 1 的请求应该命中第一个实例,来自用户 2 的请求应该基于它们的可用性(负载平衡)命中同一服务的其他实例。(即)我是否可以在 kong 中为单个 API 提供多个上游 URL。我们不想使用 nginx 进行负载平衡。请建议我们如何解决它。

4

2 回答 2

5

如果您不想要基于 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)。

于 2018-01-22T06:30:25.073 回答
2

从 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/
于 2017-02-09T20:16:36.453 回答