一、项目介绍
1、IDEA创建多模块springboot项目
springboot-dubbo-api:接口层
springboot-dubbo-client:服务消费者
springboot-dubbo-server:服务提供者
data:image/s3,"s3://crabby-images/85de4/85de482fc97540d38b886105862b1d0b60e602b0" alt=""
二、springboot-dubbo-server:服务提供者
1、实现我们在springboot-dubbo-api上定义的接口,创建一个DubboServerServiceImpl类并实现ApiService
package com.example.dubbo.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import com.example.dubbo.service.ApiService;
@Service(version = "1.0.0")
public class DubboServerServiceImpl implements ApiService {
@Override
public String getParm(String parm) {
return parm;
}
}
注意:代码里的@Service注解是com.alibaba.dubbo.config.annotation.Service的。
2、在resources下创建一个spring-dubbo.xml配置文件。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="provider"/>
<!-- 注册中心的ip地址 -->
<dubbo:registry address="zookeeper://127.0.0.1:2181"/>
<!-- 扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类 -->
<dubbo:annotation package="com.example.dubbo.service.impl"/>
</beans>
3、在ServerApplication.java文件添加
package com.example.dubbo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ImportResource;
@SpringBootApplication(scanBasePackages = {"com.example.dubbo"})
@MapperScan("com.example.dubbo.*") //扫描的mapper
@ImportResource({"classpath:spring-dubbo.xml"})
public class ServerApplication {
public static void main(String[] args) {
SpringApplication.run(ServerApplication.class, args);
}
}
三、springboot-dubbo-client:服务消费者
1、编写我们的Controller控制类
package com.example.dubbo.controller;
import com.alibaba.dubbo.config.annotation.Reference;
import com.example.dubbo.service.ApiService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class ClientController {
@Reference(version = "1.0.0")
private ApiService apiService;
@RequestMapping("client")
public String client(String parm){
return apiService.getParm(parm);
}
}
2、在resources下创建一个spring-dubbo.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="consumer"/>
<dubbo:registry address="zookeeper://127.0.0.1:2181"/>
<dubbo:annotation package="com.example.dubbo.controller"/>
</beans>
3、在ServerApplication.java文件添加
package com.example.dubbo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ImportResource;
@SpringBootApplication(scanBasePackages = {"com.example.dubbo"})
@MapperScan("com.example.dubbo.*") //扫描的mapper
@ImportResource({"classpath:spring-dubbo.xml"})
public class DubboClientApplication {
public static void main(String[] args) {
SpringApplication.run(DubboClientApplication.class, args);
}
}
至此,代码部分已经编写完毕
4、安装zookeeper注册中心到电脑中
下载地址:zookeeper下载地址
点击后下载适合自己的版本,如图所示
data:image/s3,"s3://crabby-images/32af2/32af2f0b941399a361d113c35975ee8335e4531c" alt=""
进入bin目录,运行zkServer.cmd文件。
data:image/s3,"s3://crabby-images/a0ee5/a0ee5d23632e23d1e4004f94555f0524b5dbfaf7" alt=""
5、安装dubbo-admin-2.5.8
链接:https://pan.baidu.com/s/1Hfb778tIYhwjTZ_gx2BcYg
提取码:yrfd
下载好用Jetty或Tomcat运行起来
data:image/s3,"s3://crabby-images/94e01/94e014b88f79bb0c4b75aed6365561da8ae8cdc1" alt=""
界面
data:image/s3,"s3://crabby-images/e4b5f/e4b5fe622226fc9128cf126d8a398e19b297c214" alt=""
6. 现在终于可以运行我们的项目了
依次运行server、client
data:image/s3,"s3://crabby-images/2ce09/2ce093b3d42bbdc719f687cf88c3d7f433c760ee" alt=""
server控制台看到如图所示,说明注册成功
data:image/s3,"s3://crabby-images/bb938/bb938d8599010eba408c22722aaf21ca0494eba2" alt=""
data:image/s3,"s3://crabby-images/b26cc/b26ccce28cb765c2f5c6d7dd5b148c75620fee92" alt=""
data:image/s3,"s3://crabby-images/c704f/c704f6344ee309439e84493f26c02c1ca95fe8b1" alt=""