SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

Stella981
• 阅读 752

此文转载自:https://blog.csdn.net/qq771650656/article/details/113050300#commentBox

SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

Window下安装Zookeeper和Dubbo-admin

1、Apache官网下载Zookeeper

  1. 点击官网地址下载最新版

  2. 下载完成后,打开apache-zookeeper-3.6.2-bin\bin下zkServer.cmd,正常第一次都会闪退的,因为没有配置好zoo.cfg配置文件。

  3. 将conf目录下的zoo_sample.cfg文件,复制一份,重命名为zoo.cfg
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

  4. 在apache-zookeeper-3.6.2-bin目录下新建两个文件夹data和log
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

  5. 修改zoo.cfg配置文件
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
    (修改dataDir的路径和增加dataLogDir分别对应刚刚新建的data和log文件夹)

  6. 然后运行bin下zkServer.cmd(不关闭)

  7. 再运行zkCli.cmd
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
    证明zookeeper搭建成功(详细的安装步骤百度一大堆)

2、GitHub下载Dubbo-admin

  1. 去GitHub里面下载:点击GitHub地址
  2. 下载完解压到自己习惯的位置
  3. 打开到根目录,本地地址前面加cmd 进入控制台,运行代码,打包dubbo-admin

mvn clean package -Dmaven.test.skip=true

  1. 命令行运行 dubbo-admin\target 下的dubbo-admin-0.0.1-SNAPSHOT.jar

java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

执行完毕,我们去访问一下 http://localhost:7001/ , 这时候我们需要输入登录账户和密码,我们都是默认的root-root;

登录成功后,查看界面
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

3、SpringBoot + Dubbo + Zookeeper

框架搭建

  1. 启动zookeeper !

  2. IDEA创建一个空项目,项目选择最下面那个Empty Project;

  3. 创建一个模块,选择Spring Initializr,实现服务提供者:provider-server ,选择web依赖即可

  4. 创建一个模块,选择Spring Initializr,实现服务消费者:consumer-service,选择web依赖即可

  5. 项目创建完毕;
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

  6. pom.xml配置文件引入Dubbo + zookeeper

        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.3</version>
        </dependency>
    
        <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
    
        <!-- 引入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>
    
  7. 在provider-server项目下写一个服务
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

TicketService.java

public interface TicketService {

    public String getTicket();
}

TicketServiceImpl.java

import org.apache.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;

//zookeeper:服务注册与实现

@Service   //可以被扫描到,在项目一启动就自动注册到注册中心
@Component  //使用了dubbo后,注意不要用到spring的service注解
public class TicketServiceImpl implements TicketService {
    @Override
    public String getTicket() {
        return "枫";
    }
}
  1. 在consumer-server项目下写一个消费者服务
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用

UserService.Java

import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;


@Service// 注入容器中,用spring的注解
public class UserService {

    //要拿到provider-service提供的票,要去注册中心
    @Reference   //引用,导入dubbo的包。正常开发引用pom坐标,但是可以定义路径相同的接口名
    TicketService ticketService;

    public void buyTicket(){
        String ticket = ticketService.getTicket();

        System.out.println("在注册中心拿到=》"+ticket);
    }
}
  1. 在provider-service的配置文件中配置dubbo相关属性!

SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
11. 在consumer-service的配置文件中配置dubbo相关属性!
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
12. 本来正常步骤是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同;
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
将provider-service的TicketService复制一份到consumer-service注意要相同目录

  1. 启动两个项目的启动类,注意配置文件中的端口号配置成不一样的,然后打开http://localhost:7001登录,服务治理-服务

SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用
提供者和消费者都有显示,搭建成功,后台一定要挂着zookeeper的服务。

总结

这就是SpingBoot + dubbo + zookeeper实现分布式开发的应用,其实就是一个服务拆分的思想。只是一个小小的实现,个人感觉还是挺容易理解的,主要是搭建zookeeper的环境要注意下细节,还有项目中导包注解不要导错,因为@service有两个选择,一个是spring一个是dubbo的。还有就是正常开发是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同,正常开发步骤还没学到,后面持续学习中,有相关案例再分享吧0.0。

本文同步分享在 博客“phyger”(CNBlog)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
2个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
8个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这