一:概述
Dubbox 致力于提供高性能和透明化的 RPC 远程服务调用方案,以及 SOA 服务治理
方案。说白了就是个远程服务调用的分布式框架。
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
- 服务提供者在启动时,向注册中心注册自己提供的服务。
- 服务消费者在启动时,向注册中心订阅自己所需的服务。
- 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接
推
送变更数据给消费者。 - 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调
用,
如果调用失败,再选另一台调用。 - 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统
计
数据到监控中心。
二: 注册中心 Zookeeper
官方推荐使用 zookeeper 注册中心。注册中心负责服务地址的注册与查找,相当于目录
服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小。
安装步骤:
第一步:安装 jdk(此步省略,我给大家提供的镜像已经安装好 JDK)
第二步:把 zookeeper 的压缩包(资源\配套软件\dubbox\zookeeper-3.4.6.tar.gz)上传到 linux
系统。
Alt+P 进入 SFTP ,输入 put d:\zookeeper-3.4.6.tar.gz 上传
第三步:解压缩压缩包
tar -zxvf zookeeper-3.4.6.tar.gz
第四步:进入 zookeeper-3.4.6 目录,创建 data 文件夹。
mkdir data
第五步:进入 conf 目录 ,把 zoo_sample.cfg 改名为 zoo.cfg
cd conf
mv zoo_sample.cfg zoo.cfg
第六步:打开 zoo.cfg , 修改 data 属性:dataDir=/root/zookeeper-3.4.6/data
3.2.3 Zookeeper 服务启动
进入 bin 目录,启动服务输入命令
./zkServer.sh start
三: Dubbox 本地 JAR 包部署与安装(了解)
Dubbox 的 jar 包并没有部署到 Maven 的中央仓库中,大家在 Maven 的中央仓库中可以查找
到 Dubbo 的最终版本是 2.5.3 , 阿里巴巴解散了 Dubbo 团队后由当当网继续维护此项目,并
改名为 Dubbox ,坐标不变,版本变更了,但是并没有提交到中央仓库。
我们现在需要手动将 Dubbox 的 jar 包安装到我的本地仓库中。
先将 dubbo-2.8.4.jar 包放到 d:\setup, 然后输入命令
mvn install:install-file -Dfile=d:\setup\dubbo-2.8.4.jar -DgroupId=com.alibaba -DartifactId=dubbo-Dversion=2.8.4 -Dpackaging=jar
四:入门小demo
(1 )创建 Maven 工程(WAR )dubboxdemo-service ,在 pom.xml 中引入依赖
(2 )在工程的 webapps 下创建 WEB-INF 文件夹,创建 web.xml
<!-- 加载spring容器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
**
(3 )创建业务接口
创建包 cn.itcast.dubbodemo.service,用于存放业务接口,创建接口**
package cn.itcast.dubbodemo.service;
/**
- 业务接口
- @author Administrator
*/
public interface UserService {
public String getName();
}
(4 )创建业务实现类
创建包 cn.itcast.dubbodemo.service.impl ,用于存放业务实现类。创建业务实现类:
package cn.itcast.dubbodemo.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import cn.itcast.dubbodemo.service.UserService;
@Service
public class UserServiceImpl implements UserService {
public String getName() {
return “itcast”;
}
}
注意:Service 注解与原来不同,需要引入 com.alibaba 包下的
(5 )编写配置文件
在 src/main/resources 下创建 applicationContext-service.xml ,内容如下:
注意:dubbo:annotation 用于扫描@Service 注解。
(6 )测试运行
tomcat7:run