Nacos筆記01——使用Nacos作為SpringCloud項目的服務注冊中心


前言

剛學SpringCloud時使用eureka作為服務注冊中心,隨着網飛公司eureka2.x不再更新,以及最近在公司實習接觸到的SpringCloud項目是使用Nacos來做服務注冊中心的,所以決定學習一波,並記錄一下。

Nacos是什么

Nacos是阿里巴巴的一個開源的SpringCloud項目的服務注冊中心主鍵,但是Nacos又不僅僅是注冊中心,同時可以做配置中心,將項目的配置文件版本化管理,Nacos可以無縫接入各大生態。很強大,馬上來體驗一下。

環境

  • Nacos-server:1.0.1
  • SpringCloud:Finchley.RELEASE
  • SpringBoot:2.0.6.RELEASE
  • spring-cloud-alibaba-dependencies:0.2.2.RELEASE

要注意spring-cloud-alibaba、SpringBoot、SpringCloud、Nacos-server四者之間版本的關系,避免出現版本沖突。可以參考下表:

SpringBoot SpringCloud spring-cloud-alibaba Nacos-server
2.1.x Greenwich 0.9.x 1.1.4
2.0.x Finchley 0.2.x 1.0.0
1.5.x Edgware、Dalston 0.1.x 1.0.0及以下

具體可參考:

https://blog.csdn.net/sq4521/article/details/90417562

https://github.com/alibaba/spring-cloud-alibaba/wiki/版本說明

https://www.cnblogs.com/didispace/p/10464188.html

啟動Nacos-server

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

下載解壓之后進入bin文件夾雙擊startup.cmd啟動。啟動成功后在http://127.0.0.1:8848/nacos/index.html 訪問控制台,默認賬號密碼是nacos/nacos。

nacos控制台.png

創建工程

父工程

先創建nacos-modules作為父工程,主要做版本管理。pom依賴如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <packaging>pom</packaging>
    <groupId>com.my</groupId>
    <artifactId>nacos-modules</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>nacos-modules</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
        <spring.cloud.version>Finchley.RELEASE</spring.cloud.version>
        <spring.cloud.alibaba.version>0.2.2.RELEASE</spring.cloud.alibaba.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring.cloud.version}</version>
                <!--相當於parent標簽-->
                <!--下面兩行相當於引入這個pom文件,里面的dependencyManagement定義了很多依賴,我們可以選擇性的繼承。解決單繼承問題-->
                <!--因為里面的parent是cloud-parent,子工程就可以直接用cloud的東西了-->
                <!--如果是引進來的pom有dependencies里面的會直接繼承給子工程-->
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring.cloud.alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring.boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
</project>

服務提供者

再創建一個maven工程nacos-provider,在nacos-modles把nacos-provider引進來,操作如下:

引進子工程.jpg

nacos-provider的pom依賴如下:

	<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.my</groupId>
        <artifactId>nacos-modules</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <artifactId>nacos-provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>nacos-provider</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <!--在父工程spring-cloud-alibaba-dependencies的management中有聲明,所以不用版本號-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
<!--                需要打包成jar的模塊才需要這個插件-->
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

在啟動類加@EnableDiscoveryClient啟動服務注冊發現功能。

@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication {

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

創建配置文件application.yml

server:
  port: 8000
spring:
  application:
    name: nacos-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

創建一個controller提供服務

@RestController
@RequestMapping("/test")
public class testController {

    @GetMapping("/hello")
    public String sayHello() {
        return "雷猴啊";
    }
}

服務消費者

再創建一個服務消費者,步驟與創建服務提供者一樣。

pom如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.my</groupId>
        <artifactId>nacos-modules</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <artifactId>nacos-consumer</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>nacos-consumer</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

配置文件:

server:
  port: 8010
spring:
  application:
    name: nacos-consumer
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

RestTemplate+Ribbon服務調用

@RestController
@RequestMapping("/test")
public class controller {

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

    @GetMapping("/hello")
    public String sayHello() {
        return restTemplate.getForObject("http://nacos-provider/test/hello", String.class);
    }
}

feign方式服務調用

在實際開發,服務調用用的更多的還是Feign,Feign內部集成了Ribbon和Hystrix,使用起來更加方便好用。

  1. 在nacos-consumer添加依賴:
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>
  1. 添加配置開啟Hystrix

    feign:
      hystrix:
        enabled: true
    
  2. 啟動類加@EnableFeignClients注解,開啟Feign。

  3. 創建Feign接口

    name為調用的服務名,path是url前綴,fallback是熔斷調用的類

@FeignClient(name = "nacos-provider",path = "/test",fallback = MyHystrix.class)
public interface TestFeignClient {
    @GetMapping("/hello")
    String sayHello();
}
  1. 創建Hystrix熔斷和降級處理的類
@Component
public class MyHystrix implements TestFeignClient {
    @Override
    public String sayHello() {
        return "服務超時";
    }
}

  1. controller
@RestController
@RequestMapping("/feign/test")
public class FeignController {
    @Autowired
    TestFeignClient testFeignClient;

    @GetMapping("/hello")
    public String sayHello() {
        return testFeignClient.sayHello();
    }
}

啟動項目

啟動nacos-provider和nacos-consumer,成功的話可以在nacos控制台看到:

服務列表.png

測試

http://localhost:8010/feign/test/hello

http://localhost:8010/test/hello

測試.png

模擬異常,降級處理

  1. 修改服務提供者

    @RestController
    @RequestMapping("/test")
    public class testController {
    
        @GetMapping("/hello")
        public String sayHello() {
            int i=1/0;
            return "雷猴啊";
        }
    }
    
  2. 結果

熔斷.png

總結

這次是使用Nacos作為注冊中心,我們上面說到,Nacos不僅僅可以做注冊中心,還能做配置中心,我們下一次就來試一下用Nacos做配置中心。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM