前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Consul服务注册中心

Consul服务注册中心

作者头像
CBeann
发布2023-12-25 17:43:25
1250
发布2023-12-25 17:43:25
举报
文章被收录于专栏:CBeann的博客CBeann的博客

cloud注册中心

SpringCloud的服务注册中心有Eureka、Zookeeper、Consul和Nacos

Eureka(AP)在SpringBoot1.x中比较合适,但是现在是SpringBoot2.x,而且Eureka已经停止更新了,就是不建议在使用了

Zookeeper(CP)是dubbo的注册中心,曾经的Eureka都凉了,万一我用别的注册中心又凉了怎么办,不如用zookeeper

Consul(CP)是Go语言开发的,而Java开发者可能会对不同的语言有偏见。

Nacos是比较推荐的服务注册中心。

Consul的(window)安装

Consul下载地址 Downloads | Consul by HashiCorp

下载完解压后是一个consul.exe

查看consul的版本(不用配置环境变量)

代码语言:javascript
复制
consul --version

启动consul

代码语言:javascript
复制
consul agent -dev

在浏览器输入

代码语言:javascript
复制
http://localhost:8500/

代码版本

代码语言:javascript
复制
 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
代码语言:javascript
复制
 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>

代码下载

https://github.com/cbeann/share/tree/master/springcloud-Consul-demo

注册服务提供者(在SpringBoot web基础上)

添加依赖

代码语言:javascript
复制
 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

修改application.yml文件

代码语言:javascript
复制
server:
  port: 8001

# 服务别名--consul注册中心名称
spring:
  application:
    name: provider-8001
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        service-name: ${spring.application.name}

修改主启动类

代码语言:javascript
复制
@EnableDiscoveryClient

编写controller

代码语言:javascript
复制
@RestController
public class HelloController {

    @Value("${server.port}")
    private String serverPort;


    @RequestMapping("/provider/consul")
    public String paymentConsul() {
        return "springCloud with consul: " + serverPort + "\t" + UUID.randomUUID().toString();
    }

}

启动并且自测

http://localhost:8001/provider/consul

注册服务消费者(在SpringBoot web基础上)

添加依赖

代码语言:javascript
复制
 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

修改application.yml文件

代码语言:javascript
复制
server:
  port: 80

# 服务别名---consul注册中心名称
spring:
  application:
    name: consumer-80
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        service-name: ${spring.application.name}

修改主启动类

代码语言:javascript
复制
@EnableDiscoveryClient

添加RestTemplate配置类

代码语言:javascript
复制
@Configuration
public class ApplicationContextConfig {

    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}

编写controller

代码语言:javascript
复制
@RestController
public class HelloController {
    //调用服务的名称provider-8001
    private static final String INVOKE_URL = "http://provider-8001";
    @Autowired
    private RestTemplate restTemplate;

    @GetMapping(value = "/consumer/consul")
    public String paymentInfo(){
        String result = restTemplate.getForObject(INVOKE_URL + "/provider/consul", String.class);
        return result;
    }

}

启动自测

http://localhost/consumer/consul

遇到的坑

如下图所示,正常情况是绿色对勾是2,这样访问会报 No instances available for provider

解决办法

代码语言:javascript
复制
 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-03-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • cloud注册中心
  • Consul的(window)安装
  • 代码版本
  • 注册服务提供者(在SpringBoot web基础上)
  • 注册服务消费者(在SpringBoot web基础上)
  • 遇到的坑
相关产品与服务
微服务引擎 TSE
微服务引擎(Tencent Cloud Service Engine)提供开箱即用的云上全场景微服务解决方案。支持开源增强的云原生注册配置中心(Zookeeper、Nacos 和 Apollo),北极星网格(腾讯自研并开源的 PolarisMesh)、云原生 API 网关(Kong)以及微服务应用托管的弹性微服务平台。微服务引擎完全兼容开源版本的使用方式,在功能、可用性和可运维性等多个方面进行增强。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档