ghz: grpc load testing tool

栏目: 服务器 · 发布时间: 4年前

服务支持了Grpc,服务的性能怎么样,相比我们都是非常关注的。如何做load test 是最近我在做的事情。

我们知道大概有两种方式,第一种是自己输出一个解决方案,最终需要输出的可能是一个可视化的站点;另一种方案,就是使用已经成熟的方案。我们可能知道很多http请求的load test方案,可Grpc相关的能找到的并不多,我在社区中找到了一个开源方案,ghz

ghz包含两部分内容,project和report。我觉得project可以理解成一个grpc服务,可以包含多个report,也就是每次跑出来的性能报告。

ghz提供的方案思路是这样的,通过模拟请求的方式数据各项性能指标存储到数据库,然后从数据库取出来通过图形化方式展示出来。

ghz是用golang实现的,提供了一个report包,另外提供了命令行 工具 和一个web应用服务

首先,模拟请求生成指标数据,提供了两种方式。一种是可以通过ghz命令行生成报告,另外一种就是调用report包输出报告。

然后,需要部署ghz web站点。GitHub上已经有一些release包,解压之后有一个ghz.exe和 一个ghz-web.exe文件,可通过 https://github.com/bojand/ghz/releases 下载,我下载的版本是v0.37.0。具体的部署步骤可参考 https://ghz.sh/docs/web/intro 。在选择数据库时需要注意,sqlite和 mysql 都可能都导致web应用启动失败,最后我使用了postgres

最后,把数据保存到数据库,ghz的web站点提供了api,可以通过api 把报告数据post到数据库。这样web站点就可以看到对应project的报告了

在导入数据的步骤,如果使用ghz命令是非常人工的,因为web应用创建的project信息太少,导致在web上不能直接运行,如有需要,可自行扩展。目前我的做法是,部署一个应用,用report包提供的方法生成报告,然后post到数据库,这个应用只需要配置grpc的参数即可跑出报告。

附ghz源码: https://github.com/bojand/ghz

如有问题或者更正信息,欢迎访问 https://github.com/figodeng/QAndA


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

jQuery基础教程

jQuery基础教程

Jonathan Chaffer、Karl Swedberg / 李松峰、卢玉平 / 人民邮电出版社 / 2009-11 / 49.00元

《jQuery基础教程(第2版)》作为《jQuery基础教程》的升级版,涵盖了jQuery 1.3的全部新特性,特别是新增了介绍jQuery UI(jQuery官方用户界面插件库)的内容。《jQuery基础教程(第2版)》前6章以通俗易懂的方式介绍了jQuery的基本概念,主要包括jQuery的选择符、事件、效果、DOM操作、AJAX支持等。随后3章从理论到实践,通过表格操作、构建功能型表单、实现......一起来看看 《jQuery基础教程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

URL 编码/解码
URL 编码/解码

URL 编码/解码