如何开发基于Dubbo RPC的分布式服务?
- 什么是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的服务?
第一步:定义接口
- 创建接口Jar项目,如:test-dubbo-service-api;
创建接口类和接口方法,和通常的接口定义没有什么区别,如:
public interface TestService {
/**
*
* @param a
* @return
*/
public String test(String a);
}
第二步:实现并发布服务
- 创建服务实现项目,如:test-dubbo-service-impl;
引入接口项目(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>实现服务接口,如:
@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") + ".";
}
}在实现类上添加注解@Service,此处Service为dubbo服务的声明注解com.alibaba.dubbo.config.annotation.Service,到此,基于Dubbo发布的服务已经开发并发布完成。
IconCrystal框架封装并提供了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的分布式服务?的更多相关文章
- 基于Dubbo框架构建分布式服务(一)
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- 基于Dubbo框架构建分布式服务
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- [转载] 基于Dubbo框架构建分布式服务
转载自http://shiyanjun.cn/archives/1075.html Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务 ...
- 基于Dubbo框架构建分布式服务(集群容错&负载均衡)
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- 基于Dubbo框架构建分布式服务(二)
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> ...
- 基于Dubbo框架构建分布式服务(三)
我们将上面开发的服务提供方服务,部署到2个独立的节点上(192.168.14.1和10.10.4.125),然后可以通过Dubbo管理中心查看对应服务的状况,如图所示: 上图中可以看出,该服务有两个独 ...
- 微服务痛点-基于Dubbo + Seata的分布式事务(AT)模式
前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...
- 微服务痛点-基于Dubbo + Seata的分布式事务(TCC模式)
前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...
- Dubbo 是一个分布式服务框架
Dubbo 是一个分布式服务框架-----http://www.cnblogs.com/chanshuyi/p/5144288.html
随机推荐
- ubuntu下mysql 开启远程连接
一.修改配置文件: vim /etc/mysql/my.cnf,找到 bind-address = 127.0.0.1 注释掉这行,如: #bind-address = 127.0.0.1 或者改为: ...
- [DNS]ACL、also-notify、视图服务器及安全设置
1. ACL :访问控制列表放在named.conf的头部,如果acl的内容太多,可以另创建一个文件,将acl放在该文件中,再在主配置文件named.conf用include 将文件加载进来(记得放在 ...
- iOS开发——NSArray中的字典排序
手头上碰到一个项目,需要给数组中的字典中的一个字段排序,想了想,干脆再字典中增加一个字段,用来记录需要排序字段的第一个字符,用它来作为比较的对象,进行排序. - (void)viewDidLoad { ...
- (中等) HDU 4370 0 or 1,建模+Dijkstra。
Description Given a n*n matrix C ij (1<=i,j<=n),We want to find a n*n matrix X ij (1<=i,j&l ...
- c++异常处理第四篇---不使用try catch语句,使用Loki::ScopeGuard
转载:神奇的Loki::ScopeGuard 2011-07-05 12:52:05 分类: C/C++ 转载:http://blog.csdn.net/fangqu/article/details/ ...
- ios 添加PCH文件
- 在阿里云ECS(CentOS6.5)上安装ftp
安装vsftpd 命令: yum install vsftpd –y 结果: 创建ftp存取文件的目录,用户名,密码 命令: useradd -d /home/ftp -g ftp -s /sbin/ ...
- 关于iOS后台模式
https://onevcat.com/2013/08/ios7-background-multitask/ http://zhidao.baidu.com/link?url=NUOMrLGB6Odr ...
- ucos2.86的任务调度漏洞
Ucos2.86版本有一个任务调度的漏洞,该漏洞在2.88之后的版本已经修改过来了,今天我们来看看这个漏洞, 漏洞在官方2.88的文档中如下 这两个函数都是调度器函数,也就是说调度器有漏洞,但是看官方 ...
- X-002 Exyson4412芯片启动过程分析
移植u-boot到FriendlyARM Tiny4412开发板上,首先我们需要对Samsung Exyson4412芯片的启动方式.系统时钟初始化.串口初始化.内存初始化以及开发板的内存地址空间分配 ...