Nacos: Dynamic Naming and Configuration Service 就是:

一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。、

下面是生态图:

Nacos = Eureka+Config +Bus 即 Nacos就是注册中心 + 配置中心的组合

他能干什么呢?

1、替代Eureka做服务注册中心

2、替代Config做服务配置中心

Nacos 下载安装:

1、先从官网下载Nacos   https://github.com/alibaba/nacos/releases

2、解压安装包,直接运行bin目录下的startup.cmd

3、命令运行成功后直接访问http://localhost:8848/nacos(默认账号密码:nacos)

Nacos替代Eureka做服务注册中心的使用:

1、父pom里添加:

 <dependencyManagement><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.1.0.RELEASE</version><type>pom</type><scope>import</scope></dependency>
</dependencyManagement>

2、子pom里添加:

<dependencies><!--SpringCloud ailibaba nacos --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency></dependencies>

3、Appilication.yml 文件

server:port: 9001spring:application:name: nacos-payment-providercloud:nacos:discovery:server-addr: localhost:8848 #配置Nacos地址management:endpoints:web:exposure:include: '*'

4、主启动类: @EnableDiscoveryClient

package com.atgugu.cloudalibaba;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;@EnableDiscoveryClient
@SpringBootApplication
public class PaymentMain9001
{public static void main(String[] args) {SpringApplication.run(PaymentMain9001.class, args);}
}

5、添加业务代码 .......

package com.atguigu.springcloud.alibaba.controller;import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;import javax.annotation.Resource;/*** @auther zzyy* @create 2020-02-23 15:01*/
@RestController
@Slf4j
public class OrderNacosController
{//这里使用@Resource是为了使用别的微服务模块里的方法@Resourceprivate RestTemplate restTemplate;//这里使用@Value("${service-url.nacos-user-service}")是为了使用yml文件里定义好的配置@Value("${service-url.nacos-user-service}")private String serverURL;@GetMapping(value = "/consumer/payment/nacos/{id}")public String paymentInfo(@PathVariable("id") Long id){return restTemplate.getForObject(serverURL+"/payment/nacos/"+id,String.class);}}

Nacos支持AP和CP模式之间的切换:

C是所有节点在同一时间看到的数据是一致的;而A的定义是所有的请求都会收到响应。

何时选择使用何种模式?
一般来说,
如果不需要存储服务级别的信息且服务实例是通过nacos-client注册,并能够保持心跳上报,那么就可以选择AP模式。当前主流的服务如 Spring cloud 和 Dubbo 服务,都适用于AP模式,AP模式为了服务的可能性而减弱了一致性,因此AP模式下只支持注册临时实例。
 
如果需要在服务级别编辑或者存储配置信息,那么 CP 是必须,K8S服务和DNS服务则适用于CP模式。
CP模式下则支持注册持久化实例,此时则是以 Raft 协议为集群运行模式,该模式下注册实例之前必须先注册服务,如果服务不存在,则会返回错误。
 
curl -X PUT '$NACOS_SERVER:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP'

Nacos替代Config做服务配置中心的使用:

1、父pom里添加:

 <dependencyManagement><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.1.0.RELEASE</version><type>pom</type><scope>import</scope></dependency>
</dependencyManagement>

2、子pom里添加:

 <!--nacos-config--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>

3、application.yml 和 bootstrap.yml

application.yml : 


spring:profiles:active: dev # 表示开发环境
# 测试环境:test   生产环境:prod

bootstrap.yml :

# nacos配置
server:port: 3377spring:application:name: nacos-config-clientcloud:nacos:discovery:server-addr: localhost:8848 #Nacos服务注册中心地址config:server-addr: localhost:8848 #Nacos作为配置中心地址file-extension: yaml #指定yaml格式的配置# ${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}

为什么要有两个Yml文件?

Nacos同springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,
拉取配置之后,才能保证项目的正常启动。
 
springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application
4、主启动类:@EnableDiscoveryClient

package com.atguigu.springcloud.alibaba;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;/*** @auther zzyy* @create 2020-02-10 16:51*/
@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377
{public static void main(String[] args) {SpringApplication.run(NacosConfigClientMain3377.class, args);}
}

5、业务类.......@RefreshScope (通过SpringCloud的原生注解@RefreshScope 实现配置的自动更新)

package com.atguigu.springcloud.alibaba.controller;import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;/*** @auther zzyy* @create 2020-02-10 16:55*/
@RestController
@RefreshScope //在控制器类加入@RefreshScope注解使当前类下的配置支持Nacos的动态刷新功能。
public class ConfigClientController
{@Value("${config.info}")private String configInfo;@GetMapping("/config/info")public String getConfigInfo() {return configInfo;}
}

Nacos平台配置:

配置结果:nacos-config-client-dev.yml

Nacos实现多项目多环境管理:

Namespace+Group+Data ID三者关系?为什么这么设计?

1 是什么?
   类似Java里面的package名和类名
   最外层的namespace是可以用于区分部署环境的,Group和DataID逻辑上区分两个目标对象。
2 三者情况
    
默认情况:
Namespace=public,Group=DEFAULT_GROUP, 默认Cluster是DEFAULT
 
Nacos默认的命名空间是public,Namespace主要用来实现隔离。
比方说我们现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。
 
Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去
 
Service就是微服务;一个Service可以包含多个Cluster(集群),Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。
比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,
这时就可以给杭州机房的Service微服务起一个集群名称(HZ),
给广州机房的Service微服务起一个集群名称(GZ),还可以尽量让同一个机房的微服务互相调用,以提升性能。
 
最后是Instance,就是微服务的实例。

Namespace 、Group 、 Data Id 三者之间的区别:


Nacos集群和持久化配置(重要)

集群部署架构图

因此开源的时候推荐用户把所有服务列表放到一个vip下面,然后挂到一个域名下面

http://ip1:port/openAPI 直连ip模式,机器挂则需要修改ip才可以使用。

http://SLB:port/openAPI 挂载SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),直连SLB即可,下面挂server真实ip,可读性不好。

http://nacos.com:port/openAPI 域名 + SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),可读性好,而且换ip方便,推荐模式

Nacos 1.1.4 中内置数据库derby改成持久化数据库Mysql8.0.x遇到的深坑以及解决方案:

nacos 1.1.14 连接mysql数据库包使用的是mysql-connector-java-5.1.34.jar(如下图),而我目前使用的mysql版本是mysql-8.0.13,我吗指定mysql在8.x版本使用的数据库连接包跟5.7.x版本以前是存在很大差别的。

Nacos持久化切换MySQL数据库遇到的问题_ㄔㄨ ㄓㄨㄥ的博客-CSDN博客

SpringCloud-alibaba-Nacos 从理论到落地使用相关推荐

  1. SpringCloud学习之(十八)SpringCloud Alibaba Nacos服务注册和配置中心

    文章目录 (十八)SpringCloud Alibaba Nacos服务注册和配置中心 1.Nacos简介 1.1 为什么叫Nacos 1.2 Nacos是什么 1.3 Nacos能干嘛 1.4 Na ...

  2. SpringCloud Alibaba - Nacos 作为配置中心 读取Properties配置信息

    SpringCloud Alibaba是阿里巴巴致力于对微服务的管理.配置.注册等一整套的解决方案. 简介 Nacos 提供用于存储配置和其他元数据的 K-V 存储,为分布式系统中的外部化配置提供服务 ...

  3. SpringCloud Alibaba Nacos服务注册和配置中心-微服务(二十六)

    Nacos作为服务注册中心演示 官网文档 基于Nacos的服务提供者 新建Module cloudalibaba-provider-payment9001 POM 父POM <?xml vers ...

  4. SpringCloud学习记录 | 第十五篇:SpringCloud Alibaba Nacos集群版

    重要.重要.重要 Nacos官方资料:https://nacos.io/zh-cn/docs/what-is-nacos.html Nacos集群架构 关于点故障.性能等等Nacos建议我们在实际项目 ...

  5. springcloud alibaba nacos 下载地址

    https://github.com/alibaba/nacos/releases/tag/1.4.1 nacos下载地址

  6. SpringCloud学习记录 | 第十五篇:SpringCloud Alibaba Nacos配置中心-单机版

    重要.重要.重要 官网资料:https://nacos.io/zh-cn/docs/what-is-nacos.html NacosConfigServer端 前面一篇文章意见说了怎么部署一个Naco ...

  7. Alibaba Nacos配置中心功能介绍与不同命名空间、分组等配置

    概述:我们前面介绍过 Nacos 可以为我们提供服务注册与发现,以及实现了配置中心功能,本章将介绍nacos 配置中心的使用方法,以及其不同场景下的配置方式.在前面我们介绍过nacos的领域模型(下图 ...

  8. Alibaba Nacos 服务消费者工程接入nacos并实现调用服务提供者工程

    概述:本章将介绍 服务消费者工程接入到nacos中,并使用nacos集成的负载均衡实现一个简单的轮询的负载均衡调用生产者工程示例. 环境:SpringBoot 2.2.2.RELEASE + Spri ...

  9. Alibaba Nacos 介绍以及服务提供者工程接入nacos注册中心

    一.SpringCloud Alibaba Nacos 介绍 Nacos 为 SpringCloud Alibaba 下的一款集 服务注册与发现.服务配置管理于一体的微服务管理平台. 其中在服务管理中 ...

  10. todo谷粒商城三分布式组件-SpringCloud Alibaba与SpringCloud

    简介 Spring Cloud Alibaba中文官方地址网址打不开的话可以用手机QQ浏览器. Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案.此项目包含开发分布式应用 ...

最新文章

  1. Java 程序员必须掌握的 10 款开源工具!
  2. 在tomcat下部署两个或多个项目时 log4j和web.xml配置webAppRootKey 的问题(转)
  3. python字符串/元组/列表/字典互转
  4. vue过渡和animate.css结合使用
  5. inline-block什么意思中文_css中inline-block是什么?inline-block布局的使用
  6. 沿任意方向缩放、镜像、正交投影及切变及其推导
  7. GridView格式化数据失效
  8. 解决 java.net.ConnectException: Connection refused: connect 异常
  9. Entity Framework 学习总结之三:架构组成介绍
  10. 三菱fx3u通讯手册_三菱FX3U与变频器通讯程序如何编写
  11. python资料-python 资料
  12. 计算机 管理策略,有关管理组策略管理模板的建议 (.adm) 文件
  13. 代码生成工具系列-----代码生成工具(CodeEasy)介绍
  14. java大小端在线转换_Java 大小端转换
  15. PHP搞笑文字表情包在线制作网站源码
  16. java开发坦克大战小游戏
  17. blos硬盘启动台式计算机,bios设置硬盘启动,最全的bios设置硬盘启动详细方法(两种模式)...
  18. [架构]京东咚咚架构演进
  19. linux 查看文件哈希码,Linux校验文件SHA1/SHA256/MD5哈希值方法
  20. qlikview连接mysql_QlikView安装

热门文章

  1. 性能调优疑问: IO操作消耗CPU吗?
  2. java 构造函数 静态_为什么不允许使用 Java 静态构造函数?
  3. ie型lfsr_FPGA入门实例一:LFSR
  4. 第7章 缓存雪崩+缓存击穿+缓存穿透
  5. 如何做好一个校园微信公众号,粉丝圈有话要说~
  6. autoproxy 规则
  7. 弗朗西斯科·罗曼·阿拉尔孔·苏亚雷斯!!伊斯科!!
  8. vimtex的安装与应用(仍在学习,未完待续... ...)
  9. P1848 [USACO12OPEN]Bookshelf G
  10. 基于知识图谱的问答系统(KBQA)