一、什么是replayer
Replayer是一个用于在生产环境中对线上流量进行可重复性回放的工具,是在美团点评公司的实践中发展而来的,目的在于解决线上问题,提高问题排查效率。
美团点评在内部提出了一个理念——战时状态就是日常状态。因此,在日常状态下,Replayer可以通过回放历史请求,复现线上生产环境的实际情况;在出现问题时,可以使用Replayer对问题进行详细的还原,加快问题排查。
二、与realplayer的关系
replayer与realplayer是两个不同的东西,不要把它们混淆。RealPlayer是一款媒体播放器软件,Replayer是一款用于生产环境中重放历史请求的工具。Replayer可以将历史请求从文件中读取,并将它们在不同的环境下进行处理,可以用于性能测试、故障修复、安全分析等方面。
三、如何使用replayer
1、安装replayer
Replayer可以下载安装包安装。
2、操作步骤
通过replayer进行回放,可分为三步
(1)录制业务请求
replayer record --ip=127.0.0.1 --port=8080 --out=./output --dump-all-requests=http://localhost:8080
上述命令表示,在本地将请求转发到http://localhost:8080,同时将所有的请求响应保存在指定的目录下,方便之后进行回放
(2)在本地启动服务
replayer play --ip=127.0.0.1 --port=8888 --requests=./output
上述命令表示,在本地启动服务,监听8888端口,将之前录制的请求发送至该端口
(3)在浏览器中进行回放
启动服务后,打开浏览器,访问如下网址:
http://127.0.0.1:8888
即可进行回放
四、replayer的优缺点
1、优点
(1)回放流量准确无误:Replayer能够将历史请求原样发送,确保回放过程中不出错。
(2)流量采集灵活:Replayer能够解析多种数据协议,包括 HTTP、HTTPS、RPC 等协议,而且可以根据需要选择性地采集。
(3)支持多种回放机制:Replayer能够实现常规回放、压力回放、灰度回放等回放机制。
(4)兼容多重场景:Replayer不仅可以在生产环境中进行回放,还可以在测试、UAT环境中对新功能进行回归测试。
2、缺点
(1)实时回放耗时较长:对于实时回放的情况下,回放耗时更长。
(2)协议解析限制:由于Replayer的解析能力有限,可能无法解析所有的协议。
五、总结
Replayer是一个很实用的生产工具,在美团点评等大型互联网企业中已经得到了广泛应用。它可以有力地支撑生产环境的可重放性,提供可靠的数据供排查和监控,极大提高了互联网企业的生产效率。