SpringBoot+ZooKeeper+ZKUI+Drools 实现应用配置中心及业务规则动态加载

本文目的

  1. 使用ZooKeeper作为SpringBoot应用的配置中心
  2. 应用中使用到的业务规则存储在Zookeeper中,规则更新后在不重启应用的情况下通知应用动态重载规则
1.zookeeper简介

Zookeeper是一个高性能,分布式的,开源分布式应用协调服务。它提供了简单原始的功能,分布式应用可以基于它实现更高级的服务,比如同步,配置管理,集群管理,命名空间。它被设计为易于编程,使用文件系统目录树作为数据模型。服务端跑在java上,并且提供java和C的客户端API。

数据模型:

特点:

  • 采用树形结构,每个节点叫Znode,节点路径已/分隔,如:/zoo/foo,每个节点路径必须唯一,且没有相对路径
  • 每个Znode都可以存储数据,数据类型byte[],都可以有子节点
  • 每个Znode都有一个stat数据结构来存储数据的版本,ACL及时间戳等
  • 每个Znode都可以进行CRWD操作

由此可见,采用zookeeper可以很方便的管理应用的配置,如:名为cyzy-gpserver的springboot应用,可以将配置存储在:

  • /cyzy-gpserver ## 等同 application.yml
  • /cyzy-gpserver,dev ## 等同 application-dev.yml
  • /cyzy-gpserver,prod ## 等同 application-prod.yml

这些节点下,每个节点下再分别存储相关配置项,如:

2.zookeeper及其ui客户端安装
zookeeper:

前往http://www.apache.org/dyn/closer.cgi/zookeeper/,下载3.4.6

修改如下配置,zookeeper-3.4.6\conf\zoo.cfg:

# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just 
# example sakes.
dataDir=D:\dev\zookeeper-3.4.6\datas

运行:

  • windows:zookeeper-3.4.6\bin\zkServer.cmd
  • linux:zookeeper-3.4.6\bin\zkServer.sh
ui客户端zkui:

前往https://github.com/DeemOpen/zkui,参考文档自行编译打包。
或使用别人做好的
http://download.csdn.net/detail/lirenzuo/9640272

登陆用户名/密码配置,zkui\config.cfg:

userSet = {"users": [{ "username":"admin" , "password":"admin","role": "ADMIN" }

运行:
java -jar xxx.jar

3.与SpringBoot整合

pom:

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.4.0.RELEASE</version>
</parent>

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-zookeeper-config</artifactId>
  </dependency>
</dependencies>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>Camden.SR2</version>
            <type>pom</type>
            <scope>import</scope>
  
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值