Ada*_*dam 3 google-cloud-platform
我想配置 Google 可以负载平衡,以便:
全局转发规则
目标代理
网址映射
这不起作用。
通过此设置,如果我将 redirect_backend 端口设置为 8081,则 webapp_backend 端口也将更改为 8081。同样,如果我将 webapp_backend 端口设置为 8080,则 redirect_backend 端口将设置为 8080。
是否可以将基于端口的流量路由到不同的后端?选项是它们在 GUI 中,没有验证错误,感觉应该是可能的,但是当设置后端端口时,所有后端都设置为相同的端口?
我知道将 HAProxy 放在节点上是一种解决方案,并在那里反向代理微服务,但我宁愿让 Google Cloud Application Loadbalancer 终止 SSL 作为使用 f1-micro 实例。
做到这一点的关键是https://cloud.google.com/compute/docs/load-balancing/http/backend-service#restrictions_and_guidance 上一个很容易遗漏的片段。
如果您不将同一个实例组添加到两个不同的后端,您的配置会更简单。如果您将同一个实例组添加到两个后端:
...
如果您的实例组分别为多个后端服务两个或多个端口,则您必须在实例组中指定不同的端口名称。
初始设置非常重要,因此以下是参考。
基于我的配置中的示例:
确保您有防火墙规则允许 Google 对您的服务进行健康检查访问:
gcloud compute firewall-rules create allow-http-from-lb \
--description "Incoming http allowed from cloud loadbalancer." \
--allow tcp:80
--source-ranges "130.211.0.0/22"
gcloud compute firewall-rules create allow-http-redirect-from-lb \
--description "Incoming http redirect service allowed from cloud loadbalancer." \
--allow tcp:8081
--source-ranges "130.211.0.0/22"
Run Code Online (Sandbox Code Playgroud)
确保您为两个服务设置了健康检查,检查正确的内部端口。
gcloud compute http-health-checks create webapp-healthcheck \
--description "Main webapp healthcheck" \
--port 80 \
--request-path "/healthcheck"
gcloud compute http-health-checks create httpsredirect-service-healthcheck \
--description "HTTP redirect service healthcheck" \
--port 8081 \
--request-path "/healthcheck"
Run Code Online (Sandbox Code Playgroud)
如果您的实例组有多个在不同端口上运行的微服务,并且您希望在公共负载均衡器下公开这些微服务,那么看起来是关键。
将INSTANCE_GROUP_NAME,REGION和替换named-ports为您的服务的正确值。
gcloud compute instance-groups set-named-ports INSTANCE_GROUP_NAME \
--region=REGION \
--named-ports "webapp:80,httpsredirectservice:8081"
Run Code Online (Sandbox Code Playgroud)
确保--port-name匹配上一步中的正确命名端口。
gcloud compute backend-services create webapp-lb-backend \
--http-health-check webapp-healthcheck \
--protocol http \
--description "Webapp load balancer backend" \
--port-name webapp
gcloud compute backend-services create httpsredirect-lb-backend \
--http-health-check webapp-healthcheck \
--protocol http \
--description "HTTP -> HTTPS redirect service load balancer backend" \
--port-name httpsredirectservice
Run Code Online (Sandbox Code Playgroud)
确保--default-service使用上一步中配置的值。
gcloud compute url-maps create webapp-urlmap \
--default-service webapp-lb-backend
gcloud compute url-maps create httpsredirect-urlmap \
--default-service httpsredirect-lb-backend
Run Code Online (Sandbox Code Playgroud)
目标代理由一个或多个全局转发规则引用,并将传入的 HTTP 或 HTTPS 请求路由到 URL 映射。
我们为 webapp 创建一个 https 目标代理,以在负载均衡器上终止 SSL。
gcloud compute target-https-proxies create webapp-target-proxy \
--url-map webapp-urlmap \
--ssl-certificate [SSL_CERTIFICATES]
Run Code Online (Sandbox Code Playgroud)
重定向服务:
gcloud compute target-http-proxies create httpsredirect-target-proxy \
--url-map httpsredirect-urlmap
Run Code Online (Sandbox Code Playgroud)
最后一步是创建全局转发规则
gcloud compute forwarding-rules create webapp-forwarding-rule
--global \
--address LB_STATIC_IP \
--port-range 443 \
--target-https-proxy webapp-target-proxy
gcloud compute forwarding-rules create httpsredirect-forwarding-rule
--global \
--address LB_STATIC_IP \
--port-range 80 \
--target-http-proxy httpsredirect-target-proxy
Run Code Online (Sandbox Code Playgroud)
502错误,请检查云控制台中的负载均衡器报告健康实例AWS| 归档时间: |
|
| 查看次数: |
1767 次 |
| 最近记录: |