Thrift vs  Grpc内容如下链接

http://blog.csdn.net/dazheng/article/details/48830511

背景:Facebook 开发的远程服务调用框架 Apache Thrift,它采用接口描述语言定义并创建服务,支持可扩展的跨语言服务开发,所包含的代码生成引擎可以在多种语言中创建高效的、无缝的服务,其传输数据采用二进制格式,相对 XML 和 JSON 体积更小,对于高并发、大数据量和多语言的环境更有优势。

负责的搜索服务使用thrift,之前是对其http的上游服务进行压测,从而压到该thrift服务;后续想调研一种方式能够直接对thrift服务进行压测。

thrift框架的C++小程序见:http://www.cnblogs.com/zhaoxd07/p/5387215.html

调研方向:

一 Jmeter

具体逻辑与使用Jmeter进行java请求的压测方式相似:http://www.cnblogs.com/zhaoxd07/p/4895224.html

区别在于setUp中对于协议的选择,会对结果有较大影响

TProtocol protocol = new TCompactProtocol(transport);
client = new Service.Client(protocol);

原则为:与被测代码使用协议一致即可

二 bender

https://github.com/pinterest/bender

为Pinterest公司开发的,可以对http和thrift协议做压测,使用go语言实现的。我试了一下挺好用的,就是go语言用不太习惯

主要难点在于main.go文件的实现,与Jmeter需要注意点一致:协议的使用

具体操作步骤如下:

1  Go环境初始化

1)  下载安装

# 下载安装go
cd /usr/local/ 自己选择安装目录和工作目录
wget https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz
tar -xzvf go1.8.3.linux-amd64.tar.gz

2) 配置环境变量

# 环境变量配置
vim /etc/profile 增加如下行:
#go variable
export GOROOT=/usr/local/go
export PATH=$PATH:/usr/local/go/bin
export GOPATH=/data/bender/
export GOBIN=/data/bender/bin
完成后保存 并使其生效 source /etc/profile

3) 确认变量配置是否生效

#echo $GOROOT
/usr/local/go

2  下载安装需要的插件

cd $GOPATH
go get git.apache.org/thrift.git/lib/go/thrift
go get github.com/pinterest/bender

3 准备server和client

准备server和client

因为我这是个实际项目,server已经由开发同学实现并启动,所以此时只需要准备server即可。如下

Server

cd $GOPATH/workspace/myProject/                # 进入我的工作目录
rz my_interface.thrift # 上传我的接口文件
thrift -gen go my_interface.thrift # 将thrift文件转成go语言

4 准备压测脚本bender

编写压测文件 在myProject目录下 新建 myBender文件夹,vim main.sh如下:

package main

// import 若提示有错,就看下目录下文件是否可用
import (
"github.com/pinterest/bender"
bthrift "github.com/pinterest/bender/thrift"
"git.apache.org/thrift.git/lib/go/thrift"
....
"github.com/pinterest/bender/hist"
) // 准备压测数据,我用的服务的日志,解析后作为请求发送,相当于回放
func SyntheticRequests(n int) chan interface{} {
f, err := os.Open("./advanced_search.info")
paramList := make([]*as.QueryParam, )
if err != nil {
panic(err)
}
defer f.Close() rd := bufio.NewReader(f)
for {
line, err := rd.ReadString('\n') if err != nil || io.EOF == err {
break
} else {
json_transport := thrift.NewTMemoryBufferLen(len([]rune(line)))
json_transport.WriteString(line)
json_protocol := thrift.NewTJSONProtocol(json_transport)
param := as.NewQueryParam()
param.Read(json_protocol)
paramList = append(paramList, param)
}
}
max := len(paramList)
c := make(chan interface{}, )
go func() {
for i := ; i < n; i++ {
rand.Seed(int64(time.Now().Nanosecond()))
c <- paramList[rand.Intn(max)]
}
close(c)
}()
return c
} //重要:需要跟服务端所用协议一致
func ASExecutor(request interface{}, transport thrift.TTransport) (interface{}, error) {
pFac := thrift.NewTCompactProtocolFactory()
client := as.NewRecommendSrvClientFactory(transport, pFac)
return client.GetCampaigns(request.(*as.QueryParam))
} // 主要是用bender的接口,完成压测
func main() {
intervals := bender.ExponentialIntervalGenerator() // 150 -- qps
requests := SyntheticRequests(**) //总请求数
//buffer字节数, clientExec, 超时时间, hosts--写server所在的ip和端口,如非同一机器,保证端口可访问
exec := bthrift.NewThriftRequestExec(thrift.NewTBufferedTransportFactory(), ASExecutor, * time.Second, "127.0.0.1:9099")
recorder := make(chan interface{}, )
bender.LoadTestThroughput(intervals, requests, exec, recorder)
l := log.New(os.Stdout, "", log.LstdFlags)
h := hist.NewHistogram(, )
bender.Record(recorder, bender.NewLoggingRecorder(l), bender.NewHistogramRecorder(h))
fmt.Println(h)
}

5 运行及结果

1  编译

cd $GOPATH
go install workspace/asthrift/asbender // main.go在目录asbender下

编译后的可执行文件在目录bin下,貌似新文件不能直接覆盖旧文件,因此我会先手动删除旧文件

2 执行

如下结果是因为所请求的server未启动(因该服务现阶段不属于我维护,该结果仅做参考示例)

[root@ip bin]#./asbender
Percentiles:
Min:
Median:
90th:
99th:
.9th:
.99th:
Max:
Stats:
Average: 0.923222
Total requests:
Elapsed Time (sec): 59.5483
Average QPS: 151.14
Errors:
Percent errors: 100.00

6 问题与解决

使用直接下载的bender运行时,会打印出请求的详细资料,导致压测的qps不能完成预期,可手动注释掉bender相关代码,并重新编译。

vim src/github.com/pinterest/bender/recorders.go,注释掉第44行。

  // NewLoggingRecorder creates a new log.Logger-based recorder.
func NewLoggingRecorder(l *log.Logger) Recorder {
return func(msg interface{}) {
// logMessage(l, msg)
}
}

删除目录下的pkg/linux_amd64/github.com/pinterest/bender.a文件,并重新编译:

go install github.com/pinterest/bender

thrift协议的服务进压力测试的更多相关文章

  1. 在Centos下使用Siege对Django服务进行压力测试

    Siege是linux下的一个web系统的压力测试工具,支持多链接,支持get和post请求,可以对web系统进行多并发下持续请求的压力测试.今天我们就使用Siege来对Django进行一次压力测试, ...

  2. 在Centos7.3下使用Siege对Django服务进行压力测试

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_87 Siege是linux下的一个web系统的压力测试工具,支持多链接,支持get和post请求,可以对web系统进行多并发下持续 ...

  3. 基于奇林软件kylinTOP工具的HTTP2协议的压力测试

    1.HTTP协议概述 说到http,那就应该先了解一下http协议的发展历史.关于http协议的历史,可以参考阮一峰老师的这篇博客文章HTTP 协议入门,里面介绍的比较详细了.简单来说http先后存在 ...

  4. [AapacheBench工具]web性能压力测试工具的应用与实践

    背景:网站性能压力测试是性能调优过程中必不可少的一环.服务器负载太大而影响程序效率是很常见的事情,一个网站到底能够承受多大的用户访问量经常是我们最关心的问题.因此,只有让服务器处在高压情况下才能真正体 ...

  5. 记一次压力测试和对nginx/tomcat配置的调整

    原文地址:还没找到 是一个web系统,前端使用nginx做为反向代理,处理https,并将请求转发给后端的tomcat服务. 压力测试工具选择了jmeter. 首先简单介绍一下jmeter. 它是ap ...

  6. 基于kylinTOP工具的HTTP2压力测试

    1.HTTP协议概述 说到http,那就应该先了解一下http协议的发展历史.关于http协议的历史,可以参考阮一峰老师的这篇博客文章HTTP 协议入门,里面介绍的比较详细了.简单来说http先后存在 ...

  7. HTTP压力测试工具

    HttpTest4Net是一款基于C#实现的和HTTP压力测试工具,通过工具可以简单地对HTTP服务进行一个压力测试.虽然VS.NET也集成了压力测试项目,但由于VS自身占用的资源导致了在配置不高的P ...

  8. Http压力测试工具HttpTest4Net

    HttpTest4Net是一款基于C#实现的和HTTP压力测试工具,通过工具可以简单地对HTTP服务进行一个压力测试.虽然VS.NET也集成了压力测试项目,但由于VS自身占用的资源导致了在配置不高的P ...

  9. 使用wrk进行压力测试

    最近需要对新的服务进行压力测试.比较了ab和jemeter以及wrk.最终选择wrk来作为压力测试工具,可以把cpu压到100%. 官方源码: https://github.com/wg/wrk 安装 ...

随机推荐

  1. React Native组件(二)View组件解析

    相关文章 React Native探索系列 React Native组件系列 前言 了解了RN的组件的生命周期后,我们接着来学习RN的具体的组件.View组件是最基本的组件,也是首先要掌握的组件,这一 ...

  2. android代码常识

    查看当前android代码版本号:build/core/version_defaults.mk---->查找platform_version android源码在线阅读网址 http://and ...

  3. 音乐随想——德沃夏克《From The New World》

    第一乐章 前奏拖的很长,低音,再低音.突然转向,好像漂泊数月的水手看到了新大陆. 第二乐章 前奏很优美,到双簧管出现的时候宛若紫霞仙子撑船自芦苇荡中飘过. 之后又一段较前奏稍快的旋律,好像看到了梦寐的 ...

  4. 基本SQL命令

    1.SQL命令的使用规则 1.每条命令必须以 ; 结尾 2.SQL命令不区分字母大小写 3.使用 \c 来终止当前命令的执行 2.库的管理 1.库的基本操作 1.查看已有库 show database ...

  5. GCD基础

    一.GCD介绍 1.what is GCD? Grand Central Dispatch 中枢调度器.用很简单的方式实现了极为复杂繁琐的多线程编程.异步执行任务的技术之一.   2.GCD存在于li ...

  6. VC dimension and Model complexity

    可以把growth function m_H(N)的upper bound用N^(k-1)来限制, for N large, k>=3 Thus, 定义: VC Dimension: maxim ...

  7. 每天一个linux命令:【转载】more命令

    more命令,功能类似 cat ,cat命令是整个文件的内容从上到下显示在屏幕上. more会以一页一页的显示方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会 ...

  8. 51nod 1347 旋转字符串

    S[0...n-1]是一个长度为n的字符串,定义旋转函数Left(S)=S[1…n-1]+S[0].比如S=”abcd”,Left(S)=”bcda”.一个串是对串当且仅当这个串长度为偶数,前半段和后 ...

  9. Linux驱动开发基础知识

    常用命令 lsmod: list module,将模块列表显示),功能是打印出当前内核中已经安装的模块列表 insmod: install module,安装模块,功能是向当前内核中去安装一个模块,用 ...

  10. 一款直接时空处理分析的开源数据库---geomesa

    一款直接时空处理分析的开源数据库---geomesa,可用于交通轨迹数据存储分析等相关领域, 在分布式列数据库的基础上进行扩展,目前支持Accumulo, HBase, Cassandra, and ...