参考: 参考: https://blog.csdn.net/user2025/article/details/108338849
参考: https://github.com/alibaba/spring-cloud-alibaba/tree/master/spring-cloud-alibaba-examples
Nacos整合Dubbo的架构简图如下
注册中心: 使用nacos
安装部署参考:https://blog.csdn.net/xy3233/article/details/121820554
nacos_dubbo_provider 服务提供者:
pom.xml
<?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.3.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.demo.springcloud_04_dubbo</groupId>
<artifactId>nacos_dubbo_provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>nacos_dubbo_provider</name>
<description>Demo project for Spring Boot</description>
<properties>
<spring.cloud.version>Hoxton.SR9</spring.cloud.version>
<spring.boot.version>2.3.2.RELEASE</spring.boot.version>
<spring.cloud.alibaba.version>2.2.6.RELEASE</spring.cloud.alibaba.version>
</properties>
<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.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.0</version>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>${spring.cloud.alibaba.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>
</dependencies>
<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>
<!-- spring-cloud -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- spring-cloud-alibaba -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring.cloud.alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
配置文件 分为 bootstrap.yml 和 application.yml
bootstrap.yml内容
spring:
application:
name: nacos-dubbo-provider
main:
allow-bean-definition-overriding: true
cloud:
nacos:
discovery:
server-addr: localhost:8848
server:
port: 8481
application.yml 内容
dubbo:
protocol:
name: dubbo
port: -1
registry:
address: spring-cloud://localhost:8848
cloud:
subscribed-services: dubbo-product
consumer:
check: false
scan:
base-packages: com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.service
protocols:
dubbo:
name: dubbo
port: -1
项目结构:
NacosDubboProviderApplication.java
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class NacosDubboProviderApplication {
public static void main(String[] args) {
SpringApplication.run(NacosDubboProviderApplication.class, args);
}
}
UserService.java
import com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.entity.UserEntity;
public interface UserService {
UserEntity getUser();
}
UserServiceImpl.java
import org.apache.dubbo.config.annotation.DubboService;
import com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.entity.UserEntity;
import com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.service.UserService;
@DubboService(protocol = "dubbo")
public class UserServiceImpl implements UserService {
@Override
public UserEntity getUser() {
UserEntity userEntity = new UserEntity();
userEntity.setAge(13);
userEntity.setName("张三");
return userEntity;
}
}
UserEntity.java
import lombok.Data;
import java.io.Serializable;
@Data
public class UserEntity implements Serializable {
private String name;
private Integer age;
}
nacos_dubbo_consumer 消费者
pom.xml文件
<?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.3.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.demo.springcloud_04_dubbo</groupId>
<artifactId>nacos_dubbo_consumer</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>nacos_dubbo_consumer</name>
<description>Demo project for Spring Boot</description>
<properties>
<spring.cloud.version>Hoxton.SR9</spring.cloud.version>
<spring.boot.version>2.3.2.RELEASE</spring.boot.version>
<spring.cloud.alibaba.version>2.2.6.RELEASE</spring.cloud.alibaba.version>
</properties>
<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.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.0</version>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>${spring.cloud.alibaba.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>
<dependency>
<groupId>com.demo.springcloud_04_dubbo</groupId>
<artifactId>nacos_dubbo_provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<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>
<!-- spring-cloud -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- spring-cloud-alibaba -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring.cloud.alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
配置文件也是俩 bootstrap.yml 和 application.yml
bootstrap.yml
spring:
application:
name: nacos-dubbo-consumer
cloud:
nacos:
discovery:
server-addr: localhost:8848
server:
port: 8482
application.yml文件
dubbo:
cloud:
subscribed-services: ${provider.application.name}
protocols:
dubbo:
port: -1
provider:
application:
name: nacos-dubbo-provider
项目结构
NacosDubboConsumerApplication.java
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class NacosDubboConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(NacosDubboConsumerApplication.class, args);
}
}
ConsumerCotroller.java
import org.apache.dubbo.config.annotation.DubboReference;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.entity.UserEntity;
import com.demo.springcloud_04_dubbo.nacos_dubbo_provider.provider.service.UserService;
@RestController
public class ConsumerCotroller {
@DubboReference()
private UserService userService;
@RequestMapping("/user/user")
public UserEntity getUser() {
return userService.getUser();
}
}
项目运行调用成功