Spring Cloud微服务注册中心Consul入门使用(上)

news2025/1/30 16:43:17

一、Consul安装使用

1.1 what’s the consul?

Consul是Go语言编写的一个分布式高可用的服务网格解决方案,提供包括服务发现、配置和分段功能在内的全功能控制平面。它的每个功能都可以单独使用,也可以用它来构建完整的服务网格。

为什么要用它呢?因为Eureka很早之前已经宣布不再维护了,但是还有很多替代Eureka的注册中心,例如Nacos、Zookeeper以及接下来要介绍的Consul。

Consul使用Go语言编写,通过HTTP的方式向外提供服务;支持多数据中心;一致性协议使用的是Raft。这些年来Consul一直在活跃更新中,社区活跃度上很可靠。

1.2 Consul的功能

服务发现:

调用的客户端可以通过DNS或HTTP找到要调用的服务

健康检查:

Consul提供了健康检查机制,从简单的服务端是否可以返回200的响应码到较为复杂的内存使用率是否低于90%

使用Key/value进行存储信息:

接入Consul的应用可以根据需要使用Key/Value进行存储信息。提供了易用的HTTP接口来满足用户的动态配置、特征标记、协调和leader选举等功能

多数据中心:

Consul原生就支持多数据中心。这样用户就不用自己来实现多数据中心

1.3 Consul和Consul UI的安装使用

Consul的安装很简单,因为是用Go语言写的,最后是编译完成是一个可执行的文件。支持Window、macOS、Linux等平台。在官网上选择下载的版本即可:https://developer.hashicorp.com/consul/downloads

下载完成后,解压缩,然后执行,例如下面以开发者模式启动。正常启动Consul集群需要至少启动三个Consul

consul agent -dev

$ ./consul agent -dev
==> Starting Consul agent…
Version: ‘1.15.2’
Build Date: ‘2023-03-30 17:51:19 +0000 UTC’
Node ID: ‘cd2c39c3-341c-6478-5daf-ab06807d30a8’
Node name: ‘DESKTOP-ILEN9BL’
Datacenter: ‘dc1’ (Segment: ‘’)
Server: true (Bootstrap: false)
Client Addr: [127.0.0.1] (HTTP: 8500, HTTPS: -1, gRPC: 8502, gRPC-TLS: 8503, DNS: 8600)
Cluster Addr: 127.0.0.1 (LAN: 8301, WAN: 8302)
Gossip Encryption: false
Auto-Encrypt-TLS: false
HTTPS TLS: Verify Incoming: false, Verify Outgoing: false, Min Version: TLSv1_2
gRPC TLS: Verify Incoming: false, Min Version: TLSv1_2
Internal RPC TLS: Verify Incoming: false, Verify Outgoing: false (Verify Hostname: false), Min Version: TLSv1_2

==> Log data will now stream in as it occurs:

2023-04-16T20:57:55.312+0800 [DEBUG] agent.grpc.balancer: switching server: target=consul://dc1.cd2c39c3-341c-6478-5daf-ab06807d30a8/server.dc1 from= to=
2023-04-16T20:57:55.370+0800 [INFO] agent.server.raft: initial configuration: index=1 servers=“[{Suffrage:Voter ID:cd2c39c3-341c-6478-5daf-ab06807d30a8 Address:127.0.0.1:8300}]”
2023-04-16T20:57:55.370+0800 [INFO] agent.server.raft: entering follower state: follower=“Node at 127.0.0.1:8300 [Follower]” leader-address= leader-id=
2023-04-16T20:57:55.371+0800 [INFO] agent.server.serf.wan: serf: EventMemberJoin: DESKTOP-ILEN9BL.dc1 127.0.0.1
2023-04-16T20:57:55.371+0800 [INFO] agent.server.serf.lan: serf: EventMemberJoin: DESKTOP-ILEN9BL 127.0.0.1
2023-04-16T20:57:55.371+0800 [INFO] agent.router: Initializing LAN area manager
2023-04-16T20:57:55.371+0800 [DEBUG] agent.grpc.balancer: switching server: target=consul://dc1.cd2c39c3-341c-6478-5daf-ab06807d30a8/server.dc1 from= to=dc1-127.0.0.1:8300

然后浏览器可以访问:http://localhost:8500/ui/dc1/services。进入Consul的web界面

consul-ui.png

二、Spring Cloud Consul入门使用

2.1 what’s the Spring Cloud Consul?

Spring Cloud是Spring Cloud社区通过Spring Boot自动配置,实现的一套连接Consul使用的服务发现客户端功能。只需要简单的注解便可接入Consul,构建分布式系统。

2.2 Consul在Spring Cloud生态的作用

  • 服务发现与注册,Spring Boot应用可以像Consul注册服务,通过Spring Cloud的服务发现标准DiscoveryClient(spring-cloud-common模块)来发现其他的服务。
  • 支持Ribbon,实现客户端负载均衡
  • 分布式配置中心,通过key/Value存储配置
  • 控制总线,通过Consul events实现总线

2.3 Spring Cloud Consul入门

2.3.1 创建服务提供者(cloud-registry-consul-provider)

引入依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-consul-all</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
</dependencies>

编写个测试接口:

@RestController
@RequestMapping("provider")
public class ProviderController {

    @Value("${server.port}")
    private String port;
    @Value("${spring.application.name}")
    private String appName;

    @GetMapping("info")
    public String info() {
        return "provider name: " + appName + ", port: " + port;
    }
}

启动类:

@SpringBootApplication
@EnableDiscoveryClient
public class ConsulConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsulConsumerApplication.class, args);
    }
}

配置文件:

server:
  port: 8666
spring:
  application:
    name: cloud-registry-consul-provider
  cloud:
    consul:
      host: 127.0.0.1
      port: 8500
      config:
        enabled: false
      discovery:
        heartbeat:
          enabled: true

2.3.2 创建消费者(cloud-registry-consul-consumer)

引入依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-consul-all</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
</dependencies>

创建feign客户端接口:

@FeignClient("cloud-registry-consul-provider")
public interface ConsulProviderFeignClient {

    @GetMapping(value = "provider/info")
    String getProviderInfo();
}

编写接口:

@RestController
@RequestMapping("consumer")
public class ConsumerController {
    
    @Autowired
    private ConsulProviderFeignClient providerFeignClient;

    @GetMapping("getProviderInfo")
    public String getInfo() {
        return providerFeignClient.getProviderInfo();
    }
}

启动类:

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class ConsulConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsulConsumerApplication.class, args);
    }
}

配置文件:

server:
  port: 8080
spring:
  application:
    name: cloud-registry-consul-consumer
  cloud:
    consul:
      host: 127.0.0.1
      port: 8500
      config:
        enabled: false
      discovery:
        heartbeat:
          enabled: true

2.3.3 启动测试

1、启动consul

2、启动服务提供者:cloud-registry-consul-provider

3、启动消费者:cloud-registry-consul-consumer

4、启动完成后,可以看到服务成功注册到Consul

consul-health.png

5、可在浏览器调用

http://localhost:8080/consumer/getProviderInfo

可看到响应:

provider name: cloud-registry-consul-provider, port: 8666

最后

可以关注我的微信公众号,有更多的技术干货文章
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1474155.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MetaGPT 1 安装与配置踩坑实录

安装 与 配置直接参考这里就行&#xff1a;Hugging Muti Agent&#xff08;二月学习&#xff09; - 飞书云文档 (feishu.cn) 这里按照教程安装的是metagpt 0.6.6 &#xff0c;经过跟0.7.0对比&#xff0c;个人认为0.7对其他llm接入可能更好&#xff0c;文档也更清晰。 0.6.6的…

【Vue渗透】Vue站点渗透思路

原文地址 极核GetShell 前言 本文经验适用于前端用Webpack打包的Vue站点&#xff0c;阅读完本文&#xff0c;可以识别出Webpack打包的Vue站点&#xff0c;同时可以发现该Vue站点的路由。 成果而言&#xff1a;可能可以发现未授权访问。 识别Vue 识别出Webpack打包的Vue站…

Doris实战——结合Flink构建极速易用的实时数仓

目录 一、实时数仓的需求与挑战 二、构建极速易用的实时数仓架构 三、解决方案 3.1 如何实现数据的增量与全量同步 3.1.1 增量及全量数据同步 3.1.2 数据一致性保证 3.1.3 DDL 和 DML 同步 Light Schema Change Flink CDC DML 和DDL同步 3.2 如何基于Flink实现多种数…

每日学习总结20240227

每日总结 20240227 1.如何将字符串通过串口以十六进制进行传输 将文件名或者文件内容通过串口传输&#xff0c;再解析&#xff0c;拼接成源文件 1.1 文件转换 1.1.1 转十六进制 在Linux中&#xff0c;你可以使用 xxd 命令将文本文件转换为十六进制格式。以下是如何在Linux中…

如何使用Docker部署WBO容器并实现固定公网地址访问本地白板界面

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…

【代码解读】OpenCOOD框架之model模块(以PointPillarFCooper为例)

point_pillar_fcooper PointPillarFCooperPointPillarsPillarVFEPFNLayerPointPillarScatterBaseBEVBackboneDownsampleConvDoubleConv SpatialFusion检测头 &#xff08;紧扣PointPillarFCooper的框架结构&#xff0c;一点一点看代码&#xff09; PointPillarFCooper # -*- c…

算法竞赛备赛之斜率优化的DP问题

目录 1.任务安排1 2.任务安排2 3.任务安排3 4.运输小猫 在处理下图的最小截距问题上面&#xff0c;我们该如何在维护的凸包中找到战距最小的点&#xff1f; 相当于在一个单调的队列中&#xff0c;找到第一个大于某一个数的点。 斜率单调递增&#xff0c;新加的点的横坐标也…

iOS App 上架指南及关键

引言 上架App Store是将iOS应用提交申请并上线的过程&#xff0c;旨在让应用在App Store上展示&#xff0c;吸引用户并获取流量。本文将介绍iOS上架的整体流程&#xff0c;并提供一些建议和注意事项。 一、iOS上架的整体流程 1. 申请开发者账号 首先&#xff0c;需要申请苹…

Openharmony - HDF平台驱动之I2C驱动和测试程序

By: fulinux E-mail: fulinux@sina.com Blog: https://blog.csdn.net/fulinus 喜欢的盆友欢迎点赞和订阅! 你的喜欢就是我写作的动力! 目录 概述I2C平台驱动I2C平台驱动HDF框架I2C平台驱动的使用I2C应用开发接口说明代码目录i2ctest.cBUILD.gnbundle.json修改config.json文件…

【mysql】 1819 - Your password does not satisfy the current policy requirements

创建mysql账户密码时候提示&#xff1a; 1819 - Your password does not satisfy the current policy requirements 1819-您的密码不符合当前策略要求 下面是执行的sql DROP DATABASE IF EXISTS company;CREATE DATABASE company CHARACTER SET utf8mb4 ;grant all on com…

Sora是什么意思?Sora人工智能概念股狂涨,一文带你了解Sora的全部!

2024年开年&#xff0c;Open AI就发布了超级AI人工视频工具Sora&#xff0c;并导致大量相关题材概念个股疯狂上涨&#xff0c;当然&#xff0c;也有不少股票出现了暴跌。想要彻底了解Sora&#xff0c;本篇将带您一步步了解Sora的一切&#xff0c;并锁定那些利好市场的AI概念股。…

幻兽帕鲁服务器多少钱?有买过的吗?

幻兽帕鲁服务器多少钱&#xff1f;太卷了&#xff0c;降价到24元1个月&#xff0c;阿里云4核16G10M游戏服务器26元1个月、149元半年&#xff0c;腾讯云4核16G游戏服务器32元、312元一年&#xff0c;华为云26元&#xff0c;京东云主机也是26元起。云服务器吧yunfuwuqiba.com给大…

挑战杯 基于机器视觉的二维码识别检测 - opencv 二维码 识别检测 机器视觉

文章目录 0 简介1 二维码检测2 算法实现流程3 特征提取4 特征分类5 后处理6 代码实现5 最后 0 简介 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于机器学习的二维码识别检测 - opencv 二维码 识别检测 机器视觉 该项目较为新颖&#xff0c;适合作为竞赛课…

代码随想录算法训练营第六十天|84.柱状图中最大的矩形

题目&#xff1a;84.柱状图中最大的矩形 文章链接&#xff1a;代码随想录 视频链接&#xff1a;LeetCode:84.柱状图中最大的矩形 题目链接&#xff1a;力扣题目链接 图释&#xff1a; class Solution { public:int largestRectangleArea(vector<int>& heights) {…

qtcreator-ros 安装记录

文章目录 ros_qtc_pluginros_qt_demo参考链接ros_qtc_plugin ROS Qt Creator 插件是专门为 ROS 开发的,通过简化任务和为 ROS 工具创建集中位置来提高开发人员的效率。由于它建立在Qt Creator平台之上,用户可以访问其所有现有功能,例如:语法高亮,代码索引,编辑器(C++,…

图像的压缩感知的MATLAB实现(第3种方案)

前面介绍了两种不同的压缩感知实现&#xff1a; 图像压缩感知的MATLAB实现&#xff08;OMP&#xff09; 压缩感知的图像仿真&#xff08;MATLAB源代码&#xff09; 上述两种方法还存在着“速度慢、精度低”等不足。 本篇介绍一种新的方法。 压缩感知&#xff08;Compressed S…

Spark集群搭建的三种方式详解

国科大学习生活&#xff08;期末复习资料、课程大作业解析、学习文档等&#xff09;: 文章专栏&#xff08;点击跳转&#xff09; 大数据开发学习文档&#xff08;分布式文件系统的实现&#xff0c;大数据生态圈学习文档等&#xff09;: 文章专栏&#xff08;点击跳转&#xff…

MCU独立按键单控LED实现

##江科大视频学习&#xff0c;并且对具体的一些小细节进行更详细的分析。 什么是独立按键&#xff1f; 轻触按键:相当于是一种电子开关&#xff0c;按下开头接通&#xff0c;松开时开头断开&#xff0c;实现原理是通过轻触按键内部的金属弹片受力弹动来实现接通和断开。 注意…

骨传导蓝牙耳机哪个牌子好?揭秘六大黄金法则与避坑技巧!

随着科技的发展&#xff0c;蓝牙耳机已经成为音乐爱好者的首选&#xff0c;尤其是传统的入耳式和头戴式耳机&#xff0c;它们在音质表现上有着出色的还原度。但这两种耳机在使用场景上存在一定的限制&#xff0c;特别是在运动场景下&#xff0c;它们的便捷性和舒适性有所欠缺。…

【pytorch】常用代码

文章目录 条件与概率torch.tensor()torch.rand()torch.randn()torch.randint()torch.multinominal() 逻辑运算torch.argmax()torch.max()torch.sum()torch.tanh()torch.pow() 功能性操作 torch.nn.functionalF.normalize()F.elu()F.relu()F.softmax() 张量计算torch.zeros()tor…