Dubbo+ZooKeeper

Dubbo+ZooKeeper,第1张

Dubbo+ZooKeeper

目录
  • 1. ZooKeeper安转(注册中心)
    • 1.1 下载地址
    • 1.2 下载之后,进行解压,如图所示:
    • 1.3 进入bin目录下,双击服务端运行。
    • 1.4 闪退问题
    • 1.5 在客户端zkCli.cmd进行一些测试
  • 2. dubbo-admin安装
    • 2.1 下载地址
    • 2.2 解压完成之后
    • 2.3 打包
    • 2.4 执行jap包
    • 2.5 进行可视化访问
  • 3. 进行SpringBoot整合
    • 3.1 新建两个SpringBoot项目
    • 3.2 编写provider-server
    • 3.3 编写consumer-server

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 … 、get 、 ls /:

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.增加依赖

    org.apache.dubbo
    dubbo-spring-boot-starter
    2.7.3





    com.github.sgroschupf
    zkclient
    0.1




    org.apache.curator
    curator-framework
    2.12.0


    org.apache.curator
    curator-recipes
    2.12.0


    org.apache.zookeeper
    zookeeper
    3.4.14
    
        
            org.slf4j
            slf4j-log4j12
        
    

  • 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.运行成功:

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5575502.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存