dubbo 文档,链接,https://dubbo.apache.org/zh/docs/v2.7/user/quick-start/。
官方文档是spring 的,我这里写的是spring boot 的。
工程目录。
新建 Spring boot 工程作为服务提供方。建立 spring boot 的 module 工程作为消费者。建立 maven 的 module 作为连接接口。
接口工程 api。
// IProviderService.java
public interface IProviderService {
public String method(String name);
}
服务提供方工程 provider。
// pom.xml
// 注意 不需要改为 starter-web 依赖,
// dubbo 依赖在阿里镜像里还不能下载,需要进入 IntelliJ IDEA.app/Contents/plugins/maven/lib/maven3/conf 里更改
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>0.2.0</version>
</dependency>
<dependency>
<groupId>com.roit</groupId>
<artifactId>api</artifactId>
<version>1.0.0</version>
</dependency>
// application.yml, 注册到 zookeeper 上
dubbo:
application:
name: provider
registry:
address: zookeeper://10.36.144.24:2181
// ProviderServiceImpl.java
// 注意Service包, com.alibaba.dubbo.config.annotation.Service;
@Service
public class ProviderServiceImpl implements IProviderService {
@Override
public String method(String name) {
System.out.println("name: " + name);
return "服务提供者:" + name;
}
}
// ProviderApplication.java
@SpringBootApplication
@DubboComponentScan(basePackages = "com.roit.service")
public class ProviderApplication {
public static void main(String[] args) {
SpringApplication.run(ProviderApplication.class, args);
}
}
消费者工程 consumer。
// pom.xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>0.2.0</version>
</dependency>
<dependency>
<groupId>com.roit</groupId>
<artifactId>api</artifactId>
<version>1.0.0</version>
</dependency>
// application.yml
dubbo:
application:
name: consumer
registry:
address: zookeeper://10.36.144.24:2181
// ConsumerController.java
// 注意包 com.alibaba.dubbo.config.annotation.Reference;
@RestController
@RequestMapping("/consumer")
public class ConsumerController {
@Reference
private IProviderService providerService;
@RequestMapping("/method")
public String method() {
return providerService.method("dubbo");
}
}
// ConsumerApplication.java
// 注意这里我的 controller 和 application 在同级目录,如果是 application 的下级目录,不需要 scanBasePackages
@SpringBootApplication(scanBasePackages = "com.roit")
public class ConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerApplication.class, args);
}
}
// 测试 默认端口 8080;
// http://localhost:8080/consumer/method
查看 dubbo 是否注册到 zookeeper 上。
docker exec -it zk1 /bin/bash
ls
cd bin
./zkCli.sh
// 可以看到其下有 dubbo 目录了
ls /
图形化的监控界面需要下载 dubbo 提供的工程,然后放到 tomcat 的 webapp 下打开。这里就不演示了。