Nacos

1 什么是Nacos?

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

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

在这里插入图片描述

Nacos 无缝支持一些主流的开源生态,例如

使用 Nacos 简化服务发现、配置管理、服务治理及管理的解决方案,让微服务的发现、管理、共享、组合更加容易。

https://nacos.io/zh-cn/docs/what-is-nacos.html

2 Nacos安装与启动
0.版本选择

您可以在Nacos的release notes博客中找到每个版本支持的功能的介绍,当前推荐的稳定版本为1.4.1。

1.预备环境准备

Nacos 依赖 Java 环境来运行。如果您是从代码开始构建并运行Nacos,还需要为此配置 Maven环境,请确保是在以下版本环境中安装使用:

  1. 64 bit OS,支持 Linux/Unix/Mac/Windows,推荐选用 Linux/Unix/Mac。
  2. 64 bit JDK 1.8+;下载 & 配置
  3. Maven 3.2.x+;下载 & 配置
2.下载源码或者安装包

你可以通过源码和发行包两种方式来获取 Nacos。

从 Github 上下载源码方式
git clone https://github.com/alibaba/nacos.git
cd nacos/
mvn -Prelease-nacos -Dmaven.test.skip=true clean install -U  
ls -al distribution/target/

// change the $version to your actual path
cd distribution/target/nacos-server-$version/nacos/bin
下载编译后压缩包方式

您可以从 最新稳定版本 下载 nacos-server-$version.zip 包。

  unzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gz
  cd nacos/bin
3.启动服务器
Linux/Unix/Mac

启动命令(standalone代表着单机模式运行,非集群模式):

sh startup.sh -m standalone

如果您使用的是ubuntu系统,或者运行脚本报错提示[[符号找不到,可尝试如下运行:

bash startup.sh -m standalone
Windows

启动命令(standalone代表着单机模式运行,非集群模式):

cmd startup.cmd -m standalone
4.服务注册&发现和配置管理
服务注册
curl -X POST 'http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=nacos.naming.serviceName&ip=20.18.7.10&port=8080'
服务发现
curl -X GET 'http://127.0.0.1:8848/nacos/v1/ns/instance/list?serviceName=nacos.naming.serviceName'
发布配置
curl -X POST "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test&content=HelloWorld"
获取配置
curl -X GET "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test"
3 服务发现与注册

https://github.com/alibaba/spring-cloud-alibaba/wiki/Nacos-discovery

4 Nacos集群搭建
docker 集群

拉去镜像 docker pull nacos/nacos-server

启动三个节点

docker run --name nacos1 --net=host --env MODE=cluster --env NACOS_SERVERS=“10.0.2.15:8848 10.0.2.15:8849 10.0.2.15:8850” --env SPRING_DATASOURCE_PLATFORM=mysql --env MYSQL_DATABASE_NUM=1 --env MYSQL_SERVICE_HOST=119.3.200.75 --env MYSQL_SERVICE_PORT=3306 --env MYSQL_SERVICE_DB_NAME=naocs --env MYSQL_SERVICE_USER=root --env MYSQL_SERVICE_PASSWORD=jingyi@2020 --env NACOS_APPLICATION_PORT=8848 -d -p 8748:8848 --env JVM_XMS=256M --env JVM_XMX=256M --env JVM_XMN=128M --env JVM_MMS=128M nacos/nacos-server

docker run --name nacos2 --net=host --env MODE=cluster --env NACOS_SERVERS=“10.0.2.15:8848 10.0.2.15:8849 10.0.2.15:8850” --env SPRING_DATASOURCE_PLATFORM=mysql --env MYSQL_DATABASE_NUM=1 --env MYSQL_SERVICE_HOST=119.3.200.75 --env MYSQL_SERVICE_PORT=3306 --env MYSQL_SERVICE_DB_NAME=naocs --env MYSQL_SERVICE_USER=root --env MYSQL_SERVICE_PASSWORD=jingyi@2020 --env NACOS_APPLICATION_PORT=8849 -d -p 8749:8849 --env JVM_XMS=256M --env JVM_XMX=256M --env JVM_XMN=128M --env JVM_MMS=128M nacos/nacos-server

docker run --name nacos3 --net=host --env MODE=cluster --env NACOS_SERVERS=“10.0.2.15:8848 10.0.2.15:8849 10.0.2.15:8850” --env SPRING_DATASOURCE_PLATFORM=mysql --env MYSQL_DATABASE_NUM=1 --env MYSQL_SERVICE_HOST=119.3.200.75 --env MYSQL_SERVICE_PORT=3306 --env MYSQL_SERVICE_DB_NAME=naocs --env MYSQL_SERVICE_USER=root --env MYSQL_SERVICE_PASSWORD=jingyi@2020 --env NACOS_APPLICATION_PORT=8850 -d -p 8750:8850 --env JVM_XMS=256M --env JVM_XMX=256M --env JVM_XMN=128M --env JVM_MMS=128M nacos/nacos-server

集群搭建成功
在这里插入图片描述
服务注册集群成功
在这里插入图片描述

启动单机配置中心服务

docker run --name nacos-config-server --net=host --env MODE=standalone --env SPRING_DATASOURCE_PLATFORM=mysql --env MYSQL_DATABASE_NUM=1 --env MYSQL_SERVICE_HOST=119.3.200.75 --env MYSQL_SERVICE_PORT=3306 --env MYSQL_SERVICE_DB_NAME=naocs --env MYSQL_SERVICE_USER=root --env MYSQL_SERVICE_PASSWORD=jingyi@2020 --env NACOS_APPLICATION_PORT=8851 -d -p 8751:8851 --env JVM_XMS=256M --env JVM_XMX=256M --env JVM_XMN=128M --env JVM_MMS=128M nacos/nacos-server

5 服务健康检测
6 动态配置服务

controller

@RestController
@RequestMapping("/config")
public class ConfigController {

    @NacosValue(value = "${useLocalCache:false}", autoRefreshed = true) //autoRefreshed 自动更新
    private boolean useLocalCache;

    /**
     * http://localhost:8080/config/get
     */
    @RequestMapping("/get")
    public boolean get() {
        return useLocalCache;
    }
}

启动类

@SpringBootApplication
@NacosPropertySource(dataId = "example", autoRefreshed = true)
public class NacosConfigApplication {

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

}

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.4.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.cuixk.microservice.config</groupId>
    <artifactId>nacos-config</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>nacos-config</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
        <nacos-config-spring-boot.version>0.2.1</nacos-config-spring-boot.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>nacos-config-spring-boot-starter</artifactId>
            <version>${nacos-config-spring-boot.version}</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>nacos-config-spring-boot-actuator</artifactId>
            <version>${nacos-config-spring-boot.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

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

配置文件

nacos:
  config:
    server-addr: 192.168.99.100:8851

测试

1.调用/config/get 返回 false

2.通过调用 Nacos Open API 向 Nacos server 发布配置:dataId 为example,内容为useLocalCache=true

curl -X POST "http://ip:port/nacos/v1/cs/configs?dataId=example&group=DEFAULT_GROUP&content=useLocalCache=true"

3.再访问接口,返回true,则测试成功。

7 参考链接

https://nacos.io/zh-cn/docs/what-is-nacos.html 官网

https://blog.csdn.net/qq_32352777/article/details/86560333 Nacos集群

https://www.cnblogs.com/FlyAway2013/p/11201250.html Nacos集群

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐