项目Git地址:https://github.com/duangdangding/dubbo-zookeeper
1、建立一个简单maven项目(提供者和消费者共用的接口)dubboo1
POJO类(User.java)
package com.lsh.dubboo1.pojo;
import java.io.Serializable;
import java.util.Date;
/**
* @Description:
* @author: LuShao
* @create: 2020-04-24 20:42
**/
public class User implements Serializable {
private String name;
private Integer age;
private Date birthday;
public User(String name,Integer age,Date birthday) {
this.name=name;
this.age=age;
this.birthday=birthday;
}
// 省略getter和setter方法
}
Interface接口类(UserService.java)只有一个接口方法
package com.lsh.dubboo1.service;
import com.lsh.dubboo1.pojo.User;
import java.util.List;
/**
* @Description: 定义接口
* @author: LuShao
* @create: 2020-04-24 20:44
**/
public interface UserService {
public List<User> getUser();
}
pom.xml
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.lsh</groupId>
<artifactId>dubboo1</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>dubboo1</name>
<!--
这里就是一个接口和一个POJO,
供提供者和消费者导包引用
简单的maven项目
没有依赖
-->
</project>
然后使用maven打包到本地仓库
2、新建一个springboot项目(提供者)dubbop1
实现类(UserServiceImpl.java)
package com.lsh.dubbop1.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import com.lsh.dubboo1.pojo.User;
import com.lsh.dubboo1.service.UserService;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* @Description:
* @author: LuShao
* @create: 2020-04-24 19:00
**/
// 这里的@Service注解不是spring的而是dubbo的导入的时候要看清楚
@Service
@Component
public class UserServiceImpl implements UserService {
@Override
public List<User> getUser() {
List<User> list = new ArrayList<>();
list.add(new User("ll",112,new Date()));
list.add(new User("lsl",122,new Date()));
list.add(new User("ldl",152,new Date()));
list.add(new User("lg",142,new Date()));
return list;
}
}
项目入口main方法主类(Dubbop1Application.java)
package com.lsh.dubbop1;
import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//开启dubbo注解
@EnableDubbo
@SpringBootApplication
public class Dubbop1Application {
public static void main(String[] args) {
SpringApplication.run(Dubbop1Application.class, args);
}
}
application.properties
dubbo.application.name=user-service-p
dubbo.application.registry.address=zookeeper://127.0.0.1:2181
dubbo.application.monitor.protocol=registry
server.port=8081
pom.xml
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.lsh</groupId>
<artifactId>dubbop1</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>dubbop1</name>
<dependencies>
<dependency>
<groupId>com.lsh</groupId>
<artifactId>dubboo1</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--dubbo依赖-->
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>0.2.0</version>
</dependency>
</dependencies>
</project>
3、新建springboot项目消费者(dubboc1)
控制层(UserCtr.java)
package com.lsh.dubboc1.ctroller;
import com.alibaba.dubbo.config.annotation.Reference;
import com.lsh.dubboo1.service.UserService;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
/**
* @Description:
* @author: LuShao
* @create: 2020-04-24 19:41
**/
@Controller
public class UserCtr {
//这是dubbo的注解,意思是从dubbo服务上查找关联
@Reference
private UserService userService;
@RequestMapping("/getuser")
@ResponseBody
public List getUsers() {
return userService.getUser();
}
}
Dubboc1Application.java
package com.lsh.dubboc1;
import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//开启dubbo注解
@EnableDubbo
@SpringBootApplication
public class Dubboc1Application {
public static void main(String[] args) {
SpringApplication.run(Dubboc1Application.class, args);
}
}
application.yml
dubbo:
application:
name: boot-dubbo-consumer
registry:
address: zookeeper://127.0.0.1:2181
monitor:
protocol: registry
server:
port: 8082
pom.xml
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.lsh</groupId>
<artifactId>dubboc1</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>dubboc1</name>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>com.lsh</groupId>
<artifactId>dubboo1</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<!--dubbo依赖-->
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>0.2.0</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
到这里项目已经简单的搭建完成。
下面开始启动测试:
1、首先启动zookeeper
zookeeper的下载和配置https://blog.csdn.net/lussss/article/details/105749103
dubbo服务注册zookeeper的ip和端口要一致
2、启动dubbop1这个项目
3、启动dubboc1这个项目
成功之后,访问:http://localhost:8082/getuser
Dubbo-Admin监控dubbo服务:
Dubbo-Admin的下载和安装https://blog.csdn.net/lussss/article/details/105749321
根据配置的服务访问正确的dubbo-admin的服务地址
我们可以看到我们启动的dubbo服务