zoukankan      html  css  js  c++  java
  • HSF和Dubbo有什么区别

    一、
    以下摘录自企业级分布式应用服务EDAS官网段落
    RPC服务

    提供对Dubbo和HSF两个RPC框架的支持。阿里巴巴第一代RPC框架Dubbo是国内第一款成熟的商用级RPC框架,已于2011年正式对外开源,目前已发展成为国内开源价值最高、用户使用规模最大的开源软件之一。最新一代RPC框架HSF,全称High Speed Framework,也叫"好舒服","很舒服"框架,是阿里内部对这一款高性能服务框架的昵称,是一款面向企业级互联网架构量身定制的分布式服务框架。HSF以高性能网络通信框架为基础,提供了诸如服务发布与注册,服务调用,服务路由,服务鉴权,服务限流,服务降级和服务调用链路跟踪等一系列久经考验的功能特性。

    来源:企业级分布式应用服务EDAS_企业云计算解决方案
     
     
    二、

    dubbo和S-HSF测试对比

     
    今天没什么事,简单测试下RPC框架性能: HSF完胜dubbo


    1.dubbo测试结果:

    note:
    dubbo测试时有使用ZooKeeper,所以存在不公平性,不一定准确。

    同步模型

    耗时:16.808 s
    平均:0.16808 ms
    TPS:5949.547834364588

    测试数据:
    Java代码  收藏代码
    1. public class TPS_TEST {  
    2.   
    3.     public static void main(String[] args) throws InterruptedException {  
    4.         final ClassPathXmlApplicationContext context =   
    5.                 new ClassPathXmlApplicationContext(  
    6.                         new String[] {"file:E:/1-project_test/dubbox-master/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-consumer.xml"});  
    7.         final HelloService helloService = (HelloService)context.getBean("helloService"); // get service invocation proxy  
    8.         ExecutorService executorServicePool = Executors.newFixedThreadPool(200);  
    9.         final int size = 100000;  
    10.         final CountDownLatch cdl = new CountDownLatch(size);  
    11.         long begin = System.currentTimeMillis();  
    12.         for (int i = 0; i < size; i++) {  
    13.             executorServicePool.execute(new Runnable() {  
    14.                 @Override  
    15.                 public void run() {  
    16.                     try {  
    17.                           
    18.                         String hello = helloService.hello("aa"); // do invoke!  
    19.                         //System.out.println( hello ); // cool, how are you~  
    20.                         cdl.countDown();  
    21.                     } catch (Exception e) {  
    22.                         e.printStackTrace();  
    23.                     }  
    24.                 }  
    25.             });  
    26.         }  
    27.         //executorServicePool.shutdown();  
    28.         //executorService.awaitTermination(10, TimeUnit.MINUTES);  
    29.         cdl.await();//等待所有任务处理完  
    30.         long time = System.currentTimeMillis() - begin;  
    31.         System.out.println("耗时:" + (double) time / 1000 + " s");  
    32.         System.out.println("平均:" + ((double) time) / size +" ms");  
    33.         System.out.println("TPS:" + (double) size / ((double) time / 1000));                
    34.      
    35.       
    36.     }  
    37.   
    38.      
    39. }  


    2.hsf 测试结果:

    异步模型:

    耗时:6.305 s
    平均:0.06305 ms
    TPS:15860.428231562253

    测试数据:
    Java代码  收藏代码
    1. public class Client {  
    2.     public static void main(String[] args) throws InterruptedException, ExecutionException {  
    3.         final int size = 100000;  
    4.         final CountDownLatch cdl = new CountDownLatch(size);  
    5.   
    6.         // final TestService testService = ServiceProxyFactory.getRoundFactoryInstance(connector).wrapAsyncProxy(  
    7.         // TestService.class);  
    8.           
    9.         HsfConnector connector = new HsfConnectorImpl();  
    10.         connector.connect(new InetSocketAddress("localhost", 8082));  
    11.           
    12.           
    13.         final TestService testService = ServiceProxyFactory.getRoundFactoryInstance(connector).wrapAsyncCallbackProxy(  
    14.                 TestService.class, new AsyncCallback<Object>() {  
    15.                     public void doCallback(Object data) {  
    16.                         //System.out.println("received:" + data);  
    17.                         cdl.countDown();  
    18.                     };  
    19.                     @Override  
    20.                     public void doExceptionCaught(Throwable ex, HsfChannel channel, Object param) {  
    21.                         System.out.println(ex);  
    22.                         super.doExceptionCaught(ex, channel, param);  
    23.                     }  
    24.                 });  
    25.         ExecutorService executorServicePool = Executors.newFixedThreadPool(200);  
    26.         long begin = System.currentTimeMillis();  
    27.         for (int i = 0; i < size; i++) {  
    28.             executorServicePool.execute(new Runnable() {  
    29.                 @Override  
    30.                 public void run() {  
    31.                     try {  
    32.                         testService.test("aa");  
    33.                     } catch (Exception e) {  
    34.                         e.printStackTrace();  
    35.                     }  
    36.                 }  
    37.             });  
    38.         }  
    39.         //executorServicePool.shutdown();  
    40.         //executorService.awaitTermination(10, TimeUnit.MINUTES);  
    41.         cdl.await();//等待所有任务处理完  
    42.         long time = System.currentTimeMillis() - begin;  
    43.         System.out.println("耗时:" + (double) time / 1000 + " s");  
    44.         System.out.println("平均:" + ((double) time) / size +" ms");  
    45.         System.out.println("TPS:" + (double) size / ((double) time / 1000));  
    46.           
    47.     }  
    48.   
    49. }  


    同步模型:

    耗时:9.446 s
    平均:0.09446 ms
    TPS:10586.491636671608
    Java代码  收藏代码
    1. //tips:  
    2. //模拟HSF的同步模型:在10万个并发线程发送数据时有时候比异步模型还要快,这点有点想不通,估计是我测试的服务是直接return的场景吧。  
    3.   
    4. /** 
    5.  * @Title: Client.java 
    6.  * @Description: TODO(添加描述) 
    7.  * @date 2012-2-23 上午01:01:33 
    8.  * @version V1.0 
    9.  */  
    10. public class Client2 {  
    11.     public static void main(String[] args) throws InterruptedException, ExecutionException {  
    12.          final int size = 100000;    
    13.          final CountDownLatch cdl = new CountDownLatch(size);     
    14.          HsfConnector connector = new HsfConnectorImpl();    
    15.          connector.connect(new InetSocketAddress("10.118.63.12", 10223));    
    16.                 
    17.                 
    18.         /* 
    19.          final TestService testService = ServiceProxyFactory.getRoundFactoryInstance(connector).wrapAsyncCallbackProxy(   
    20.                 TestService.class, new AsyncCallback<Object>() {   
    21.                     public void doCallback(Object data) {   
    22.                         //System.out.println("received:" + data);   
    23.                         cdl.countDown();   
    24.                     };   
    25.                     @Override   
    26.                     public void doExceptionCaught(Throwable ex, HsfChannel channel, Object param) {   
    27.                         System.out.println(ex);   
    28.                         super.doExceptionCaught(ex, channel, param);   
    29.                     }   
    30.                 });   
    31.          ExecutorService executorServicePool = Executors.newFixedThreadPool(200);   
    32.                 long begin = System.currentTimeMillis();   
    33.                 for (int i = 0; i < size; i++) {   
    34.                     executorServicePool.execute(new Runnable() {   
    35.                         @Override   
    36.                         public void run() {   
    37.                             try {   
    38.                                 testService.test("aa");   
    39.                             } catch (Exception e) {   
    40.                                 e.printStackTrace();   
    41.                             }   
    42.                         }   
    43.                     });   
    44.                 }  
    45.                  
    46.           */  
    47.            
    48.          final TestService testService = ServiceProxyFactory.getRoundFactoryInstance(connector).wrapSyncProxy(    
    49.                 TestService.class);   
    50.            
    51.         ExecutorService executorServicePool = Executors.newFixedThreadPool(200);    
    52.         long begin = System.currentTimeMillis();    
    53.         for (int i = 0; i < size; i++) {    
    54.             executorServicePool.execute(new Runnable() {    
    55.                 @Override    
    56.                 public void run() {    
    57.                     try {    
    58.                         String hello = testService.test("aa");    
    59.                         cdl.countDown();    
    60.                     } catch (Exception e) {    
    61.                         e.printStackTrace();    
    62.                     }    
    63.                 }    
    64.             });    
    65.         }    
    66.         //executorServicePool.shutdown();    
    67.         //executorService.awaitTermination(10, TimeUnit.MINUTES);    
    68.         cdl.await();//等待所有任务处理完    
    69.         long time = System.currentTimeMillis() - begin;    
    70.         System.out.println("耗时:" + (double) time / 1000 + " s");    
    71.         System.out.println("平均:" + ((double) time) / size +" ms");    
    72.         System.out.println("TPS:" + (double) size / ((double) time / 1000));   
    73.       
    74.     }  
    75.       
     来源:
     
    相关:
  • 相关阅读:
    c11---位运算相关
    c10---多文件开发
    C9---include,编译
    c8---递归
    c7---函数
    c6----函数的声明和实现
    c5
    Arm 环境上面libgdiplus的简单安装配置
    批量查找可执行文件目录的简单方法
    Android常用工具类
  • 原文地址:https://www.cnblogs.com/langtianya/p/5720275.html
Copyright © 2011-2022 走看看