SpringBoot+Dubbo项目简单搭建实现斐波那契第n项

简介: step1 新建项目方法1:直接在IDEA里新建如图:方法2:在start.spring.io新建step2 新建需要的包和接口以及实现类step3 在两个项目的resource下新建配置文件step4 代码编写导入依赖providerconsumer端口冲突更改step5 运行

step1 新建项目


方法1:直接在IDEA里新建如图:


76ecee0e84a746309927c0bed6c04d42.png


方法2:在start.spring.io新建


495ba872a8744c5c990f1df48ec95c9d.png


可能有的小朋友已经发现了,第一种方式的Server URL就是第二个的网站,都是一样的


要新建两个项目,第一个项目如上图所示,第二个项目只需要将provider改为consumer

其余不变,解压后通过IDEA打开


step2 新建需要的包和接口以及实现类


provider 项目结构:

468e3d55fe2e48edab0b17d1e27e9367.png


consumer 项目结构:

df4170e4c6494dc48c700404600964d8.png


请注意,两个ServiceAPI在项目中的的所在位置,或者说包名要严格一致,否则后续会出问题

如果不一致,可以按照如下方式按需进行更改


9a98d09f0929481aadda63625242300f.png


xsd放到指定目录下:

C:\Users\用户名\.lemminx\cache\http\code.alibabatech.com\schema\dubbo

文件:dubbo.xsd

下载链接:

dubbo xsd」https://www.aliyundrive.com/s/JN8dCuDH3XF

点击链接保存,或者复制本段内容,打开「阿里云盘」APP ,无需下载极速在线查看,视频原画倍速播放。


step3 在两个项目的resource下新建配置文件


需要新建的名字为:spring-dubbo.xml


provider的该配置文件中写入:

<?xml version="1.0" encoding="UTF-8"?>
<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应用名称 -->
    <dubbo:application name="springboot-buddo-provider"/>
    <!-- 发布者 dubbo协议  -->
    <dubbo:protocol name="dubbo" port="20881"/>
    <!-- 定义bean -->
    <bean id="providerImpl" class="com.springdubbo.demo.springbootdubbo.apiImpl.ProviderImpl"/>
    <!-- dubbo服务 发布者发布服务  需要暴露的服务接口 -->
    <dubbo:service interface="com.springdubbo.demo.springbootdubbo.ServiceAPI" ref="providerImpl"
                   registry="N/A"/>
</beans>


consumer的该配置文件内写入:

<?xml version="1.0" encoding="UTF-8"?>
<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应用名称 -->
    <dubbo:application name="springboot-buddo-consumer"/>
    <!-- 远程服务调用代理 -->
    <dubbo:reference id="consumerImpl"
                     interface="com.springdubbo.demo.springbootdubbo.ServiceAPI"
                     url="dubbo://localhost:20881" />
</beans>


step4 代码编写


导入依赖


在两个项目的pom.xml下均添加依赖:

<dependency>
  <groupId>com.alibaba.spring.boot</groupId>
  <artifactId>dubbo-spring-boot-starter</artifactId>
  <version>2.0.0</version>
</dependency>


provider


ProviderImpl

Service注解一定不要忘记加,而且一定要是dubbo的Service


package com.springdubbo.demo.springbootdubbo.apiImpl;
import com.alibaba.dubbo.config.annotation.Service;
import com.springdubbo.demo.springbootdubbo.ServiceAPI;
/**
 * @author wuyt
 * @data 2022/6/11
 * @apiNote
 */
@Service
public class ProviderImpl implements ServiceAPI {
    public String getMessage(String message) {
        return "springboot-dubbo-provider  =>>>>>" + message;
    }
    public String getTheFeibN(int n) {
        //斐波那契数列第n项的实现逻辑
    }
}


ServiceAPI

package com.springdubbo.demo.springbootdubbo;
/**
 * @author wuyt
 * @data 2022/6/11
 * @apiNote
 */
public interface ServiceAPI {
    public String getMessage(String message);
    public String getTheFeibN(int n);
}


SpringbootDubboApplication

一定要加上ImportResource注解

package com.springdubbo.demo.springbootdubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ImportResource;
@SpringBootApplication
@ImportResource("classpath:spring-dubbo.xml")
public class SpringbootDubboApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringbootDubboApplication.class, args);
    }
}


consumer


ServiceAPI

package com.springdubbo.demo.springbootdubbo;
/**
 * @author wuyt
 * @data 2022/6/11
 * @apiNote
 */
public interface ServiceAPI {
    public String getMessage(String message);
    public String getTheFeibN(int n);
}


SpringbootDubboApplication

package com.springdubbo.demo.springbootdubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ImportResource;
@SpringBootApplication
@ImportResource("classpath:spring-dubbo.xml")
public class SpringbootDubboApplication {
  public static void main(String[] args) {
    ConfigurableApplicationContext count = SpringApplication.run(SpringbootDubboApplication.class, args);
    ServiceAPI impl = (ServiceAPI)count.getBean("consumerImpl");
//    System.out.println(impl.getMessage("Hello dubbo"));
    System.out.println(impl.getTheFeibN(10));
  }
}


端口冲突更改


可以修改provider或者是consumer其中任意一个的端口号

这里修改consumer运行的端口号:

d994ca8130714c4887c8511522f8d8e4.png


step5 运行


首先运行provider,然后运行consumer

结果:


2104bf68ec5c4f3daf49381580c5d8ea.png




目录
相关文章
|
15天前
|
Dubbo Java 应用服务中间件
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用
|
3月前
|
Dubbo Java 应用服务中间件
实战指南:如何在Spring Boot中无缝整合Dubbo【四】
实战指南:如何在Spring Boot中无缝整合Dubbo【四】
47 0
|
4月前
|
Dubbo Java 应用服务中间件
Spring Boot Dubbo 构建分布式服务
Spring Boot Dubbo 构建分布式服务
52 0
|
4月前
|
Dubbo Java 应用服务中间件
微服务框架(十)Maven Archetype制作Dubbo项目原型
  此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。   本文为Maven Archetype的制作及使用,使用archetype插件制作Dubbo项目原型
|
4月前
|
JSON Dubbo Java
微服务框架(二十)Dubbo Spring Boot 生产就绪特性
  此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。   本文为Dubbo Spring Boot 生产就绪特性
|
4月前
|
Dubbo Java 应用服务中间件
微服务框架(十六)Spring Boot及Dubbo zipkin 链路追踪组件埋点
此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。 本文第一部分为调用链、OpenTracing、Zipkin和Jeager的简述;第二部分为Spring Boot及Dubbo zipkin 链路追踪组件埋点
|
2月前
|
SQL 监控 Java
nacos常见问题之dubbo+nacos+springboot3的native打包成功后运行出现异常如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
48 2
|
2月前
|
Dubbo Java 应用服务中间件
Spring Boot整合Dubbo+Zookeeper实现RPC调用
Spring Boot整合Dubbo+Zookeeper实现RPC调用 技术栈说明 Dubbo:Dubbo作为RPC框架,能在多个服务之间实现远程服务的调用。比如有两个独立的微服务A和B,A服务想要调用B服务时,因为两者不在同个内存空间中,不能直接调用,所以可以通过Dubbo实现这点。 功能和Spring Cloud的Feign相同,两者都是应用于微服务架构的远程调用框架 Zookeeper:作为注册中心去管理Dubbo服务,这点和Eureka、Nacos相同。 概述 通过一个示例说明Dubbo+Zookeeper在Spring Boot中的应用。 现有两个服务provider和con
119 4
|
Java 应用服务中间件 Maven
传统maven项目和现在spring boot项目的区别
Spring Boot:传统 Web 项目与采用 Spring Boot 项目区别
361 0
传统maven项目和现在spring boot项目的区别
|
XML Java 数据库连接
创建springboot项目的基本流程——以宠物类别为例
创建springboot项目的基本流程——以宠物类别为例
127 0
创建springboot项目的基本流程——以宠物类别为例