基于Spring Cloud Zookeeper實現服務注冊與發(fā)現
更新時間:2020年11月20日 09:17:20 作者:自律給我自由
這篇文章主要介紹了基于Spring Cloud Zookeeper實現服務注冊與發(fā)現,幫助大家更好的理解和學習spring框架,感興趣的朋友可以了解下
服務注冊
1.添加Spring Cloud Zookeeper依賴:
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId> <exclusions> <exclusion> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.6.2</version> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
2.在服務配置文件中添加zookeeper配置:
spring: cloud: zookeeper: connect-string: localhost:2181 #zookeeper地址
3.啟動zookeeper服務器和服務(我這邊是啟動了兩個服務,分別是provider和consumer),然后在zookeeper客戶端中可以查看已經注冊到zookeeper中的服務:

服務發(fā)現
1.創(chuàng)建controller
消費者controller:
package com.buhe.zk.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import java.util.List;
@RestController
public class ZkConsumerController {
private static final String SERVICE_NAME = "provider";
private static final String SERVICE_PATH = "/zk/provider";
@Autowired
private RestTemplate restTemplate;
@Autowired
private DiscoveryClient discoveryClient;
/**
* 調用提供者服務
* @return
*/
@GetMapping("/zk/consumer")
public String zkConsumer(){
return "我吃了" + restTemplate.getForObject("http://" + SERVICE_NAME + SERVICE_PATH, String.class);
}
/**
* 獲取提供者服務URL
* @return
*/
@GetMapping("/zk/url")
public String serviceUrl() {
List<ServiceInstance> list = discoveryClient.getInstances(SERVICE_NAME);
if (list != null && list.size() > 0 ) {
return list.get(0).getUri().toString() + SERVICE_PATH;
}
return null;
}
}
要使用RestTemplate別忘了加配置:
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
提供者controller:
package com.buhe.zk.controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class ZkProviderController {
@GetMapping("/zk/provider")
public String zkProvider(){
return "10個蘋果";
}
}
2.服務調用

以上就是基于Spring Cloud Zookeeper實現服務注冊與發(fā)現的詳細內容,更多關于Spring Cloud Zookeeper服務注冊與發(fā)現的資料請關注腳本之家其它相關文章!
您可能感興趣的文章:
- SpringCloud用Zookeeper搭建配置中心的方法
- springcloud集成zookeeper的方法示例
- SpringBoot+Dubbo+Zookeeper實現簡單分布式開發(fā)的應用詳解
- 關于idea+centos7+zookeeper報錯connectionloss,timeout問題
- 如何用python 操作zookeeper
- Zookeeper全局唯一ID生成方案解析
- SpringBoot中dubbo+zookeeper實現分布式開發(fā)的應用詳解
- 2020最新IDEA SpringBoot整合Dubbo的實現(zookeeper版)
- SpringBoot系列教程之dubbo和Zookeeper集成方法
- Python通過zookeeper實現分布式服務代碼解析
- 在Java中操作Zookeeper的示例代碼詳解
- SpringCloud使用Zookeeper作為注冊中心
相關文章
Spring Boot @Conditional注解用法示例介紹
這篇文章主要給大家介紹了關于Spring Boot @Conditional注解用法的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Spring Boot具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-11-11

