Nacos简介
背景:当在微服务项目中不同模块之间需要实现服务调用时,如何实现服务注册与发现?
1、Nacos概述
1.1 什么是Nacos
Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施
Nacos 支持如下核心特性:
1)服务发现: 支持 DNS 与 RPC 服务发现,也提供原生 SDK 、OpenAPI 等多种服务注册方式和 DNS、HTTP 与 API 等多种服务发现方式。
2)服务健康监测: Nacos 提供对服务的实时的健康检查,阻止向不健康的主机或服务实例发送请求。
3)动态配置服务: Nacos 提供配置统一管理功能,能够帮助我们将配置以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置。
4)动态 DNS 服务: Nacos 支持动态 DNS 服务权重路由,能够让我们很容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单 DNS 解析服务。
5)服务及其元数据管理: Nacos 支持从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述、生命周期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略、服务的 SLA 以及最首要的 metrics 统计数据。
1.2 常见的注册中心
- Eureka(原生,2.0遇到瓶颈,停止维护)
- Zookeeper(支持,专业的独立产品。例如:dubbo)
- Consul(原生,GO语言开发)
- 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 实现服务的注册与发现。
注:nacos与eureka的区别(简单介绍)
1)nacos和eureka的范围不同,Nacos的阈值是针对某个具体Service的,而不是针对所有服务的;但Eureka的自我保护阈值是针对所有服务的。nacos支持CP和AP两种;eureka只支持AP。nacos使用netty,是长连接; eureka是短连接,定时发送。
2)Eureka保护方式:当在短时间内,统计续约失败的比例,如果达到一定阈值,则会触发自我保护的机制,在该机制下,Eureka Server不会剔除任何的微服务,等到正常后,再退出自我保护机制。自我保护开关(eureka.server. enab1e-self-preservation:false)
Nacos保护方式:当域名健康实例(Instance)占总服务实例(Instance)的比例小于阈值时,无论实例(Instance)是否健康,都会将这个实例(Instance)返回给客户端。这样做虽然损失了一部分流量,但是保证了集群的剩余健康实例(Instance)能正常工作。
1.3 Nacos结构图
1.4 Nacos下载和安装
1)软件环境
Nacos 版本:2.0.4
mysql版本:5.7
2)安转步骤
此处使用docker安转nacos
**注:**注意启动时需要配置这个环境配置 -e MODE=standalone 否则默认启动为占用内存为1G
1、先拉取镜像
命令:docker pull nacos/nacos-server:v2.0.4
2、运行容器
命令: docker run --name nacos(容器名称) -d -p 8848(外部访问端口):8848(容器内端口) --privileged=true --restart=always -e JVM_XMS=256m -e JVM_XMX=256m -e MODE=standalone -e PREFER_HOST_MODE=hostname -v /home/nacos/logs(数据卷主机地址):/home/nacos/logs(数据卷容器内部地址) -v /home/nacos/conf:/home/nacos/conf ea54f31c46e4(容器id)
3)查看容器是否启动
命令:docker ps
4)查看容器相关日志
命令:docker logs --since 10m nacos的容器id #查看指定容器的输出日志
5)进行访问
本机IP地址:8848/nacos
注:记得开放对应端口
登录账号 登录密码
nacos nacos
2、注册服务
1.1整合nacos
引入依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
在对应模块的配置文件中添加nacos配置
#服务名(该服务名,会在nacos上显示)
spring.application.name=服务名称
# nacos服务地址
spring.cloud.nacos.discovery.server-addr=ip:端口
在启动类上添加注解
2.2重启服务,查看
重新启动服务,登录nacos页面查看(下图发现服务成功注册上nacos中)
3、整合外部的mysql(单节点)
3.1建库建表
可以会直接根据里面的内容创建
https://github.com/my-dlq/blog-example/blob/master/kubernetes/nacos-deploy/nacos.sql
3.2修改数据卷挂载出来的nacos配置
进入数据卷保存路面
此处我们nacos配置保存在宿主机的/home/nacos/conf中
修改下面内容即可
重启 Nacos 即可,验证。
再次创建相关信息、重启服务之后依然存在。