Consul服务注册与发现
Consul简介是什么https://www.consul.io/intro/index.HTML
提供了微服务系统中的服务治理、配置中心控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以-起使用以构建全方位的服务网格,总之Consul提供了一种完整的服务网格解决方案。
它具有很多优点。包括:基于raft协议,比较简洁;支持健康检查,同时支持http和DNS协议支持跨数据中心的WAN集群提供图形界面跨平台,支持linux、Mac、 windows
能干嘛服务发现提供http/DNS两种发现方式
健康检测支持多种方式,http、TCP、Docker、shell脚本定制化
KV存储Key、Value的存储方式
多数据中心Consul支持多数据中心
可视化界面去哪下https://www.consul.io/downloads.HTML
怎么玩https://www.springcloud.cc/spring-cloud-consul.HTML
安装并运行Consul官网说明https://learn.hashicorp.com/consul/getting-started/install.HTML
下载完成后只有一个consul.exe文件 硬盘路径下双击运行,查看版本信息consul --version
使用开发模式启动consul agent -dev
通过以下地址可以访问Consul的首页: http://localhost:8500
结果页面
cloud-provIDerconsul-payment8006
POM<?xml version="1.0" enCoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactID>cloud2020</artifactID> <groupID>com.atguigu.springcloud</groupID> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactID>cloud-provIDerconsul-payment8006</artifactID> <description>支付服务的提供者之注册中心consul</description> <dependencIEs> <!--SpringCloud consul-server--> <dependency> <groupID>org.springframework.cloud</groupID> <artifactID>spring-cloud-starter-consul-discovery</artifactID> </dependency> <dependency> <groupID>com.atguigu.springcloud</groupID> <artifactID>cloud-API-common</artifactID> <version>${project.version}</version> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-web</artifactID> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-actuator</artifactID> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-devtools</artifactID> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupID>org.projectlombok</groupID> <artifactID>lombok</artifactID> <optional>true</optional> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-test</artifactID> <scope>test</scope> </dependency> </dependencIEs></project>
YMLserver: # consul服务端口 port: 8006spring: application: name: cloud-provIDer-payment cloud: consul: # consul注册中心地址 host: localhost port: 8500 discovery: hostname: 127.0.0.1 service-name: ${spring.application.name}
主启动类package com.atguigu.springcloud;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.clIEnt.discovery.EnablediscoveryClIEnt;/** * * @author zzyy * @create 2020/2/17 21:13 **/@SpringBootApplication@EnablediscoveryClIEntpublic class PaymentMain8006 { public static voID main(String[] args) { SpringApplication.run(PaymentMain8006.class,args); }}
业务类Controllerpackage com.atguigu.springcloud.controller;import lombok.extern.slf4j.Slf4j;import org.springframework.beans.factory.annotation.Value;import org.springframework.web.bind.annotation.RequestMapPing;import org.springframework.web.bind.annotation.RestController;import java.util.UUID;/** * @author zzyy * @create 2020-01-30 16:55 **/@RestController@Slf4jpublic class PaymentController { @Value("${server.port}") private String serverPort; @RequestMapPing(value = "payment/consul") public String paymentConsul() { return "SpringCloud with consul:" + serverPort + "\t" + UUID.randomUUID().toString(); }}
验证测试http://localhost:8006/payment/consul
cloud-consumerconsul-order80
POM<?xml version="1.0" enCoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactID>cloud2020</artifactID> <groupID>com.atguigu.springcloud</groupID> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactID>cloud-consumerconsul-payment80</artifactID> <description>服务消费者之注册中心consul</description> <dependencIEs> <!--SpringCloud consul-server--> <dependency> <groupID>org.springframework.cloud</groupID> <artifactID>spring-cloud-starter-consul-discovery</artifactID> </dependency> <dependency> <groupID>com.atguigu.springcloud</groupID> <artifactID>cloud-API-common</artifactID> <version>${project.version}</version> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-web</artifactID> </dependency> <!--监控--> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-actuator</artifactID> </dependency> <!--热部署--> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-devtools</artifactID> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupID>org.projectlombok</groupID> <artifactID>lombok</artifactID> <optional>true</optional> </dependency> <dependency> <groupID>org.springframework.boot</groupID> <artifactID>spring-boot-starter-test</artifactID> <scope>test</scope> </dependency> </dependencIEs></project>
YMLserver: port: 80spring: application: name: cloud-consumer-order cloud: consul: # consul注册中心地址 host: localhost port: 8500 discovery: hostname: 127.0.0.1 service-name: ${spring.application.name}
主启动类package com.atguigu.springcloud;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.clIEnt.discovery.EnablediscoveryClIEnt;/** * @author zzyy * @date 2020/02/18 17:20 **/@SpringBootApplication@EnablediscoveryClIEntpublic class OrderConsulMain80 { public static voID main(String[] args) { SpringApplication.run(OrderConsulMain80.class,args); }}
配置bean配置一个和其他order一样的ApplicationContextConfig
Controller@RestController@Slf4jpublic class OrderConsulController { private static final String INVOKE_URL = "http://consul-provIDer-payment"; @Resource private RestTemplate restTemplate; @GetMapPing(value = "/consumer/payment/consul") public String paymentInfo() { String result = restTemplate.getForObject(INVOKE_URL+"/payment/consul",String.class); return result; }}
验证测试访问测试地址http://localhost/consumer/payment/consul
三个注册中心异同点组件名 | 语言 | CAP | 服务健康检查 | 对外暴露接口 | SpringCloud集成 |
---|---|---|---|---|---|
Eureka | Java | AP | 可配支持 | http | 已集成 |
Consul | Go | CP | 支持 | http/DNS | 已集成 |
Zookeeper | Java | CP | 支持 | 客户端 | 已集成 |
在分布式中,分区容错性要保证,所以要么是CP,要么是AP
C: Consistency(强一致性)A: Availability(可用性)P: Parttition tolerance(分区容错性)CAP理论关注粒度是否是数据,而不是整体系统设计的策略
经典CAP图最多只能同时较好的满足两个。
CAP理论的核心是:一个分布式系统不可能同时很好的满足一致性,可用性和分区容错性这三个需求,
因此,根据CAP原理将Nosql数据库分成了满足CA原则、满足CP原则和满足AP原则三大类:
CP架构
当网络分区出现后,为了保证一致性,就必须拒绝请求,否则无法保证一致性
结论:违背了可用性A的要求,只满足一致性和分区容错,即CP
以上是内存溢出为你收集整理的【SpringCloud】Consul服务注册与发现全部内容,希望文章能够帮你解决【SpringCloud】Consul服务注册与发现所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)