一、
以下摘录自企业级分布式应用服务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.       
 来源:
 
相关:

转载于:https://www.cnblogs.com/langtianya/p/5720275.html

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐