1.1 概念
Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,可以和spring框架无缝集成。
Dubbo 采用的是一种非常简单的模型,要么是提供方提供服务,要么是消费方消费服务,所以基于这一点可以抽象出服务提供方(Provider)和服务消费方(Consumer)两个角色。
Dubbo 致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案;
①服务定义: 服务是围绕服务提供方和服务消费方的,服务提供方实现服务,而服务消费方调用服务。
②服务注册: 对于服务提供方,它需要发布服务,而且由于应用系统的复杂性,服务的数量、类型也不断膨胀;对于服务消费方,它最关心如何获取到它所需要的服务,而面对复杂的应用系统,需要管理大量的服务调用。而且,对于服务提供方和服务消费方来说,他们还有可能兼具这两种角色,即需要提供服务,又需要消费服务。
通过将服务统一管理起来,可以有效地优化内部应用对服务发布/使用的流程和管理。服务注册中心有如下几种类型可供选择:
Multicast注册中心(测试)、Zookeeper注册中心(官方推荐)、Redis注册中心、Simple注册中心
③服务监控
无论是服务提供方,还是服务消费方,他们都需要对服务调用的实际状态进行有效的监控,从而改进服务质量。
④远程通信与信息交换
远程通信需要指定通信双方所约定的协议,在保证通信双方理解协议语义的基础上,还要保证高效、稳定的消息传输。Dubbo继承了当前主流的网络通信框架,主要包括如下几个:
Mina、Netty、Grizzly
1.2案例解析
1.2.1注册中心
public interface service {
public String sayHello(String msg);
}
1.2.2服务提供方
(一)实现类
/*
* 服务提供方
* */
public class UserServiceImpl implements service {
/*
*
* 具体方法的实现
*
* */
public String sayHello(String msg) {
System.out.println("远程调用服务:"+msg);
return "hello"+msg;
}
}
(二)配置文件
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<!--应用名称-->
<dubbo:application name="userService_provider"/>
<!--指定注册中心的地址-->
<dubbo:registry address="multicast://224.5.6.7:1234" />
<!--使用协议和端口号-->
<dubbo:protocol name="dubbo" port="20880"/>
<!--发布服务接口 ref放实现类-->
<dubbo:service interface="cn.tx.service.service" ref="userService"/>
<!--使用bean管理实现类-->
<bean id="userService" class="cn.tx.service.impl.UserServiceImpl"/>
</beans>
(三)测试方法
public class UserServletBoot {
public static void main(String[] args) throws IOException {
//加载spring的配置文件
ApplicationContext ac = new ClassPathXmlApplicationContext("classpath:dubbo_provider.xml");
//阻塞
System.in.read();
}
}
1.2.3服务消费方
(一)配置文件
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<!--应用名称-->
<dubbo:application name="userService_consumer"/>
<!--注册中心的地址-->
<dubbo:registry address="multicast://224.5.6.7:1234" />
<!--可以使用服务-->
<dubbo:reference interface="cn.tx.service.service" id="userService"/>
</beans>
(二)测试方法
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:dubbo_consumer.xml")
public class ConsumerTest {
@Autowired
private service service;
@Test
public void run1(){
String msg = service.sayHello("亮哥爱玩");
System.out.println(msg);
}
}