搭建spring+dubbo环境踩坑小记

spring+dubbo环境搭建网上汗牛充栋,但是实践过程中遇到种种麻烦,小记一篇,免得自己或者别人再次踩坑。 主要的问题是,项目需要引入哪些包,对有些版本过时的配置该如何修正,遇到异常如何处理(hello world应用代码极少,主要是配置问题)

参考文章Idea创建dubbo项目步骤和简单实例开发(dubo+zookeeper)

文章写的非常清楚,我们主要聚焦几个问题

1 dubboprovider 和 dubboconsumer的 pom配置

bash 复制代码
<!-- dubboprovider和dubbocomsumer 都需要引入,提供了dubbo注解,并会自动关联相应dubbo包,这里是2.6.2 -->
<dependency>
			<groupId>com.alibaba.boot</groupId>
			<artifactId>dubbo-spring-boot-starter</artifactId>
			<version>0.2.0</version>
</dependency>

<!-- dubboprovider和dubbocomsume spring web的启动器,不引入会遇到 4 那种问题 -->

<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
</dependency>

只有dubboconsumer用到的包

bash 复制代码
<!-- Controller需要用到 @RequestMapping 等-->
<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-web</artifactId>
		</dependency>

2 dubboprovider 和 dubboconsumer的 application.properties文件配置

dubboprovider 相关配置

bash 复制代码
# apllication name
dubbo.application.name=dubboprovider

# register center
dubbo.registry.protocol=zookeeper
dubbo.registry.address=localhost:2181

dubbo.protocol.name=dubbo
dubbo.protocol.port=20880

dubbo.monitor.protocol=registry
#开启包扫描,因代码有 @EnableDubbo,所以不需要
#dubbo.scan.base-packages=com.dubbolearn.dubboprovider.service.impl

dubboconsumer需要的配置

server.port=7070

bash 复制代码
server.port=7070

# apllication name
dubbo.application.name=dubboconsumer

# register center
dubbo.registry.protocol=zookeeper
dubbo.registry.address=localhost:2181

#dubbo.protocol.name=dubbo
#dubbo.protocol.port=20880

dubbo.monitor.protocol=registry

3 启动文件配置

bash 复制代码
package com.dubbolearn.consumer;

import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
// 注意现在的写法需要改成这样
@EnableDubbo    
public class DubboconsumerApplication {

	public static void main(String[] args) {
		SpringApplication.run(DubboconsumerApplication.class, args);
	}

}

4 Current Spring Boot Application is await...的问题

启动dubboprovider 、 dubboconsumer 时,如果没有引入spring-boot-starter-web就会遇到该问题

5 Whitelabel Error Page...的问题

通过浏览器访问 localhost:7070/hello

如果遇到

Whitelabel Error Page

This application has no explicit mapping for /error, so you are seeing this as a fallback.

Mon Jul 26 20:59:17 CST 2021

There was an unexpected error (type=Internal Server Error, status=500).

spring启动是成功的,但dubbo调用comsumer找不到provider

会在dubbocomsuer报错

检查 dubboprovider 的StudentServiceImpl的

@Service(interfaceClass = StudentService.class, version="1.0.0",timeout=15000)

和 dubboprovider的studentsController的

@Reference(interfaceClass = StudentService.class,version="1.0.0",check=false)

private StudentService studentService;

是否匹配一致

例如有没有这种错 https://www.cnblogs.com/wangchao928/p/15063380.html

相关推荐
程序员阿鹏4 分钟前
责任链模式
java·spring·servlet·tomcat·maven·责任链模式
@淡 定14 分钟前
Java内存模型(JMM)详解
java·开发语言
czhc114007566338 分钟前
C# 1221
java·servlet·c#
黄俊懿40 分钟前
【深入理解SpringCloud微服务】Seata(AT模式)源码解析——全局事务的回滚
java·后端·spring·spring cloud·微服务·架构·架构师
派大鑫wink1 小时前
【Day12】String 类详解:不可变性、常用方法与字符串拼接优化
java·开发语言
JIngJaneIL1 小时前
基于springboot + vue健康管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
秋饼1 小时前
【三大锁王争霸赛:Java锁、数据库锁、分布式锁谁是卷王?】
java·数据库·分布式
电商API&Tina1 小时前
【电商API接口】关于电商数据采集相关行业
java·python·oracle·django·sqlite·json·php
刘一说1 小时前
Spring Boot中IoC(控制反转)深度解析:从实现机制到项目实战
java·spring boot·后端
悟空码字1 小时前
SpringBoot参数配置:一场“我说了算”的奇幻之旅
java·spring boot·后端