Rainbond对微服务进行请求速率限制详解

2022-07-15,,,,

rainbond 默认支持基于 envoy 的全局速率限制。在 rainbond 默认提供的综合网络治理插件中呈现。本文我们将一个用例呈现 rainbond 中全局速率限制的使用方式。

前置条件

  1. rainbond平台已部署完成。
  2. 在rainbond中部署可访问的 demo 业务。
  3. 为此组件开通综合网络治理插件。

参考视频

https://player.bilibili.com/player.html?aid=540728010

rainbond 速率限制设置参考视频

操作流程

1.部署全局限制服务需要使用的 redis 组件,使用镜像redis:alpine创建组件,组件创建后在端口设置中将 6379 端口别名修改为redis,开启对内服务权限。

2.部署全局限制服务,使用镜像的方式部署全局限制服务。使用以下 dockerrun 命令创建组件,组件可部署到业务的同一个应用中。添加后使其依赖上步安装的 redis 组件。

docker run -e use_statsd=false -e redis_socket_type=tcp -e redis_url=${redis_host}:${redis_port} -e runtime_root=/data -e runtime_subdirectory=ratelimit -v /data/ -p 8081:8081 barnett/ratelimit:v1.4.0 /bin/ratelimit

添加成功后切换到组件端口设置页面,将 8081 端口对内服务打开并设置端口别名为rate_limit_server

默认使用的全局限制服务是 envoy 的默认实现,你可以根据 envoy 的速率限制服务 api 规范进行自定义实现。

3.添加速率限制配置文件

进入全局限制服务组件的环境管理中,添加配置文件,文件路径为 /data/ratelimit/config/config.yaml

domain: limit.common
descriptors:
  - key: remote_address
    rate_limit:
      unit: second
      requests_per_unit: 10

  # black list ip
  - key: remote_address
    value: 50.0.0.5
    rate_limit:
      unit: second
      requests_per_unit: 0

添加完配置文件后重启组件。

该配置的含义是通过请求来源 ip 进行速率限制,ip为 50.0.0.5 限制访问,其他 ip 地址限制每秒请求 10 次

4.业务组件依赖限制服务组件并更新插件配置

编辑拓扑图使业务组件依赖刚刚部署的速率限制服务组件,然后进入业务组件插件管理,点击已开通的综合治理插件的查看配置入口。在配置表单中做如下配置:

配置open_limit为yes

配置limit_domain为limit.common,该值与上面配置文件中的配置 domain 形成对应。

配置完成后更新插件配置即可。

5.验证速率限制是否生效

我们可以使用ab命令进行压力测试

ab -n 1000 -c 20 http://5000.gr425688.duaqtz0k.17f4cc.grapps.cn/

结果会显示如下:

concurrency level:      20
time taken for tests:   6.132 seconds
complete requests:      1000
failed requests:        794
   (connect: 0, receive: 0, length: 794, exceptions: 0)
non-2xx responses:      794

可见 1000 次请求有 794 次被限制,被速率限制驳回的请求访问码为429

常见问题

是否可以自定义开发速率限制服务

当然可以,本文采用的服务实现是envoy ratelimit,你可以基于api 规范自主实现。

是否支持更多速率限制策略

速率限制策略还可以支持基于请求头来进行限制,但目前仅支持基于来源 ip 地址。

以上就是rainbond对微服务进行请求速率限制详解的详细内容,更多关于rainbond对微服务进行请求速率限制的资料请关注其它相关文章!

《Rainbond对微服务进行请求速率限制详解.doc》

下载本文的Word格式文档,以方便收藏与打印。