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

Consul下載地址 https://www.consul.io/downloads.html

下載完解壓後是一個consul.exe

查看consul的版本(不用配置環境變量)

consul --version

啓動consul

consul agent -dev

在瀏覽器輸入

http://localhost:8500/

代碼版本

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

代碼下載

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

 

註冊服務提供者(在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();
    }

}

  啓動並且自測

http://localhost:8001/provider/consul

註冊服務消費者(在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;
    }

}

啓動自測

http://localhost/consumer/consul

遇到的坑

如下圖所示,正常情況是綠色對勾是2,這樣訪問會報 No instances available for provider

解決辦法

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章