『高级篇』docker之课程管理dubbo入门操练(14)
admin
2023-04-08 17:23:25
0

原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
原文链接地址:『高级篇』docker之课程管理dubbo入门操练(14)

接下来我们即将开始说课程管理,课程服务他是基于dubbo实现的,所以先来预热下,dubbo,对不熟悉的dubbo的老铁进行一下讲解。 源码:https://github.com/limingios/dubbo.git

『高级篇』docker之课程管理dubbo入门操练(14)

dubbo 介绍

  • 官网 http://dubbo.apache.org/zh-cn/

    高性能的基于java的,RPC框架。dubbo是阿里巴巴开源的一个项目,就像大多的RPC框架,dubbo的思想围绕一个服务,指定一个方法的参数和返回值,这个方法可以被远程调用的,在服务端,会实现这个接口,会运行dubbo的服务用来处理客户端的调用,在客户端,会有一个存根它提供和服务端想通的方法。其实这些概念用java的术语:首先要定义一个接口,这个接口在服务端和客户端公用,服务端会完成这个接口的实现,客户端通过接口的描述来调用服务端。

『高级篇』docker之课程管理dubbo入门操练(14)

『高级篇』docker之课程管理dubbo入门操练(14)

快速入门讲解 spring 版本,

  • 根据官网来创建

『高级篇』docker之课程管理dubbo入门操练(14)

  • 创建三个api,provider,consumer 三个项目

『高级篇』docker之课程管理dubbo入门操练(14)

『高级篇』docker之课程管理dubbo入门操练(14)

『高级篇』docker之课程管理dubbo入门操练(14)

  • 用了本地调用。
    provider.xml

    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    

consumer.xml



    
        dubbo-demo
        com.idig8
        1.0-SNAPSHOT
    
    4.0.0

    dubbo-demo-consumer
    
        
            com.idig8
            dubbo-demo-api
            1.0-SNAPSHOT
        
        
            com.alibaba
            dubbo
            2.6.4
        
        
            org.springframework
            spring-context
            4.3.0.RELEASE
        
    

快速入门讲解springboot版本

SpringBoot整合dubbo示例

一、定义API(API模块)

1. 定义api

package com.idig8.springboot.dubbo.demo;

public interface DemoService {
    String sayHello(String name);
}

2. install到本地

对外提供的maven坐标如下:


    com.idig8
    dubbo-demo-api
    1.0-SNAPSHOT

二、服务提供者(provider模块)

1. 增加maven依赖



    org.springframework.boot
    spring-boot-starter-parent
    1.5.3.RELEASE



    io.dubbo.springboot
    spring-boot-starter-dubbo
    1.0.0



    com.idig8
    dubbo-demo-api
    1.0-SNAPSHOT

2. 实现API接口

package com.idig8.springboot.dubbo.demo.provider;

import com.alibaba.dubbo.config.annotation.Service;
import com.idig8.springboot.dubbo.demo.DemoService;

@Service
public class DemoServiceImpl implements DemoService {

    public String sayHello(String name) {
        return "Hello, " + name + " (from Spring Boot)";
    }

}

3. springboot配置文件 - application.properties

spring.dubbo.application.name=demo-provider
#这里使用广播的注册方式,
#如果有Can't assign address异常需要加vm参数:
#-Djava.net.preferIPv4Stack=true
spring.dubbo.registry.address=multicast://224.5.6.7:1234
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20880
spring.dubbo.scan=com.idig8.springboot.dubbo.demo.provider

4. 启动类

package com.idig8.springboot.dubbo.demo.provider;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MainProvider {
    public static void main(String[] args) {
        SpringApplication.run(MainProvider.class,args);
    }
}

三、服务消费者(consumer模块)

1. 增加maven依赖



    org.springframework.boot
    spring-boot-starter-parent
    1.5.3.RELEASE



   org.springframework.boot
    spring-boot-starter-web



    io.dubbo.springboot
    spring-boot-starter-dubbo
    1.0.0



    com.idig8
    dubbo-demo-api
    1.0-SNAPSHOT

2. 实现controller

package com.idig8.springboot.dubbo.demo.consumer;

import com.alibaba.dubbo.config.annotation.Reference;
import com.idig8.springboot.dubbo.demo.DemoService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class DemoConsumerController {

    @Reference
    private DemoService demoService;

    @RequestMapping("/sayHello")
    public String sayHello(@RequestParam String name) {
        return demoService.sayHello(name);
    }

}

3. springboot配置文件 - application.properties

server.port=8080
#dubbo config
spring.dubbo.application.name=demo-consumer
#这里使用广播的注册方式,
#如果有Can't assign address异常需要加vm参数:
#-Djava.net.preferIPv4Stack=true
spring.dubbo.registry.address=multicast://224.5.6.7:1234
spring.dubbo.scan=com.idig8.springboot.dubbo.demo.consumer

4. 启动类

package com.idig8.springboot.dubbo.demo.consumer;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Main {

    public static void main(String[] args) {
        SpringApplication.run(Main.class,args);
    }

}

PS:dubbo的入门也就到这里,从spring 和springboot 对dubbo的整合。
流程基本之前也说,api 建立接口,provider 实现接口, consumer 调用接口。

『高级篇』docker之课程管理dubbo入门操练(14)

相关内容

热门资讯

终于明白“荊州晃晃麻将真的有挂... 家人们!今天小编来为大家解答荊州晃晃麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
玩家分享攻略“蜀山四川麻将有没... 网上科普关于“蜀山四川麻将有没有挂”话题很是火热,小编也是针对蜀山四川麻将作*弊开挂的方法以及开挂对...
玩家最新攻略“北部麻将可以开挂... 您好:北部麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
【今日要闻】“新好游炸/金/花... 【今日要闻】“新好游炸/金/花有挂吗?”(原来真的有挂)您好,新好游炸/金/花这个游戏其实有挂的,确...
今日重大通报“微乐三打一真的有... 今日重大通报“微乐三打一真的有挂吗?”(原来真的有挂)您好,微乐三打一这个游戏其实有挂的,确实是有挂...
【第一资讯】“西兵互娱到底是不... 有 亲,根据资深记者爆料西兵互娱是可以开挂的,确实有挂(咨询软件无需打开...
终于明白“道游联盟炸/金/花可... 终于明白“道游联盟炸/金/花可以开挂吗?”(太坑了果然有挂)您好,道游联盟炸/金/花这个游戏其实有挂...
今日重大通报“快乐打筒子到底有... 网上科普关于“快乐打筒子有没有挂”话题很是火热,小编也是针对快乐打筒子作*弊开挂的方法以及开挂对应的...
【第一消息】“酷玩联盟是不是有... 有 亲,根据资深记者爆料酷玩联盟是可以开挂的,确实有挂(咨询软件无需打开...
【第一消息】“丫丫诗词是不是有... 家人们!今天小编来为大家解答丫丫诗词透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...