dubbo方法调用的timeout设置
方法调用的默认超时时间为1s,但是具体的超时时间受限于服务端方法性能、服务端个数、客户端的并发数等因素,所以超时时间需要根据不同的场景进行调试。
基本步骤为:
- 测试服务端的TPS,单位为 任务数或线程个数/S,即每秒能够处理的任务数。TPS能够表示出每秒能够处理的任务个数。
- 根据客户端的并发量要求和服务端的服务能力设置超时时间。例如客户端并发量为R,单个服务端的服务能力为T,服务端的个数为N,那么超时时间 = R/(T*N) 。
具体调试步骤参考如下:
- 使用多线程机制测试服务端接口的TPS。我使用单元测试进行的测试,UserTestInstance可以用作中使用的XXXService可以使用dubbo接口的服务注入,也可以注入服务端的服务。
- package tps;
- import org.junit.After;
- import org.junit.Before;
- import org.junit.Test;
- import org.springframework.beans.factory.annotation.Autowired;
- import tps.support.DubboFutureTask;
- import tps.support.DubboThread;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.concurrent.ExecutorService;
- import java.util.concurrent.Executors;
- /**
- * Created by admin on 2015-12-27.
- */
- public class UserTestInstance {
- @Autowired
- private XXXService xxxService ;
- private static int num = 500 ;
- //默认使用和线程个数相同的线程池,避免线程等待的时间
- private ExecutorService executorService = Executors.newFixedThreadPool(num);
- //存储线程任务
- private List<DubboFutureTask> futureTasks = new ArrayList<>(num) ;
- private long startTime ;
- @Before
- public void startTime(){
- System.out.println() ;
- System.out.println("初始化调用线程。");
- for (int i=0 ; i<num ; i++){
- DubboThread dubboThread = new DubboThread() ;
- dubboThread.setXXXService(xxxService) ;
- dubboThread.setName("thread->"+(i+1));
- //创建异步任务
- DubboFutureTask futureTask = new DubboFutureTask(dubboThread) ;
- futureTasks.add(futureTask) ;
- }
- //创建完任务之后,开始计时
- startTime = System.currentTimeMillis() ;
- }
- @After
- public void endTime(){
- boolean flag = true ;
- while (flag){
- flag = false ;
- for (DubboFutureTask futureTask : futureTasks) {
- //如果有一个没完成,则继续执行
- if(!futureTask.isDone()){
- flag = true ;
- break ;
- }
- }
- }
- //等待所有任务完成之后,停止计时
- double consumeTime = (System.currentTimeMillis() - startTime)/1000.0 ;
- System.out.println("线程数:"+futureTasks.size()+" , 共消耗时间:"+consumeTime+"s" +" , 异常数量:"+DubboThread.TIMEOUT_NUM.get());
- System.out.println("TPS:"+num/consumeTime);
- }
- @Test
- public void testTPS(){
- //提交任务请求到线程池
- for (DubboFutureTask futureTask : futureTasks) {
- executorService.submit(futureTask) ;
- }
- }
- }
- package tps.support;
- import lombok.Getter;
- import lombok.Setter;
- import java.util.concurrent.FutureTask;
- /**
- * Created by admin on 2015-12-27.
- */
- @Setter
- @Getter
- public class DubboFutureTask extends FutureTask<Object> {
- private DubboThread dubboThread ;
- public DubboFutureTask(DubboThread dubboThread) {
- super(dubboThread) ;
- this.dubboThread = dubboThread ;
- }
- }
- package tps.support;
- import com.glodon.framework.common.util.JsonMapper;
- import lombok.Getter;
- import lombok.Setter;
- import java.util.concurrent.Callable;
- import java.util.concurrent.atomic.AtomicInteger;
- /**
- * Created by admin on 2015-12-21.
- */
- @Setter
- @Getter
- public class DubboThread implements Callable<Object> {
- public static final AtomicInteger TIMEOUT_NUM = new AtomicInteger(0) ;
- private XXXService xxxService ;
- private String name ;
- @Override
- public Object call() throws Exception {
- XXXEntity xxx = null ;
- try {
- xxx= xxxService.login("superman" , "123456") ;
- System.out.println("线程名称-> "+getName()+" -> "+ JsonMapper.toJSONString(xxx));
- }catch (Exception e){
- //异常数量
- TIMEOUT_NUM.incrementAndGet() ;
- e.printStackTrace();
- }
- return xxx ;
- }
- }
- 根据服务端性能、个数和客户端的并发要求,就可以计算出具体的timeout的值了。
- dubbo用户手册 : http://dubbo.io/User+Guide-zh.htm
dubbo方法调用的timeout设置的更多相关文章
- dubbo同步调用、异步调用和是否返回结果源码分析和实例
0. dubbo同步调用.异步调用和是否返回结果配置 (1)dubbo默认为同步调用,并且有返回结果. (2)dubbo异步调用配置,设置 async="true",异步调用可以提 ...
- dubbo源码分析2-reference bean发起服务方法调用
dubbo源码分析1-reference bean创建 dubbo源码分析2-reference bean发起服务方法调用 dubbo源码分析3-service bean的创建与发布 dubbo源码分 ...
- pycharm 如何设置方法调用字体颜色
一.pycharm 如何设置方法调用字体颜色 1.打开pycharm编辑器,file > settings > editor > color scheme > python & ...
- dubbo中拦截生产者或消费者服务方法调用
比如当前有个需求,需要拦截dubbo的服务提供方或者服务消费方的方法,判断参数中是否包含某个关键字进行拦截阻止执行,那么我们可以通过使用dubbo的SPI机制通过实现Filter类来拦截,话不多说直接 ...
- 9.4 dubbo异步调用原理
9.1 客户端发起请求源码.9.2 服务端接收请求消息并发送响应消息源码.9.3 客户端接收响应信息(异步转同步的实现) 分析了dubbo同步调用的源码,现在来看一下dubbo异步调用. 一.使用方式 ...
- Dubbo——服务调用过程
文章目录 引言 服务的交互 服务降级 集群容错 服务调用 服务端接收请求 总结 引言 经过之前文章的铺垫,现在可以来分析服务的交互调用过程了. 服务的交互 服务降级 从名字上看我们不难理解MockCl ...
- Dubbo服务调用过程源码解析④
目录 0.服务的调用 1.发送请求 2.请求编码 3.请求的解码 4.调用具体服务 5.返回调用结果 6.接收调用结果 Dubbo SPI源码解析① Dubbo服务暴露源码解析② Dubbo服务引用源 ...
- dubbo+zookeeper+springBoot框架整合与dubbo泛型调用演示
dubbo + zookeeper + spring Boot框架整合与dubbo泛型调用演示 By:客 授客 QQ:1033553122 欢迎加入全国软件测试交流 QQ 群:7156436 ...
- 限时购校验小工具&dubbo异步调用实现限
本文来自网易云社区 作者:张伟 背景 限时购是网易考拉目前比较常用的促销形式,但是前期创建一个限时购活动时需要各个BU按照指定的Excel格式进行选品提报,为了保证提报数据准确,运营需要人肉校验很多信 ...
随机推荐
- 【bzoj4272】筐子放球
看题解会的系列…… 详细解释先坑着,以后补…… #include<bits/stdc++.h> #define N 200005 using namespace std; ,tot=,cn ...
- hdu 1513(滚动数组)
Palindrome Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- 【转】巧用局部变量提升javascript性能
转自:http://www.jb51.net/article/47219.htm 巧用局部变量可以有效提升javascript性能,下面有个不错的示例,大家可以参考下 javascript中一 ...
- [centos] 需要 libmpc.so.2 提供下载
http://pan.baidu.com/s/1kTmmthH yum update 的时候需要libmpc.so.2, 于是下载了一个 rpm -ivh filename.rpm 安装上就好了
- 大数据技术之_16_Scala学习_06_面向对象编程-高级+隐式转换和隐式值
第八章 面向对象编程-高级8.1 静态属性和静态方法8.1.1 静态属性-提出问题8.1.2 基本介绍8.1.3 伴生对象的快速入门8.1.4 伴生对象的小结8.1.5 最佳实践-使用伴生对象解决小孩 ...
- 大型vue单页面项目优化总结
这是之前在公司oa项目优化时罗列的优化点,基本都已经完成,当时花了点心思整理的,保存在这里,方便以后其他项目用到查漏补缺. 1.打包文件中的app.js文件放入cdn,加快页面首次加载速度 2.提取公 ...
- 7、Django实战第7天:用form实现登录
Django提供了form对表单进行验证,比如今天要完成的限定登录的时候用户名和密码不能为空,通过这个操作,数据进入到数据库查询之前,我们就可以过滤很多错误,避免不必要的查询. 在users目录下新建 ...
- ASP.NET Core 2.2 基础知识(十一) ASP.NET Core 模块
ASP.NET Core 应用与进程内的 HTTP 服务器实现一起运行.该服务器实现侦听 HTTP 请求,并在一系列请求功能被写到 HttpContext 时,将这些请求展现到应用中. ASP.NET ...
- [BZOJ4337][BJOI2015]树的同构(树的最小表示法)
4337: BJOI2015 树的同构 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1023 Solved: 436[Submit][Status ...
- [BZOJ 1177] Oil
Link:https://www.lydsy.com/JudgeOnline/problem.php?id=1177 Solution: 相当于将大矩形分为3块,取每块中最大的正方形 对于此类分成几块 ...