• 什么是Dubbo?

    • Dubbo能做什么?
  • 在Crystal框架下,如何开发基于Dubbo RPC的服务?
  • 在Crystal框架下,如何调用Dubbo RPC服务?
  • 相关的文章

什么是Dubbo?

Dubbo[]是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。

其核心部分包含:

  • 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
  • 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
  • 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

Dubbo能做什么?

  • 透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。
  • 软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
  • 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

想了解跟多关于Dubbo的信息,请查看:http://alibaba.github.io/dubbo-doc-static/Home-zh.htm

在Crystal框架下,如何开发基于Dubbo RPC的服务?

第一步:定义接口

  1. 创建接口Jar项目,如:test-dubbo-service-api;
  2. 创建接口类和接口方法,和通常的接口定义没有什么区别,如:

    public interface TestService {
    /**
    *
    * @param a
    * @return
    */
    public String test(String a);
    }

第二步:实现并发布服务

  1. 创建服务实现项目,如:test-dubbo-service-impl;
  2. 引入接口项目(test-dubbo-service-api)、Crystal框架dubbo服务支持包(crystal-remote-server-dubbo),如:

    <dependency>
    <groupId>com.gsoft.test</groupId>
    <artifactId>test-dubbo-service-api</artifactId>
    </dependency>
    <dependency>
    <groupId>com.gsoft.crystal</groupId>
    <artifactId>crystal-remote-server-dubbo</artifactId>
    </dependency>
  3. 实现服务接口,如:

    @Service
    public class TestServiceImpl implements TestService {
    @Value("${crystal.application.name}")
    private String name;
    /*
    * (non-Javadoc)
    *
    * @see com.gsoft.test.dubbo.TestService#test(java.lang.String)
    */
    @Override
    public String test(String a) {
    return "Hello, " + a + "! " + " I'm " + name + " " + System.getenv("LOGONSERVER") + ".";
    }
    }
  4. 在实现类上添加注解@Service,此处Service为dubbo服务的声明注解com.alibaba.dubbo.config.annotation.Service,到此,基于Dubbo发布的服务已经开发并发布完成。

    Icon

    Crystal框架封装并提供了Dubbo的默认配置,因此开发Dubbo服务非常简单。 当需要调整配置时,可根据Crystal框架参数加载顺序,采用项目中profile/config.properties文件中参数,调整配置,如下:
    
    crystal.application.name = crystal_framework
    
    crystal.application.owner = Crystal
    
    dubbo.registry.address = zookeeper://127.0.0.1:2181
    
    dubbo.protocol.port = 20880

在Crystal框架下,如何调用Dubbo RPC服务?

第一步:项目中引用Dubbo服务接口包和Crystal框架dubbo客户端支持包(crystal-remote-client-dubbo),如

<dependency>
<groupId>com.gsoft.test</groupId>
<artifactId>test-dubbo-service-api</artifactId>
</dependency>
<dependency>
<groupId>com.gsoft.crystal</groupId>
<artifactId>crystal-remote-client-dubbo</artifactId>
</dependency>

第二步:在需要使用Dubbo RPC服务的类中,添加服务的引用,并添加@Reference注解:(此处Reference为dubbo服务的声明注解com.alibaba.dubbo.config.annotation.Reference

public class TestCostumer {
@Reference
private TestService s;
private int i = 0;
@Value("${crystal.application.name}")
private String name;
public void hello() {
System.out.println(s.test(name + " " + System.getenv("LOGONSERVER") + "-" + ++i));
}
}
Crystal框架封装并提供了Dubbo的默认配置,因此开发Dubbo服务非常简单。 当需要调整配置时,可根据Crystal框架参数加载顺序,采用项目中profile/config.properties文件中参数,调整配置,如下:

crystal.application.name = crystal_framework

crystal.application.owner = Crystal

dubbo.registry.address = zookeeper://127.0.0.1:2181

如何开发基于Dubbo RPC的分布式服务?的更多相关文章

  1. 基于Dubbo框架构建分布式服务(一)

    Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...

  2. 基于Dubbo框架构建分布式服务

    Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...

  3. [转载] 基于Dubbo框架构建分布式服务

    转载自http://shiyanjun.cn/archives/1075.html Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务 ...

  4. 基于Dubbo框架构建分布式服务(集群容错&负载均衡)

    Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...

  5. 基于Dubbo框架构建分布式服务(二)

    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> ...

  6. 基于Dubbo框架构建分布式服务(三)

    我们将上面开发的服务提供方服务,部署到2个独立的节点上(192.168.14.1和10.10.4.125),然后可以通过Dubbo管理中心查看对应服务的状况,如图所示: 上图中可以看出,该服务有两个独 ...

  7. 微服务痛点-基于Dubbo + Seata的分布式事务(AT)模式

    前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...

  8. 微服务痛点-基于Dubbo + Seata的分布式事务(TCC模式)

    前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...

  9. Dubbo 是一个分布式服务框架

    Dubbo 是一个分布式服务框架-----http://www.cnblogs.com/chanshuyi/p/5144288.html

随机推荐

  1. 自制ichartjs饼图

    饼图:2个数据: <!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> &l ...

  2. JSP/JAVA目录清单

    JAVA253中国象棋(CS) JAVA258网络五子棋游戏的设计与实现(CS) JAVA390停车场管理系统SQL(CS) JSP001学生综合素质测评系统JAVA+Mysql JSP002学生成绩 ...

  3. CodeForces 598E Chocolate Bar

    区间DP预处理. dp[i][j][k]表示大小为i*j的巧克力块,切出k块的最小代价. #include<cstdio> #include<cstring> #include ...

  4. RAC(ReactiveCocoa)

    什么是 ReactiveCocoa ReactiveCocoa(其简称为 RAC)是由 Github 开源的一个应用于 iOS 和 OS X 开发的新框架.RAC 具有函数式编程和响应式编程的特性.它 ...

  5. (中等) POJ 2886 Who Gets the Most Candies? , 反素数+线段树。

    Description N children are sitting in a circle to play a game. The children are numbered from 1 to N ...

  6. MySQL索引背后的之使用策略及优化(高性能索引策略)

    为了讨论索引策略,需要一个数据量不算小的数据库作为示例.本文选用MySQL官方文档中提供的示例数据库之一:employees.这个数据库关系复杂度适中,且数据量较大.下图是这个数据库的E-R关系图(引 ...

  7. Spring AOP进行日志记录,管理

    在java开发中日志的管理有很多种.我一般会使用过滤器,或者是Spring的拦截器进行日志的处理.如果是用过滤器比较简单,只要对所有的.do提交进行拦截,然后获取action的提交路径就可以获取对每个 ...

  8. 【转】每一个程序员需要了解的10个Linux命令

    作为一个程序员,在软件开发职业生涯中或多或少会用到Linux系统,并且可能会使用Linux命令来检索需要的信息.本文将为各位开发者分享10个有用的Linux命令,希望对你会有所帮助. 以下就是今天我们 ...

  9. css3快速复习

    选择器边框.阴影 border-radius: 50%; 设置正圆形背景的改变CSS3重要的新东西: ● transition 过度,让一个元素从一个样式,变为另一个样式,不再是干蹦了,而是有动画,均 ...

  10. VS2013 opencv2.4.8

    [转]http://my.phirobot.com/blog/2014-02-opencv_configuration_in_vs.html vs2010+opencv2.4.0:http://www ...