【SpringCloud】Consul服务注册与发现

【SpringCloud】Consul服务注册与发现,第1张

概述Consul服务注册发现 #Consul简介 ##是什么 https://www.consul.io/intro/index.html Consul是一开源的分布式服务发现和配置管理系统,由Hash

Consul服务注册与发现

Consul简介是什么

https://www.consul.io/intro/index.HTML


Consul是一开源的分布式服务发现和配置管理系统,由HashiCorp公司用Go语言开发。

提供了微服务系统中的服务治理、配置中心控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以-起使用以构建全方位的服务网格,总之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

结果页面

服务提供者新建Module支付服务provIDer8006

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>
YML
server:  # 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);    }}
业务类Controller
package 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

服务消费者新建Module消费服务order80

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>
YML
server:  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集成
EurekaJavaAP可配支持http已集成
ConsulGoCP支持http/DNS已集成
ZookeeperJavaCP支持客户端已集成

CAP

在分布式中,分区容错性要保证,所以要么是CP,要么是AP

C: Consistency(强一致性)A: Availability(可用性)P: Parttition tolerance(分区容错性)

CAP理论关注粒度是否是数据,而不是整体系统设计的策略

经典CAP图

最多只能同时较好的满足两个。
CAP理论的核心是:一个分布式系统不可能同时很好的满足一致性,可用性和分区容错性这三个需求,
因此,根据CAP原理将Nosql数据库分成了满足CA原则、满足CP原则和满足AP原则三大类:

CA:单点集群,满足一致性,可用性的系统,通常在可扩展性坏太强大。CP:满足一致性,分区容忍必的系统,通常性能不是特别高。AP:满足可用性,分区容忍性的系统,通常可能对一致性要求低一些。

AP(eureka)

CP(Zookeeper/Consul)

CP架构
当网络分区出现后,为了保证一致性,就必须拒绝请求,否则无法保证一致性
结论:违背了可用性A的要求,只满足一致性和分区容错,即CP

总结

以上是内存溢出为你收集整理的【SpringCloud】Consul服务注册与发现全部内容,希望文章能够帮你解决【SpringCloud】Consul服务注册与发现所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1215437.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存