Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zonghaishang/rpc-performance-test
https://github.com/zonghaishang/rpc-performance-test
dubbo rpc-benchmark sofa-rpc
Last synced: 18 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/zonghaishang/rpc-performance-test
- Owner: zonghaishang
- License: apache-2.0
- Created: 2020-04-10T01:54:29.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-06-10T20:02:35.000Z (over 2 years ago)
- Last Synced: 2024-11-08T09:15:56.188Z (2 months ago)
- Topics: dubbo, rpc-benchmark, sofa-rpc
- Language: Java
- Size: 21.5 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
一、在pom.xml引入测试api facade
二、获取压测工程
1. 获取rpc-performance工程
```shell
git clone https://github.com/zonghaishang/rpc-performance.git
# 本地install依赖和打包
mvn clean install package
```2. 解压rpc-performance-xx.tar.gz
```shell
tar -xzvf rpc-performance-xx.tar.gz
# 解压后生成rpc.benchmark目录
```三、开发压测接口实现类(eg: BenchmarkRandom_1k),并且继承AbstractExchangeRunnable并实现doInvoke方法
参考实现:
```java
public class BenchmarkRandom_1k extends AbstractExchangeRunnable {public BenchmarkRandom_1k(InvokeOption option) {
super(option);
}@Override
public Object doInvoke() {
/**
* 通过serviceFactory获取接口proxy,
* 如果返回值不为空并且没有异常抛出,认为调用成功.
*/
BenchmarkService benchmarkService = (BenchmarkService) serviceFactory.getReference(BenchmarkService.class);
return benchmarkService.send_1k(randomString(1024));
}
}
```四、打包本地测试工程执行测试
1. 打包工程
```shell
mvn clean package
```2. 复制本地测试工程jar到`rpc.benchmark/ext`目录
3. 执行压测
```shell
cd rpc.benchmark
./benchmark.sh
usage: benchmark.sh [options]
-b,--target target benchmark runnable class
-c,--threads The number of concurrent
-d,--duration benchmark running duration(seconds)
-h,--host server host or address
-p,--port server port
-t,--timeout rpc request timeout(milliseconds)
-tc,--connections The number of tcp connection
-w,--warm-up warm up duration(seconds)# 开始压测, 为了测试结果更准确,建议warm up 30秒.
# 压测工具默认会不统计最后调用10秒
./benchmark.sh -b com.demo.rpc.benchmark.BenchmarkRandom_1k -h 127.0.0.1 -p 20880 -d 300 -w 30
```五、本项目依赖facade指引
目前测试用facade api包含在开源仓库:
https://github.com/sofastack-guides/sofastack-mesh-demo.git
对应的分支:benchmark1. 本机进入sofastack-mesh-demo根目录,执行mvn clean install一下
2. 在测试时,可以把dubbo-echo-server注册中心禁用掉,这样本地启动server即可。
``````
六、完整开发实例,可以切到run_test分支