BFE 初探

概述

什么是 BFE?一块儿来看下官方介绍。前端

BFE(Baidu Front End)是百度的一款开源的应用负载均衡产品,目前已接入百度大部分流量,每日转发请求接近1万亿,峰值QPS超过1000万。在2019年百度春晚红包活动中,BFE平台在超大用户压力、数次流量波峰下平稳运行,保证了春晚红包活动的顺利进行。详情请查看 BFE 官网地址:https://www.bfe-networks.net,github 地址:https://github.com/baidu/bfe。git

BFE 源码是使用 GO 语言开发的,这篇文章咱们一块儿来认识 BFEgithub

我用 BFE 作什么?

我用 BFE 作网关,主要实现路由转发和过滤器,路由转发指的是,接收一切外部请求转发到后端微服务上,过滤器指的是,限流、鉴权、协议转化等等。web

BFE 还支持 日志、链路、监控等等。后端

BFE 基本概念

两大概念: 产品线和集群,见下图。

能解决哪些问题?

场景一:好比先后端分离项目,前端须要请求两个服务(服务A 和 服务B),服务A 和 服务B 的域名是不一样的,怎么解决这个问题?跨域

第一反应使用 跨域资源共享 CORS 去解决,固然须要浏览器和服务器同时支持。浏览器

一、后台须要新增代码:安全

设置 Access-Control-Allow-Origin,必选,要么是自定义设置域名,要么是 * 。服务器

设置 Access-Control-Allow-Methods,必选,设置容许请求的方法。微信

设置 Access-Control-Allow-Credentials,可选,是否容许发送 Cookie,默认状况下 Cookie 不包括在CORS请求之中。

设置 Access-Control-Expose-Headers,可选,设置其余的 Header 参数。

二、前端请求了两次(浏览器自动请求两次)

第一个请求是 OPTIONS 请求,也能够称为 “预检请求”,根据服务器返回的内容,判断服务器是否容许该请求访问。

第二个请求是 具体的 POST 或 GET 请求。

这个弊端是须要后端开发人员调整代码,同时浏览器请求两次,增长请求时间及服务器资源,还有没有更好的解决方案?有同窗确定会说 “设置 Access-Control-Max-Age 参数” 用来指定本次预检请求的有效期,单位为秒,好比设置 120s,表示在此期间内,不用发出另外一条预检请求,你还有没有其余方案?

能够使用 BFE 路由规则 和 重写规则就能搞定!好比:前端项目为 abc.com,当访问 abc.com/service-a/xxx 请求到服务A,当访问 abc.com/service-b/xxx 请求到服务B。

场景二:开发了一个服务A,目前微服务是内网访问的,假设有一种场景外网的客户端项目须要请求这个微服务,你怎么解决这个问题?

一、外网客户端项目,请求本身项目的 API,而后 API 项目再去请求订单管理微服务,进行数据返回,这样的弊端是增长了 API 开发人员的工做量。

二、服务A 直接配置外网能够访问,这样的弊端是安全风险太大,若是使用签名访问,也存在安全风险,同时还增长了前端人员的工做量。

可在将域名解析到负载均衡(LB)上,而后负载均衡(LB)去找下游的 BFE 配置。

场景三:上线一个新需求,想让一部分用户继续用老版本,一部分用户开始使用新版本,若是用户对新版本没有什么反对意见 或 研发未收到重大的问题反馈,而后再逐步扩大范围,把全部用户都迁移到新版本上来?另外这个比例是须要动态配置的,怎么去解决这个问题?

能够使用 BFE 集群配置,设置子集群的分流权重。

上面的主要使用了 路由转发 和 集群配置。

路由转发 相关配置文件以下:

  • server_data_conf/host_rule.data(域名规则)
  • server_data_conf/route_rule.data(分流规则)
  • server_data_conf/cluster_conf.data(集群配置文件)
  • mod_redirect/redirect.data(重定向规则)
  • mod_rewrite/rewrite.data(重写规则)

集群配置 相关配置文件以下:

  • cluster_conf/cluster_table.data(集群实例列表)
  • cluster_conf/gslb.data(子集群负载均衡)

如何使用?

根据官方介绍的每一个文件及每一个文件的配置项,进行配置,配置完了记得进行重启,部分文件支持热加载的方式,进行更新。

后面会挨个介绍每一个文件及其配置项。

小结

这篇文章主要是分享一些简单的介绍,初探,就先分享到这。

推荐阅读


本文分享自微信公众号 - 新亮笔记(XinLiangTalk)。
若有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一块儿分享。

相关文章
相关标签/搜索