Consul服务注册中心

简介: Consul服务注册中心

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)安装


1.png


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


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


consul --version


2.png


启动consul


consul agent -dev


3.png


在浏览器输入


http://localhost:8500/


4.png


代码版本


 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>


 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>


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


添加依赖


 <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文件


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


修改主启动类


@EnableDiscoveryClient


编写controller


@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();
    }
}


启动并且自测


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


添加依赖


 <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文件


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


修改主启动类


@EnableDiscoveryClient


添加RestTemplate配置类


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


编写controller


@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;
    }
}


启动自测


遇到的坑


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


5.png


解决办法


 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
目录
相关文章
|
8月前
|
存储 安全 Go
Golang 语言微服务的服务注册与发现组件 Consul
Golang 语言微服务的服务注册与发现组件 Consul
63 0
|
19天前
|
存储 网络协议 数据中心
服务注册中心Consul
服务注册中心Consul
35 1
|
19天前
Consul安装教程和注册
Consul安装教程和注册
19 0
|
19天前
|
微服务
三个微服务注册中心eureka、consul、zookeeper之间的异同点以及CAP理论图
三个微服务注册中心eureka、consul、zookeeper之间的异同点以及CAP理论图
281 0
|
9月前
|
应用服务中间件 Shell nginx
Docker consul的容器服务注册与发现-2
Docker consul的容器服务注册与发现
67 0
|
9月前
|
前端开发 应用服务中间件 nginx
Docker consul的容器服务注册与发现-1
Docker consul的容器服务注册与发现
85 0
|
11月前
|
XML 监控 网络协议
手把手教你搭建SpringCloud项目(七)集成Consul服务注册中心
手把手教你搭建SpringCloud项目(七)集成Consul服务注册中心
231 0
|
12月前
|
监控
Springcloud整合consul作为注册中心需要注意的问题(No instances available for)
使用consul跟使用zookeeper的整合过程没有太大的区别,就是有一点需要注意, pom文件必须引入一个健康度监控的包,不然报错No instances available for
|
存储 Cloud Native 安全
【云原生】springcloud07—Consul的服务注册与发现
【云原生】springcloud07—Consul的服务注册与发现