现在用spring cloud框架搭建微服务已经是比较流行了,毕竟这个是spring提供给我们的一个框架,可以很好配合spring boot使用,很快就可以搭建出一个微服务来,大大的减少了工作量。
这里就谈一下,各个微服务之间要怎么的互相调用。这个就需要一个有服务注册和发现功能的服务,所有的微服务注册到这个服务上面,这样的话,所有的微服务就客户互相的调用了。
服务的注册和发现功能,目前有两种形式:一种是客户端发现(eureka),比较流行。另一种是服务端发现(zookeeper或consul)。
这里主要谈一下使用zookeeper作为服务注册中心与配置中心。
一、服务注册中心
1.安装zookeeper
解压zookeeper:
1 | 复制代码tar -xvf zookeeper-3.4.10.tar.gz |
)
启动zookeeper:
1 | bash复制代码cd zookeeper-3.4.10 |
)
2.引入依赖
1 | xml复制代码<dependency> |
)
3.创建微服务,并以zookeeper作为服务注册中心。
1 | typescript复制代码package com.garlic.springcloudzookeeperclientapp; |
)
对应的application.properties
1 | ini复制代码## 配置应用名称 |
)
使用DiscoveryClient获取注册服务列表
1 | kotlin复制代码package com.garlic.springcloudzookeeperclientapp.controller; |
)
注:可以启动不同的实例,此处我启动了端口8080与8081两个实例,然后使用端点可以查询到所注册的服务列表。同样可以通过zookeeper相关命令查询到说注册的服务列表
1 | csharp复制代码sh zkCli.sh |
)
二、配置中心
1.使用zkCli创建配置信息
1 | bash复制代码[zk: localhost:2181(CONNECTED) 27] create /config "" |
)
2.使用controller来动态获取zookeeper配置中心的数据
2.1maven依赖
1 | xml复制代码<dependency> |
)
2.2bootstrap.properties
1 | ini复制代码## 启用zookeeper作为配置中心 |
)
spring.cloud.zookeeper.config.root对应zkCli创建的config目录,defaultContext对应创建的garlic或garlic-* 目录,根据profile来确定获取dev还是test或者prod配置
2.3application.properties
1 | ini复制代码## 配置应用名称 |
)
2.4使用controller来动态获取zookeeper配置中心的数据
1 | kotlin复制代码package com.garlic.springcloudzookeeperconfigapp.controller; |
)
启动配置实例之后,可以通过zkCli修改garlic下name的值,然后通过访问端点来查看值是否变化。至此,使用zookeeper作为服务注册中心与配置中心就完成了,我们可以通过使用zookeeper作为配置中心,然后使用zuul作为API网关,配置动态路由,为服务提供者,配置数据库连接相关信息。
本文转载自: 掘金