一、创建发布者项目
dubbo-boot-service-provider
参考上一篇
包引用 pom.xm
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.6.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<!-- <parent>-->
<!-- <groupId>org.apache.dubbo</groupId>-->
<!-- <artifactId>dubbo-spring-boot-parent</artifactId>-->
<!-- <version>2.7.8</version>-->
<!-- <relativePath />-->
<!-- </parent>-->
<groupId>com.hhm</groupId>
<artifactId>dubbo-boot-service-provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>dubbo-boot-service-provider</name>
<description>dubbo的发布者</description>
<packaging>jar</packaging>
<properties>
<java.version>1.8</java.version>
<spring-boot.version>2.6.2</spring-boot.version>
<dubbo.version>2.7.8</dubbo.version>
<skip_maven_deploy>true</skip_maven_deploy>
</properties>
<dependencyManagement>
<dependencies>
<!-- Spring Boot -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- Apache Dubbo -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-dependencies-bom</artifactId>
<version>${dubbo.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo</artifactId>
<version>${dubbo.version}</version>
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
</exclusion>
<exclusion>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.example</groupId>
<artifactId>dubbo-demo-service</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<!--注册中心依赖-->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.10</version>
</dependency>
<!--阿里巴巴下的 dubbo 起步依赖-->
<dependency>
<groupId>com.alibaba.spring.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.0.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
配置文件 application.properties
dubbo.application.name=dubbo-boot-service-provider
dubbo.registry.protocol=zookeeper
dubbo.registry.address=127.0.0.1
dubbo.registry.port=2181
server.port=8081
# 开启指定dubbo服务
spring.dubbo.server=true
程序实现
@Component
@Service(interfaceClass = UserService.class,version = "1.0.0",register = true)
public class UserServiceImpl implements UserService {
引用的包是
import com.alibaba.dubbo.config.annotation.Service;
启动类
@SpringBootApplication
@EnableDubbo
导入的包是
import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
消费者项目可以不变
需要替换的话,实现类
@Reference(interfaceClass = UserService.class,version = "1.0.0",check = false)
引用的包
import com.alibaba.dubbo.config.annotation.Reference;
启动类
@EnableDubboConfiguration
这种方式不需要启动监控中心