SpringCloud alibaba微服務之NACOS多環境配置整合

前言

        伴隨着spring cloud alibaba 登上主板之後,我就去了解下感受仍是蠻不錯的。說實話第一次看見Nacos好長一段時間連讀法都不知道...(/nɑ:kəʊs/)。按照官方的話說Nacos是:一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平臺。嗯...就是註冊中心 + 配置中心的組合。
        聽說 Nacos 在阿里巴巴內部有超過 10 萬的實例運行,已通過了相似雙十一等各類大型流量的考驗。因此能夠放心的用。html

        官方中文文檔:https://nacos.io/zh-cn/docs/what-is-nacos.htmljava

        下載地址:https://github.com/alibaba/nacos/releasesgit

啓動註冊中心

        不少人覺得nacos和eureka同樣,須要本身搭建一個項目,再一springboot的方式啓動,然而並非。
        直接從下載的地址中找到nacos-server-*.*.*.zipnacos-server-*.*.*.zip.gzgithub

Linux/Unix/Mac

        啓動命令(standalone表明着單機模式運行,非集羣模式):web

       sh startup.sh -m standalonespring

        若是您使用的是ubuntu系統,或者運行腳本報錯提示[[符號找不到,可嘗試以下運行: bootstrap

       bash startup.sh -m standaloneubuntu

Windows

        啓動命令:springboot

      cmd startup.cmdbash

        或者雙擊startup.cmd運行文件。

訪問:127.0.0.1:8848/nacos/index.html 出現登陸界面,啓動成功。(用戶名和祕密都是nacos)

服務註冊到NACOS

首先Nacos規定必須是bootstrap配置文件才能注入。我項目中用yml,示例以下:

server:
  port: 8060
spring:
  application:
    name: power-match #項目名
  profiles: 
    active: local
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848 #註冊中心地址
      discovery: 
        server-addr: 127.0.0.1:8848

其次啓動類示例以下(我使用了feign): 

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

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

運行後去Nacos頁面查看,效果以下:

表示註冊成功。

分環境註冊

在這我只舉例官方推薦的方法,別的就再也不介紹了。仍是同一個nacos,登陸——找到命名空間——新建命名空間,輸入內容後就會生成命名空間ID

以application-local.yml配置爲例

spring:
  cloud:
    nacos:
      config:
        namespace: e503611c-9c54-4669-baff-e12770b3e948
      discovery:
        namespace: e503611c-9c54-4669-baff-e12770b3e948
ribbon:    
  ReadTimeout: 60000    
  ConnectTimeout: 60000

啓動後,去看服務列表的test下面就有註冊的服務了,只會服務調用就會只在local中調用。

他支持多種服務消費方式WebClient、Feign、RestTemplate。

WebClient

@EnableDiscoveryClient
@SpringBootApplication
public class TestApplication {

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class, args);
    }

    @Slf4j
    @RestController
    static class TestController {

        @Autowired
        private WebClient.Builder webClientBuilder;

        @GetMapping("/test")
        public Mono<String> test() {
            Mono<String> result = webClientBuilder.build()
                    .get()
                    .uri("http://alibaba-nacos-discovery-server/hello?name=didi")
                    .retrieve()
                    .bodyToMono(String.class);
            return result;
        }
    }

    @Bean
    @LoadBalanced
    public WebClient.Builder loadBalancedWebClientBuilder() {
        return WebClient.builder();
    }

}

使用Feign

上面介紹的RestTemplate和WebClient都是Spring本身封裝的工具,下面介紹一個Netflix OSS中的成員,經過它能夠更方便的定義和使用服務消費客戶端。下面也舉一個具體的例子,其實現內容與上面兩種方式結果一致:

第一步:在pom.xml中增長openfeign的依賴:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

第二步:定義Feign客戶端和使用Feign客戶端:

@EnableDiscoveryClient
@SpringBootApplication
@EnableFeignClients
public class TestApplication {

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class, args);
    }

    @Slf4j
    @RestController
    static class TestController {

        @Autowired
        Client client;

        @GetMapping("/test")
        public String test() {
            String result = client.hello("word");
            return "Return : " + result;
        }
    }


    @FeignClient("alibaba-nacos-discovery-server")
    interface Client {

        @GetMapping("/hello")
        String hello(@RequestParam String name);

    }

}

使用RestTemplate

@EnableDiscoveryClient
@SpringBootApplication
public class TestApplication {

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class, args);
    }

    @Slf4j
    @RestController
    static class TestController {

        @Autowired
        RestTemplate restTemplate;

        @GetMapping("/test")
        public String test() {
            String result = restTemplate.getForObject("http://alibaba-nacos-discovery-server/hello?name=word", String.class);
            return result;
        }
    }

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

}

總的來講,還說和之前沒的什麼區別。

相關文章
相關標籤/搜索