IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Spring+dubbo搭建一个简单的分布式 -> 正文阅读

[Java知识库]Spring+dubbo搭建一个简单的分布式

不了解dubbo分布式是啥的小伙伴可以点击这篇文章了解一下:

dubbo详解_crazyK.的博客-CSDN博客

目录

一、zookeeper 环境安装搭建

二、实现服务接口 dubbo-interface

1. dubbo-interface 项目创建

?2. 创建接口类

3. 将项目打成 jar 包供其他项目使用

三、实现服务提供者 dubbo-provider

1. dubbo-provider 项目创建

?2. pom 文件引入相关依赖

?3. 在 application.properties 配置文件中配置 dubbo 相关信息

4. 实现接口

5. 服务提供者启动类编写

四、实现服务消费者 dubbo-consumer

4. 编写一个简单 Controller 调用远程服务

5. 服务消费者启动类编写

?五、测试


一、zookeeper 环境安装搭建

搭建 zookeeper 之前要确保当前的机器已经有 JDK 环境。

我使用的是 CentOS 7.5 华为云服务器,注意:如果你也同样华为云服务器必须配置一个安全组,不然你的应用程序会无法访问你的 zookeeper 服务器,这一点我在后面也提到了。

CentOS部署zookeeper教程:CentOS云服务器部署zookeeper_crazyK.的博客-CSDN博客_centos zookeeper

二、实现服务接口 dubbo-interface

主要分为下面几步:

  1. 创建 Maven 项目;

  2. 创建接口类

  3. 将项目打成 jar 包供其他项目使用

项目结构:

dubbo-interface 后面被打成 jar 包,它的作用只是提供接口。

1. dubbo-interface 项目创建

File->New->Module... ,然后选择 Maven类型的项目,其他的按照提示一步一步走就好。

?2. 创建接口类


?public interface HelloService {
?
 ? ?public ?String sayHello(String name);
}
?

3. 将项目打成 jar 包供其他项目使用

点击右边的 Maven Projects 然后选择 install ,这样 jar 包就打好了。

三、实现服务提供者 dubbo-provider

主要分为下面几步:

  1. 创建 springboot 项目;

  2. 加入 dubbo 、zookeeper以及接口的相关依赖 jar 包;

  3. 在 application.properties 配置文件中配置 dubbo 相关信息;

  4. 实现接口类;

  5. 服务提供者启动类编写

项目结构:

1. dubbo-provider 项目创建

创建一个 SpringBoot 项目,注意勾选上 web 模块。不会创建的话,可以查看下面这篇文章:,可以说很详细了。

创建SpringBoot项目并整合Mybaits(奶奶看了都会)_crazyK.的博客-CSDN博客

?2. pom 文件引入相关依赖

需要引入 dubbo 、zookeeper以及接口的相关依赖 jar 包。注意将本项目和 dubbo-interface 项目的 dependency 依赖的 groupId 和 artifactId 改成自己的。dubbo 整合spring boot 的 jar 包在这里找dubbo-spring-boot-starter。zookeeper 的 jar包在 Maven 仓库 搜索 zkclient 即可找到。 ? ?

        <dependency>
 ? ? ? ? ? ?<groupId>top.snailclimb</groupId>
 ? ? ? ? ? ?<artifactId>dubbo-interface</artifactId>
 ? ? ? ? ? ?<version>1.0-SNAPSHOT</version>
 ? ? ? ?</dependency>
 ? ? ? ?<!--引入dubbo的依赖-->
 ? ? ? ?<dependency>
 ? ? ? ? ? ?<groupId>com.alibaba.spring.boot</groupId>
 ? ? ? ? ? ?<artifactId>dubbo-spring-boot-starter</artifactId>
 ? ? ? ? ? ?<version>2.0.0</version>
 ? ? ? ?</dependency>
 ? ? ? ?<!-- 引入zookeeper的依赖 -->
 ? ? ? ?<dependency>
 ? ? ? ? ? ?<groupId>com.101tec</groupId>
 ? ? ? ? ? ?<artifactId>zkclient</artifactId>
 ? ? ? ? ? ?<version>0.10</version>
 ? ? ? ?</dependency>

?3. 在 application.properties 配置文件中配置 dubbo 相关信息

配置很简单,这主要得益于 springboot 整合 dubbo 专属的@EnableDubboConfiguration 注解提供的 Dubbo 自动配置。

# 配置端口
server.port=8333
?
spring.dubbo.application.name=dubbo-provider
spring.dubbo.application.registry=zookeeper://ip地址:2181

4. 实现接口

注意: @Service 注解使用的时 Dubbo 提供的而不是 Spring 提供的。另外,加了Dubbo 提供的 @Service 注解之后还需要加入

import com.alibaba.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;
import top.snailclimb.service.HelloService;
?
@Component
@Service
public class HelloServiceImpl implements HelloService {
 ? ?@Override
 ? ?public String sayHello(String name) {
 ? ? ? ?return "Hello " + name;
 ?  }
}

5. 服务提供者启动类编写

注意:不要忘记加上 @EnableDubboConfiguration 注解开启Dubbo 的自动配置。

import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
?
@SpringBootApplication
// 开启dubbo的自动配置
@EnableDubboConfiguration
public class DubboProviderApplication {
 ? ?public static void main(String[] args) {
 ? ? ? ?SpringApplication.run(DubboProviderApplication.class, args);
 ?  }
}

四、实现服务消费者 dubbo-consumer

主要分为下面几步:

  1. 创建 springboot 项目;

  2. 加入 dubbo 、zookeeper以及接口的相关依赖 jar 包;

  3. 在 application.properties 配置文件中配置 dubbo 相关信息;

  4. 编写测试类;

  5. 服务消费者启动类编写

  6. 测试效果

项目结构:

第1,2,3 步和服务提供者的一样,这里直接从第 4 步开始。

4. 编写一个简单 Controller 调用远程服务

import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import top.snailclimb.service.HelloService;
?
@RestController
public class HelloController {
 ? ?@Reference
 ? ?private HelloService helloService;
?
 ? ?@RequestMapping("/hello")
 ? ?public String hello() {
 ? ? ? ?String hello = helloService.sayHello("world");
 ? ? ? ?System.out.println(helloService.sayHello("CrazyK"));
 ? ? ? ?return hello;
 ?  }
}

5. 服务消费者启动类编写

import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
?
@SpringBootApplication
@EnableDubboConfiguration
public class DubboConsumerApplication {
?
 ? ?public static void main(String[] args) {
?
 ? ? ? ?SpringApplication.run(DubboConsumerApplication.class, args);
 ?  }
}

?五、测试

浏览器访问 http://localhost:8330/hello 页面返回 Hello world,控制台输出 Hello SnailClimb,和预期一致,使用SpringBoot+Dubbo 搭建第一个简单的分布式服务实验成功!

代码地址: Github-CrazyK ?

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-06-25 17:56:45  更:2022-06-25 17:59:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 17:00:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码