1.1. 什么是 Nacos

Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

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

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

1.2. 为什么是Nacos

常见的注册中心:

  1. Eureka(原生,2.0遇到性能瓶颈,停止维护)
  2. Zookeeper(支持,专业的独立产品。例如:dubbo)
  3. Consul(原生,GO语言开发)
  4. Nacos

相对于 Spring Cloud Eureka 来说,Nacos 更强大。

Nacos = Spring Cloud Eureka + Spring Cloud Config

Nacos 可以与 Spring, Spring Boot, Spring Cloud 集成,并能代替 Spring Cloud Eureka, Spring Cloud Config。

  • 通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-config 实现配置的动态变更。

  • 通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-discovery 实现服务的注册与发现。

1.3. Nacos搭建

1.下载及解压缩(这里提供目前最新1.2.1版本)
也可参考https://nacos.io/zh-cn/docs/quick-start.html
github下载地址链接:https://github.com/alibaba/nacos/releases
百度网盘下载地址链接:https://pan.baidu.com/s/1ny8ffoOIBJKJQQqMCmV6Fw
提取码:dj1w
下载完后可使用Xftp移动到linux下如下:
在这里插入图片描述
执行命令: tar -zxvf nacos-server-1.2.1.tar.gz -C /usr/local 将压缩包解压至/usr/local目录

2.启动nacos
cd /usr/local/nacos/bin 移动至安装目录的bin目录下
./startup.sh -m standalone 运行nacos,如下图说明已成功启动
在这里插入图片描述
启动成功后我们访问http://192.168.10.20:8848/nacos 如下所示:
在这里插入图片描述
输入账号nacos 密码nacos 就会进入nacos控制台如下在这里插入图片描述
到这nacos就已经安装好可以使用了

1.3. 服务注册

新建一个springboot项目,然后引入依赖配置如下:

<?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.1.13.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>cn.joral</groupId>
    <artifactId>jmall-user</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>jmall-user</name>
    <description>用户服务</description>

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.SR5</spring-cloud.version>
        <spring-nacos.version>2.1.1.RELEASE</spring-nacos.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>${spring-nacos.version}</version>
        </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>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <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>
            </plugin>
        </plugins>
    </build>

</project>

server:
  port: 8081
spring:
  application:
    name: jmall-service
  cloud:
    nacos:
      discovery:
        server-addr: 192.168.10.20:8848

在这里插入图片描述
到这里已经将服务注册到nacos中

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐