组内最近需要搭建一个微服务治理及动态配置管理平台,在调研了一些诸如Eureka、Consul等开源框架后,无意识中找到了阿里近年发布的一款比较靠谱的产品:Nacos。 进入到其官方文档和GitHub中看了一下,较为丰富的API以及较高的社区活跃度让我决定用它来试一试。
Nacos 致力于发现、配置和管理微服务。它提供了一组简单易用的特性集,帮助快速实现动态服务发现、服务配置、服务元数据及流量管理。使用Nacos 可以更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。
服务(Service)是 Nacos 世界的一等公民。Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理:
Kubernetes Service.
gRPC & Dubbo RPC Service.
Spring Cloud RESTful Service.
Nacos 的关键特性包括:
命名空间(Namespace)
配置(Configuration)
配置管理(Configuration Management)
配置ID和配置分组(Data ID & Group)
服务名(Service)
服务注册中心(Service Registry)
服务发现(Service Discovery)
服务分组(Service Group)
虚拟集群(Virtual Cluster)
实例(Instance)
权重(Weight)
健康检查(Health Check)
健康保护阈值(Protect Threshold)
通过源码或者发行包获取。
git clone https://github.com/alibaba/nacos.git
cd nacos/
mvn -Prelease-nacos clean install -U
ls -al distribution/target/
// change the $version to your actual path
cd distribution/target/nacos-server-$version/nacos/bin
unzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gz
cd nacos/bin
0.7版本之后,Nacos支持MySQL数据存储
安装步骤如下:
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=user_name
db.password=pwd
#ip:port
200.8.9.16:8848
200.8.9.17:8848
200.8.9.18:8848
upstream nacosserver {
server 10.152.73.201:8848;
server 10.152.90.146:8848;
server 10.153.13.216:8848;
}
server {
listen 8080;
server_name localhost;
location / {
proxy_pass http://nacosserver/;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
sh startup.sh -m standalone
sh startup.sh
sh shutdown.sh
http://10.142.73.201:8080/nacos/index.html
默认用户名:nacos
默认密码:nacos
修改nacos密码:
目前nacos暂不提供用户管理页面,需要手动对Nacos的user表进行密码修改
利用Nacos源码中PasswordEncoderUtil类生成密码,修改数据库即可
package com.alibaba.nacos.console.utils;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
/**
* Password encoder tool
*
* @author nacos
*/
public class PasswordEncoderUtil {
public static void main(String[] args) {
System.out.println(new BCryptPasswordEncoder().encode("nacos"));
}
}
这里仅列举项目中用到的一些API,更丰富的API详情可参考官方文档
请求类型
GET
请求URL
/nacos/v1/cs/configs?search=accurate
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
appName | string | 应用名称 |
PageNo | int | 页码 |
pageSize | int | 页数量 |
请求类型
GET
请求URL
/nacos/v1/cs/configs?show=all
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
请求类型
GET
请求URL
/nacos/v1/cs/history?search=accurate
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
pageNo | int | 页码 |
pageSize | int | 页数量 |
请求类型
GET
请求URL
/nacos/v1/cs/history
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
nid | int | 配置主键 |
请求类型
DELETE
请求URL
/nacos/v1/cs/configs
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
请求类型
POST
请求URL
/nacos/v1/cs/configs
请求参数
名称 | 类型 | 描述 |
---|---|---|
dataId | string | 配置ID |
group | string | 配置分组 |
content | string | 配置内容 |
desc | string | 配置描述 |
type | string | 配置类型 |
请求类型
GET
请求URL
/nacos/v1/ns/catalog/serviceList
请求参数
名称 | 类型 | 描述 |
---|---|---|
pageNo | int | 页码 |
pageSize | int | 页数量 |
keyword | string | 服务名称 |
请求类型
DELETE
请求URL
/nacos/v1/ns/service
请求参数
名称 | 类型 | 描述 |
---|---|---|
serviceName | string | 服务名称 |
请求类型
GET
请求URL
/nacos/v1/ns/
请求参数
名称 | 类型 | 描述 |
---|---|---|
serviceName | string | 服务名称 |
请求类型
GET
请求URL
/nacos/v1/ns/instance/list
请求参数
名称 | 类型 | 描述 |
---|---|---|
serviceName | string | 服务名称 |
请求类型
PUT
请求URL
/nacos/v1/ns/instance
请求参数
名称 | 类型 | 描述 |
---|---|---|
serviceName | string | 服务名称 |
ip | string | IP地址 |
port | int | 端口号 |
clusterName | string | 集群名称 |
weight | double | 权重 |
enable | bool | 是否上线 |
官网Demo:nacos-spring-cloud-config-example
<dependency>
<groupId>org.springframework.cloudgroupId>
<artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
<version>${latest.version}version>
dependency>
bootstrap.yml
中配置Nacos服务地址和应用名称spring:
cloud:
nacos:
config:
file-extension: yaml
server-addr:
10.142.73.201:8080
application:
name: nacos-manager
profiles:
active: online
说明:之所以需要配置 spring.application.name ,是因为它是构成 Nacos 配置管理 dataId字段的一部分。
在 Nacos Spring Cloud 中,dataId 的完整格式如下:
${prefix}-${spring.profile.active}.${file-extension}
1. prefix默认为spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
2. spring.profile.active即为当前环境对应的 profile,详情可以参考 Spring Boot文档。注意:当 spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}。
3. file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持properties和yaml类型。
@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {
@Value("${useLocalCache:false}")
private boolean useLocalCache;
@RequestMapping("/get")
public boolean get() {
return useLocalCache;
}
}
官网Demo:nacos-spring-cloud-discovery-example
<dependency>
<groupId>org.springframework.cloudgroupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
<version>${latest.version}version>
dependency>
bootstrap.yml
中配置Nacos服务地址和应用名称spring:
cloud:
nacos:
discovery:
server-addr: 10.142.73.201:8080
cluster-name: nacos-provider
application:
name: nacos-provider
ii. 通过 Spring Cloud 原生注解 @EnableDiscoveryClient 开启服务注册发现功能:
@SpringBootApplication
@EnableDiscoveryClient
public class NacosProviderApplication {
public static void main(String[] args) {
SpringApplication.run(NacosProviderApplication.class, args);
}
@RestController
class EchoController {
@RequestMapping(value = "/echo/{string}", method = RequestMethod.GET)
public String echo(@PathVariable String string) {
return "Hello Nacos Discovery " + string;
}
}
}
bootstrap.yml
中配置Nacos服务地址和应用名称spring:
cloud:
nacos:
discovery:
server-addr: 10.142.73.201:8080
cluster-name: nacos-consumer
application:
name: nacos-consumer
ii. 通过 Spring Cloud 原生注解 @EnableDiscoveryClient 开启服务注册发现功能。
@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(NacosConsumerApplication.class, args);
}
@RestController
public class TestController {
private final RestTemplate restTemplate;
@Autowired
public TestController(RestTemplate restTemplate) {this.restTemplate = restTemplate;}
@RequestMapping(value = "/echo/{str}", method = RequestMethod.GET)
public String echo(@PathVariable String str) {
return restTemplate.getForObject("http://nacos-provider/echo/" + str, String.class);
}
}
}
nacos-sdk-nodejs
nacos-sdk-python
https://github.com/spring-cloud/spring-cloud-config ,Star数1178,官方组件,社区较活跃
Pivotal(Spring官方团队)
N多,目前用Spring Cloud的大多团队都是用的Spring Cloud Config
https://github.com/ctripcorp/apollo ,Star数11169,社区很活跃
携程
携程、网易蜂巢、中国平安等,更多公司详见https://github.com/ctripcorp/apollo
暂未发现
https://github.com/alibaba/nacos ,Star数3820,社区非常活跃
阿里巴巴
阿里巴巴、虎牙直播、工商银行软件开发中心、爱奇艺等,更多公司详见https://github.com/alibaba/nacos/issues/273
暂未发现
https://github.com/knightliao/disconf ,Start数4505,社区活跃度一般
原百度员工,现在蚂蚁金服
百度、滴滴出行、顺丰、网易等,更多公司详见https://github.com/knightliao/disconf
最新的版本发布于两年前,有点久了。
https://github.com/spring-cloud/spring-cloud-consul ,Star数493,官方组件,社区较活跃
Pivotal(Spring官方团队)
暂未发现
https://github.com/spring-cloud/spring-cloud-zookeeper ,Star数330,官方组件,社区较活跃
Pivotal(Spring官方团队)
暂未发现
以上配置服务在调研过程中会存在先入为主的个人因素,但排除有明显缺点的项目之后,Nacos显然没有拒绝的理由。
https://nacos.io/zh-cn/docs/what-is-nacos.html