SpringBoot之整合Dubbo
一、下载Dubbo-Admin并导入本地
dubbo-admin地址为:
https://github.com/apache/dubbo-admin
官方文档:
https://github.com/apache/dubbo-admin/blob/develop/README_ZH.md
注意需要安装Zookeeper(因为Dubbo使用Zookeeper作为注册中心)
二、建立服务提供者(这里是我博客的一个子项目名为blog-dubbo-provider)
1.导入Maven依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!-- dubbo的依赖 --> <!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-spring-boot-starter --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.6</version> </dependency> <!-- zk的依赖 --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-dependencies-zookeeper</artifactId> <version>2.7.6</version> <type>pom</type> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency>
2.编写启动类和配置文件
启动类:
package com.dubbo.blog; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DubboProviderApplication { public static void main(String[] args) { SpringApplication.run(DubboProviderApplication.class, args); } }
配置文件(application.properties):
# Spring boot application spring.application.name=blog-dubbo-provider # Base packages to scan Dubbo Component: @org.apache.dubbo.config.annotation.Service dubbo.scan.base-packages=com.dubbo.blog.provider.service.impl # Dubbo Application ## The default value of dubbo.application.name is ${spring.application.name} dubbo.application.name=${spring.application.name} # Dubbo Protocol dubbo.protocol.name=dubbo dubbo.protocol.port=20880 ## Dubbo Registry dubbo.registry.address=zookeeper://127.0.0.1:2181 server.port=7010
3.编写接口和对应的实现类
TestService:
package com.dubbo.blog.provider.service; public interface TestService { String showName(); }
TestServiceImpl:
package com.dubbo.blog.provider.service.impl; import com.dubbo.blog.provider.service.TestService; import org.apache.dubbo.config.annotation.Service; @Service(version = "1.0.0") public class TestServiceImpl implements TestService { @Override public String showName() { return "HELLO DUBBO"; } }
TestService2:
package com.dubbo.blog.provider.service; public interface TestService2 { String showName(); }
TestService2Impl:
package com.dubbo.blog.provider.service.impl; import com.dubbo.blog.provider.service.TestService2; import org.apache.dubbo.config.annotation.Service; @Service(version = "1.0.0") public class TestService2Impl implements TestService2 { @Override public String showName() { return "HELLO TestService2"; } }
4.启动主类并打开Dubbo-Admin
三、建立服务消费者(这里是我博客的一个子项目名为blog-dubbo-consumer)
1.导入Maven依赖
<dependency> <groupId>com.challenger.blog</groupId> <artifactId>blog-dubbo-provider</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- dubbo的依赖 --> <!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-spring-boot-starter --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.6</version> </dependency> <!-- zk的依赖 --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-dependencies-zookeeper</artifactId> <version>2.7.6</version> <type>pom</type> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency>
2.编写启动类和配置文件
启动类:
package com.dubbo.blog; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DubboConsumerApplication { public static void main(String[] args) { SpringApplication.run(DubboConsumerApplication.class, args); } }
配置文件(application.properties):
spring.application.name=blog-dubbo-consumer dubbo.registry.address=zookeeper://127.0.0.1:2181 server.port=7000
3.编写Controller
package com.dubbo.blog; import com.dubbo.blog.provider.service.TestService; import com.dubbo.blog.provider.service.TestService2; import org.apache.dubbo.config.annotation.Reference; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class TestDubboController { @Reference(version = "1.0.0") private TestService2 service2; @Reference(version = "1.0.0") private TestService service; @GetMapping("test1") public String test1() { return service.showName(); } @GetMapping("test2") public String test2() { return service2.showName(); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
2018-05-22 JavaScript高级程序设计学习(五)之对象