Spring Cloud 整合Nacos学习笔记及集群搭建
Nacos1 什么是Nacos?Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。Nacos 无缝支持一些主流的开源生态,例如Spring C
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环境,请确保是在以下版本环境中安装使用:
- 64 bit OS,支持 Linux/Unix/Mac/Windows,推荐选用 Linux/Unix/Mac。
- 64 bit JDK 1.8+;下载 & 配置。
- 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集群
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)