dubbo 快速入门


在这里插入图片描述

  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 下打开。这里就不演示了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值