架构师进阶之九Consul+Openresty作为api gateway

本文介绍了API网关的作用,包括隐藏微服务细节、优化客户端请求等,并探讨了三种实现方式:nginx-upsync-module与Consul配合、OpenResty以及通过Consul实现的服务注册和发现。此外,还讨论了OpenResty可能的单点故障问题及解决方案。

什么是API gateway

  • 确保客户端无法察觉应用程序是如何被拆分为多项微服务的。
  • 确保客户端不受服务实例的位置的影响。
  • 为每套客户端提供最优API。
  • 降低请求/往返次数。举例来说,API网关能够确保客户端在单次往返中就从多项服务中检索出数据。请求数量更少意味着运行负担更低且用户体验更好。API网关对于移动应用而言是必不可少的。
  • 将从客户端调用多项服务的逻辑转换为从API网关处调用,从而简化整个客户端

实现方式

1. nginx-upsync-module

该模块可以使nginx动态同步service 配置,无需重启生效。可以配合着consul或者etcd一起使用

下面的例子就是使用的consul。

nginx-upsync-module - Nginx C module, sync upstreams from consul or others, dynamically modify backend-servers attribute(weight, max_fails,...), needn't reload nginx.

It may not always be convenient to modify configuration files and restart NGINX. For example, if you are experiencing large amounts of traffic and high load, restarting NGINX and reloading

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值