Dubbo+ZooKeeper

1. ZooKeeper安转(注册中心)

1.1 下载地址

下载地址: zookeeper-3.4.14.tar.gz.(windows、linux都可以用)

1.2 下载之后,进行解压,如图所示:

在这里插入图片描述

1.3 进入bin目录下,双击服务端运行。

在这里插入图片描述

启动成功:
在这里插入图片描述
然后双击客户端(如下连接成功):
在这里插入图片描述

1.4 闪退问题

如果双击服务端闪退,解决办法是先将zkServer.cmd用记事本打开,最后一行加一个pause,然后再双击运行,查看报错信息。
在这里插入图片描述
在这里插入图片描述
然后就去更改配置:(这个文件里面有客户端端口号等配置信息)
在这里插入图片描述

1.5 在客户端zkCli.cmd进行一些测试

比如输入 create -e …getls /
在这里插入图片描述

2. dubbo-admin安装

注意: dubbo-admin是一个监控管理后台(可视化界面),查看我们注册了哪些服务,哪些服务被消费了。(也可以不要)

2.1 下载地址

Dubbo-admin下载地址: Dubbo-admin.

2.2 解压完成之后

在这里插入图片描述

2.3 打包

在项目目录下对项目进行打包dubbo-admin,命令如下:

mvn clean package -Dmaven.test.skip=true

打包成功:
在这里插入图片描述
在dubbo-admin路径下生成jap包:
在这里插入图片描述

2.4 执行jap包

执行前要保证ZooKeeper运行了。
在这里插入图片描述

2.5 进行可视化访问

用户名、密码默认都是root
端口号是7001,可以去该项目的.properties配置文件中更改.
在这里插入图片描述
在这里插入图片描述

3. 进行SpringBoot整合

3.1 新建两个SpringBoot项目

这里分别叫provider-server、consumer-server了,分别是服务提供者服务消费者
在这里插入图片描述

3.2 编写provider-server

  • 1.在service层写一个卖票的业务:

TicketService接口:

public interface TicketService {
    public String getTicket();
}

TicketService实现类:

@Component  //实用Dubbo之后,尽量不要使用@Service注解
public class TicketServiceImpl implements TicketService {
    @Override
    public String getTicket() {
        return "卖票卖票";
    }
}
  • 2.在配置文件中改端口号为8081(为了和消费者区分,消费者8082),并配置如下信息:
server.port=8081	# 这个不重要,为了让两个项目都跑起来

# 服务应用名字
dubbo.application.name=provider-server
# 注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
# 哪些服务要被注册
dubbo.scan.base-packages=com.hui.service
  • 3.增加依赖
<!--导入依赖:Dubbo + zookeeper-->
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>2.7.3</version>
</dependency>


<!--zkclient,用github的-->
<dependency>
    <groupId>com.github.sgroschupf</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.1</version>
</dependency>

<!--日志会冲突,解决冲突-->
<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>
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
        </exclusion>
    </exclusions>
</dependency>
  • 4.运行起来(保证zookeeper是运行着嘞)
    在这里插入图片描述
    启动之后,可以看到dubbo-admin中多了一个连接:
    在这里插入图片描述

3.3 编写consumer-server

  • 1.导入依赖,类似于3.2中第3步。

  • 2.在配置文件中改端口号为8082,还有其他配置

server.port=8082

# 消费者取拿服务需要暴漏自己的名字
dubbo.application.name=consumer-server
# 注册中心的地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
  • 3.写一个UserService类实现用户买票业务
import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    // 想拿到provider-server提供的票
    @Reference  // 方式一:引用pom坐标,方式二:也可以定义路径相同的接口名
    TicketService ticketService;

    public void buyTicket(){
        String ticket = ticketService.getTicket();
        System.out.println("在注册中心拿到"+ticket);
    }
}

在这里插入图片描述

  • 4.在消费者中编写测试类:
@SpringBootTest
class ConsumerServerApplicationTests {
    @Autowired
    UserService userService;
    @Test
    void contextLoads() {
        userService.buyTicket();
    }
}
  • 5.运行成功:
    在这里插入图片描述
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值