SOA框架之dubbox的使用

本文详细介绍了Dubbox作为SOA架构的一部分,如何利用Zookeeper作为注册中心进行服务治理。从概述到具体步骤,包括Zookeeper的安装、Dubbox的本地JAR包部署,以及创建简单的服务接口和实现。通过实例演示了Dubbox的基本使用,包括服务提供者和服务消费者的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:概述

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

在这里插入图片描述
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。

  1. 服务提供者在启动时,向注册中心注册自己提供的服务。
  2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
  3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接

    送变更数据给消费者。
  4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调
    用,
    如果调用失败,再选另一台调用。
  5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统

    数据到监控中心。

二: 注册中心 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

<?xml version="1.0" encoding="UTF-8"?>

<!-- 加载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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值