定義API
public interface HelloServiceFacade {
void sayHello();
}
定義服務提供者
API的實現類
SpringBoot的啓動類
import com.alibaba.dubbo.config.annotation.Service;
import com.smart.springboot.api.HelloServiceFacade;
@Service(version = "1.0.0",timeout = 20000)
public class HelloService implements HelloServiceFacade {
@Override
public void sayHello() {
System.out.println("123");
}
}
配置文件
Dubbo相關配置
dubbo.scan.basePackages=掃描包路徑
dubbo.application.id=springboot-dubbo-provider
dubbo.application.name=springboot-dubbo-provider
dubbo.protocol.id=dubbo
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880
dubbo.registry.id=zookeeper-registry
dubbo.registry.address=zk地址
dubbo.registry.protocol=zookeeper
dubbo.monitor.protocol=registry
pom文件的配置
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.smart.springboot</groupId>
<artifactId>springboot-dubbo-provider</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!--引入dubbo環境-->
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>0.2.0</version>
</dependency>
<dependency>
<groupId>com.smart.springboot</groupId>
<artifactId>springboot-dubbo-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
定義服務消費者
服務的引用(便於服務的管理)
import com.alibaba.dubbo.config.annotation.Reference;
import com.smart.springboot.api.HelloServiceFacade;
import org.springframework.stereotype.Component;
@Component
public class ConsumerManager {
@Reference(version="1.0.0")
private HelloServiceFacade helloServiceFacade;
public HelloServiceFacade getHelloServiceFacade(){
return helloServiceFacade;
}
}
消費者的定義
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
@Component
public class HelloServiceConsumer extends ConsumerManager{
@Autowired
private ConsumerManager consumerManager;
public void sayHello(){
consumerManager.getHelloServiceFacade().sayHello();
}
}
SpringBoot啓動類
import com.smart.springboot.consumer.HelloServiceConsumer;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
@SpringBootApplication
public class SpringBootDubboConsumer {
public static void main(String[] args) {
ConfigurableApplicationContext configurableApplicationContext = SpringApplication.run(SpringBootDubboConsumer.class,args);
HelloServiceConsumer helloSereviceConsumer = configurableApplicationContext.getBean(HelloServiceConsumer.class);
helloSereviceConsumer.sayHello();
}
}
配置
dubbo.scan.basePackages=包路徑
dubbo.application.id=springboot-dubbo-consumer
dubbo.application.name=springboot-dubbo-consumer
dubbo.protocol.id=dubbo
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880
dubbo.registry.id=zookeeper-registry
dubbo.registry.address=zk地址
dubbo.registry.protocol=zookeeper
dubbo.monitor.protocol=registry
dubbo.consumer.check=false
總結
本文主要是讓讀者學會Springboot與Dubbo的簡單整合,每天進步一點點。