您的位置:

replayer的全面解析

一、什么是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是一个很实用的生产工具,在美团点评等大型互联网企业中已经得到了广泛应用。它可以有力地支撑生产环境的可重放性,提供可靠的数据供排查和监控,极大提高了互联网企业的生产效率。