1. 创建空的父项目
一直下一步就可以了
2. 创建生产者服务项目
2.1 provider_service项目目录结构
2.2 引入依赖
<!--Dubbo-->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.11</version>
</dependency>
<!--zkclient-->
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
2.3 编写配置文件
application.properties
# 配置开启端口号
server.port=8081
# 配置Dubbo
# 配置Dubbo应用名称
dubbo.application.name=provider_service
# 配置注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
# 配置注册服务(给其他服务调用)
dubbo.scan.base-packages=com.test.service
2.4 编写Service接口
TicketService.java
public interface TicketService {
public String sellTicket();
}
2.5 编写Service实现类
@Service:指dubbo的注解,可以被扫描到,在项目一启动就自动注册到注册中心;因为spring也有这个注解,避免使用混淆,不推荐使用。
@Component:使用了Dubbo后尽量不要用service注解
@Service//可以被扫描到,在项目一启动就自动注册到注册中心
@Component//使用了Dubbo后尽量不要用service注解
public class TicketServiceImpl implements TicketService {
@Override
public String sellTicket() {
return "provider_service提供ticket";
}
}
2.6 启动测试
注意:
- ZooKeeper服务需要启动成功
- dubbo-admin本地jar包也要部署成功
详情可参考:https://blog.csdn.net/Yearingforthefuture/article/details/117440416
在浏览器输入:http://localhost:7001/governance/providers 默认用户名、密码都是root
3. 创建消费者服务项目
3.1 customer_service项目目录结构
3.2 引入依赖
<!--Dubbo-->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.11</version>
</dependency>
<!--zkclient-->
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
3.3 编写配置文件
application.properties
server.port=8082
# 配置Dubbo
# 配置Dubbo应用名称
# 消费者取哪里拿服务需要暴露自己的名字
dubbo.application.name=customer_service
# 配置注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
3.4 编写业务类
@Service:这里使用的是Spring注解,需要注册到容器中
@Reference:引入提供服务类
引入提供服务类不成功解决方案:
1、引用Pom坐标
2、可以定义路径相同的接口名
import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;
@Service //这里使用的是Spring注解,需要注册到容器中
public class UserService {
//想拿到provider_service提供的票,要去注册中心拿到服务
@Reference//1、引用Pom坐标2、可以定义路径相同的接口名
TicketService ticketService;
public void buyTicket() {
String ticket = ticketService.sellTicket();
System.out.println("在注册中心拿到ticket:"+ticket);
}
}
4. 解决冲突
zookeeper会与springboot的日志发生冲突
<!--zookeeper会与springboot的日志发生冲突-->
<!-- 引入zookeeper -->
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.14</version>
<!--排除这个slf4j-log4j12-->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
5. 编写测试类
CustomerServiceApplicationTests.java
@SpringBootTest
class CustomerServiceApplicationTests {
@Autowired
UserService userService;
@Test
void contextLoads() {
userService.buyTicket();
}
}
6. 启动测试
7. 总结
步骤:
-
提供者提供服务
1.导入依赖
2.配置注册中心的地址,以及服务发现名,和要扫描的包~
3.在想要被注册的服务上面~增加一个注解@Service -
消费者如何消费
1.导入依赖
⒉.配置注册中心的地址,配置自己的服务名~
3.从远程注入服务~
内容参考:https://www.bilibili.com/video/BV1PE411i7CV
仅用于学习!