微服务与中间件系列——Nacos快速使用

微服务与中间件系列——Nacos快速使用

  • 前言
  • Nacos
    • 官方地址
    • 下载安装
    • 单点启动
    • Nacos依赖了解
    • 关于`@EnableDiscoveryClient`注解
    • QuickStart With SpringCloud
      • 1.构建如下图目录项目
      • 2.在父工程中引入管理依赖
      • 3.父工程引入nacos-discovery
      • 完整pom文件(父工程)
      • 4.修改子工程yaml文件
        • service
        • client
      • 5.在启动类上加上`@EnableDiscoveryClient`注解
      • 6.启动服务查看nacos

前言

本文单纯只是教大家如何快速在微服务的项目中构建Nacos,有关于深入学习的内容将在后续SpringCluod系列的Nacos中进行介绍,或大家可以参照Nacos的官网学习!

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。

Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

微服务与中间件系列——Nacos快速使用_第1张图片

官方地址

https://nacos.io/zh-cn/docs/quick-start.html

下载安装

https://github.com/alibaba/nacos/releases/tag/2.1.1
微服务与中间件系列——Nacos快速使用_第2张图片

单点启动

进入目录cmd执行:

.\startup.cmd -m standalone

结果如图:
微服务与中间件系列——Nacos快速使用_第3张图片
默认账号:nacos
默认密码:nacos
登录后如图:
微服务与中间件系列——Nacos快速使用_第4张图片

Nacos依赖了解

  • 通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-config 实现配置的动态变更。
  • 通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-discovery 实现服务的注册与发现。

关于@EnableDiscoveryClient注解

表示我们开启服务发现,官网上推荐大家在启动类上加上这个注解
当然你不加上也是可以正常使用的,但是官方都加了最好我们也加上

QuickStart With SpringCloud

1.构建如下图目录项目

若对构建微服务多模块项目任然不熟悉请参照:微服务构建多模块项目
微服务与中间件系列——Nacos快速使用_第5张图片

2.在父工程中引入管理依赖

<properties>
        <java.version>11</java.version>
        <spring-cloud.version>2021.0.3</spring-cloud.version>
</properties>
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2021.0.1.0</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

3.父工程引入nacos-discovery

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

完整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.7.3</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>Demo project for Spring Boot</description>
    <packaging>pom</packaging>
    <modules>
        <module>client</module>
        <module>service</module>
    </modules>
    <properties>
        <java.version>11</java.version>
        <spring-cloud.version>2021.0.3</spring-cloud.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-loadbalancer</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2021.0.1.0</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

4.修改子工程yaml文件

service

server:
  port: 10086
spring:
  application:
    name: testService
  cloud:
    nacos:
      server-addr: localhost:8848

client

server:
  port: 8080
spring:
  application:
    name: client
  cloud:
    nacos:
      server-addr: localhost:8848

5.在启动类上加上@EnableDiscoveryClient注解

6.启动服务查看nacos

如下两个服务注册成功
微服务与中间件系列——Nacos快速使用_第6张图片

你可能感兴趣的:(笔记,微服务与中间件,#,SpringCloud,微服务,中间件,java)