本文目的:
- 使用ZooKeeper作为SpringBoot应用的配置中心
- 应用中使用到的业务规则存储在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>