配置事件调度程序

云眼About 2 min

配置事件调度程序

本主题介绍如何为云眼灰度发布(特性标帜)AB实验 Ruby SDK 中每次展示或转化发出的 HTTP 请求配置事件调度程序。

云眼灰度发布(特性标帜)AB实验 SDK 为每个触发的决策事件或转化事件发出 HTTP 请求。每个 SDK 都有一个内置的事件调度程序来处理这些事件,但我们建议根据环境的具体情况重写它。

Ruby SDK 有一个开箱即用的同步调度程序。建议自定义在生产中使用的事件调度程序,以确保以可扩展到应用程序处理的卷的方式对事件进行排队和发送。通过自定义事件调度程序,可以利用批处理等功能,从而更轻松地有效地处理大型事件量或在请求失败时实现重试逻辑。可以从头开始构建调度程序,也可以从提供的调度程序开始。

🚧 重要

同步调度程序的性能风险:将 SDK 与同步内置事件调度程序(PHP、Ruby 和 Python)一起使用时,自定义事件调度程序非常重要,以确保无需等待相应的网络请求返回即可检索变体。

这些示例显示,要自定义事件调度程序,请使用事件调度程序实例初始化 Eyeofcloud 客户端(或管理器)。

Ruby

# Create an Eyeofcloud client with the default event dispatcher 
eyeofcloud_client = Eyeofcloud::Project.new(datafile,                                             
                                            Eyeofcloud::EventDispatcher.new)

事件调度程序应实现一个dispatchEvent函数,该函数接受三个参数:httpVerburlparams,所有这些都由内部类EventBuilder创建。在此函数中,应该使用params作为请求的主体(确保将其字符串化为 JSON)和标头中{content-type: 'application/json'}向给定的url请求发送POST请求。

🚧 重要

如果使用的是自定义事件调度程序,请不要修改从云眼灰度发布(特性标帜)AB实验返回的事件负载。修改此有效负载将更改结果。

我们的 Ruby SDK 包含一个基本的同步事件调度器open in new window。如果在生产环境中使用 SDK,则应使用所选的网络库提供自己的事件调度程序。此处提供了替代方法的示例:

Last update:
Contributors: zhangweixue,“zhangweixue”