2021年7月18日星期日

Nacos入门学习&实践

文中涉及到了一些模块代码没有给出,我一并上传到github了,可以整个项目clone下来进行调试。

地址:https://github.com/stronglxp/springcloud-test

在这里插入图片描述

1、SpringCloud Alibaba介绍

1.1 为什么会出现SpringCloud Alibaba

Spring Cloud Netflix项目进入维护模式。https://spring.io/blog/2018/12/12/spring-cloud-greenwich-rc1-available-now

将模块置于维护模式,意味着Spring Cloud团队将不会再向模块添加新功能。他们将修复block级别的 bug 以及安全问题,他们也会考虑并审查社区的小型pull request。

1.2 SpringCloud Alibaba是什么

文档:https://github.com/alibaba/spring-cloud-alibaba/blob/master/README-zh.md

Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

诞生:2018.10.31,Spring Cloud Alibaba 正式入驻了Spring Cloud官方孵化器,并在Maven 中央库发布了第一个版本。

1.3 SpringCloud Alibaba能干嘛

  • 服务限流降级:默认支持 WebServlet、WebFlux, OpenFeign、RestTemplate、Spring Cloud Gateway, Zuul, Dubbo 和 RocketMQ 限流降级功能的接入,可以在运行时通过控制台实时修改限流降级规则,还支持查看限流降级 Metrics 监控。
  • 服务注册与发现:适配 Spring Cloud 服务注册与发现标准,默认集成了 Ribbon 的支持。
  • 分布式配置管理:支持分布式系统中的外部化配置,配置更改时自动刷新。
  • 消息驱动能力:基于 Spring Cloud Stream 为微服务应用构建消息驱动能力。
  • 分布式事务:使用 @GlobalTransactional 注解, 高效并且对业务零侵入地解决分布式事务问题。
  • 阿里云对象存储:阿里云提供的海量、安全、低成本、高可靠的云存储服务。支持在任何应用、任何时间、任何地点存储和访问任意类型的数据。
  • 分布式任务调度:提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。同时提供分布式的任务执行模型,如网格任务。网格任务支持海量子任务均匀分配到所有 Worker(schedulerx-client)上执行。
  • 阿里云短信服务:覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。

1.4 如何使用

如果需要使用已发布的版本,在 dependencyManagement 中添加如下配置。

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

然后在 dependencies 中添加自己所需使用的依赖即可使用。

1.5 组件

Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

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

RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。

Dubbo:Apache Dubbo™ 是一款高性能 Java RPC 框架。

Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

Alibaba Cloud OSS: 阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。

Alibaba Cloud SchedulerX: 阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。

Alibaba Cloud SMS: 覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。

1.6 学习资料

  • 官网:https://spring.io/projects/spring-cloud-alibaba#overview

  • 英文

    • https://github.com/alibaba/spring-cloud-alibaba
    • https://spring-cloud-alibaba-group.github.io/github-pages/greenwich/spring-cloud-alibaba.html
  • 中文:https://github.com/alibaba/spring-cloud-alibaba/blob/master/README-zh.md

2、nacos介绍及下载安装

2.1 nacos介绍

Nacos(Dynamic Naming and Configuration Service),一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

在这里插入图片描述
通过上面的SpringCloud组件图可知,nacos这个玩意在服务注册和服务配置、服务总线都有应用,直接把Eureka、Config和Bus给替换了,一箭三雕。

总结一下nacos的作用:注册中心+配置中心的组合 -> Nacos = Eureka+Config+Bus

2.2 各种注册中心比较在这里插入图片描述

CAP定理:https://zh.wikipedia.org/wiki/CAP%E5%AE%9A%E7%90%86

在这里插入图片描述
Nacos服务发现实例模型

在这里插入图片描述
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

2.3 学习文档

  • https://nacos.io/zh-cn/docs/what-is-nacos.html
  • https://spring-cloud-alibaba-group.github.io/github-pages/greenwich/spring-cloud-alibaba.html#_spring_cloud_alibaba_nacos_discovery

2.4 nacos服务器下载安装

下载前确保有jdk环境和maven环境

选择合适的版本,点击下载

在这里插入图片描述
下载完成后解压,然后以单机模式启动bin/startup.cmd

startup.cmd -m standalone

在这里插入图片描述
在这里插入图片描述

3、nacos的服务注册功能

3.1 创建服务提供者模块

如何创建分布式项目可参考:SpringCloud入门及创建分布式项目一文。

我们新建module:cloud-nacos-provider

在这里插入图片描述
pom.

<?

application.yml文件如下

server: port: 10001spring: application: name: cloud-nacos-provider cloud: nacos:  discovery:  server-addr: localhost:8848 # 配置本地的Nacos服务器地址

主启动类

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

编写一个控制器

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;@RestControllerpublic class ProviderController { @Value("${server.port}") private String port; @GetMapping(value = "/payment/nacos/{id}") public String getPayment(@PathVariable("id") Integer id) {  return "nacos registry, serverPort: " + port + "\t id" + id; }}

然后启动该模块,在nacos控制台就能看到该实例已经注册到nacos。

在这里插入图片描述

3.2 创建服务消费者模块

新建module:cloud-nacos-consumer

pom.

<?

application.yml文件如下

server: port: 10083spring: application: name: cloud-nacos-consumer cloud: nacos:  discovery:  server-addr: localhost:8848# 消费者将要去访问的微服务名称(注册成功进nacos的微服务提供者)service-url: nacos-user-service: >import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.client.discovery.EnableDiscoveryClient;@SpringBootApplication@EnableDiscoveryClientpublic class CloudNacosConsumerApplication { public static void main(String[] args) {  SpringApplication.run(CloudNacosConsumerApplication.class, args); }}

配置类

import org.springframework.cloud.client.loadbalancer.LoadBalanced;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.web.client.RestTemplate;@Configurationpublic class ApplicationContextConfig { @Bean @LoadBalanced public RestTemplate restTemplate() {  return new RestTemplate(); }}

控制器

import lombok.extern.slf4j.Slf4j;import org.springframework.beans.factory.annotation.Autowired;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;@RestController@Slf4jpublic class OrderNacosController { @Autowired private RestTemplate restTemplate; @Value("${service-url.nacos-user-service}") private String serviceUrl; @GetMapping(value = "/consumer/nacos/{id}") public String paymentInfo(@PathVariable("id") Long id) {  return restTemplate.getForObject(serviceUrl + "/payment/nacos/" + id, String.class); }}

然后启动消费者模块,在nacos控制台可以看到服务列表

在这里插入图片描述
我们通过consumer去访问provider的接口

在这里插入图片描述

3.3 Nacos的负载均衡

nacos支持负载均衡是因为spring-cloud-starter-alibaba-nacos-discovery内含netflix-ribbon包。

为了省事,我们可以直接copy一个provider进行启动

在这里插入图片描述
在这里插入图片描述
copy完成后,启动在这里插入图片描述
然后通过consumer付访问provider提高的接口,通过打印可以知道是轮询访问10001/10002

4、nacos作为配置中心

4.1 创建配置模块

新建module:cloud-nacos-config

pom.

<?

nacos和springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动

springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application。所以我们拉取配置需要写在bootstrap.yml文件中,启动完bootstrap.yml把相关配置拉取下来后才能正常启动项目。

配置bootstrap.yml文件

server: port: 3377spring: application: name: cloud-nacos-config cloud: nacos:  config:  server-addr: localhost:8848 # nacos本地服务器地址  file-extension: yaml # 配置文件的格式,默认properties  group: DEFAULT_GROUP # 分组,默认DEFAULT_GROUP

配置application.yml文件

spring: profiles: active: dev

4.2 在nacos控制台增加配置信息

前面我们在bootstrap.yml文件中配置了spring.application.name,是因为它是构成 Nacos 配置管理 dataId字段的一部分。

在 Nacos Spring Cloud 中,dataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。 注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 propertiesyaml 类型。

最后公式:

${spring.application.name}-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension}

在这里插入图片描述
接下来在nacos控制台新增配置

在这里插入图片描述
在这里插入图片描述
保存后,再修改启动类

import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.context.ConfigurableApplicationContext;@SpringBootApplicationpublic class CloudNacosConfigApplication { public static void main(String[] args) {  ConfigurableApplicationContext applicationContext = SpringApplication.run(CloudNacosConfigApplication.class, args);  // 读取启用配置文件中的属性  String userName = applicationContext.getEnvironment().getProperty("user.name");  String userAge = applicationContext.getEnvironment().getProperty("user.age");  System.err.println("user name :" +userName+"; age: "+userAge); }}

启动项目,控制台打印

在这里插入图片描述

4.3 动态更新配置

nacos支持动态更新配置信息。我们修改启动类代码如下

import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.context.ConfigurableApplicationContext;import java.util.concurrent.TimeUnit;@SpringBootApplicationpublic class CloudNacosConfigApplication { public static void main(String[] args) throws InterruptedException {  ConfigurableApplicationContext applicationContext = SpringApplication.run(CloudNacosConfigApplication.class, args);  while (true) {   // 读取启用配置文件中的属性   String userName = applicationContext.getEnvironment().getProperty("user.name");   String userAge = applicationContext.getEnvironment().getProperty("user.age");   System.err.println("user name :" +userName+"; age: "+userAge);   TimeUnit.SECONDS.sleep(1);  } }}

while条件永远为真,每隔一秒就是获取配置文件的值。然后我们在nacos控制台修改对应配置文件中user.age的值,发现控制台打印的user.age的值也更新了。

在这里插入图片描述
如果要禁用自动更新,在bootstrap.yml中进行配置

spring: cloud: nacos:  config:  refresh:   enabled: false

4.4 namespace和group和dataId三者的关系

三个东西是为了解多项目多环境的问题。

实际开发中,通常一个系统会准备

  • dev开发环境
  • test测试环境
  • prod生产环境

如何保证指定环境启动时服务能正确读取到Nacos上相应环境的配置文件呢?

一个大型分布式微服务系统会有很多微服务子项目,每个微服务项目又都会有相应的开发环境、测试环境、预发环境、正式环境…那怎么对这些微服务配置进行管理呢?

nacos默认的namespace是public,默认的group是DEFAULT_GROUP

在这里插入图片描述
在这里插入图片描述
类似Java里面的package名和类名,最外层的namespace是可以用于区分部署环境的,Group和DatalD逻辑上区分两个目标对象。

在这里插入图片描述

  • Nacos默认的Namespace是public,Namespace主要用来实现隔离。

    比方说我们现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。

  • Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去

  • Service就是微服务:一个Service可以包含多个Cluster (集群),Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。
    比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称(HZ) ,给广州机房的Service微服务起一个集群名称(GZ),还可以尽量让同一个机房的微服务互相调用,以提升性能。

  • 最后是Instance,就是微服务的实例

我们可以在nacos控制台创建namespace和group。

创建dev和test的namespace

在这里插入图片描述
回到配置列表,就能看到我们创建的namespace

在这里插入图片描述
分别在test和dev的namespace里新建配置文件

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在bootstrap.yml中指定group和namespace就可以获取不同的配置文件了。(记住dataId的生成规则)

spring: application: name: cloud-nacos-config cloud: nacos:  config:  server-addr: localhost:8848 # nacos本地服务器地址  file-extension: yaml # 配置文件的格式,默认properties  group: TEST_GROUP # 分组,默认DEFAULT_GROUP  # group: DEV_GROUP  namespace: 155a7fd7-6834-4787-80f7-35f56dd9f8fb  # namespace: 2f42a525-6d50-45dc-8ed1-d474fff7ce42

5、nacos集群和持久化

参考文档:https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html

https://nacos.io/zh-cn/docs/deployment.html

5.1 集群部署架构图

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

在这里插入图片描述
一般在实际部署时,架构图如下

在这里插入图片描述
默认Nacos使用嵌入式数据库实现数据的存储。所以,如果启动......

原文转载:http://www.shaoqun.com/a/887589.html

跨境电商:https://www.ikjzd.com/

airwallex:https://www.ikjzd.com/w/1011

epa认证:https://www.ikjzd.com/w/1769

执御:https://www.ikjzd.com/w/717.html


文中涉及到了一些模块代码没有给出,我一并上传到github了,可以整个项目clone下来进行调试。地址:https://github.com/stronglxp/springcloud-test1、SpringCloudAlibaba介绍1.1为什么会出现SpringCloudAlibabaSpringCloudNetflix项目进入维护模式。https://spring.io/blog/2018
圣诞节2021新年日本关西旅游购物推荐——大阪阪急百货店梅田总店!:http://www.30bags.com/a/425994.html
圣诞节吃什么好?做什么好?:http://www.30bags.com/a/403204.html
圣诞节和女朋友怎么过好?:http://www.30bags.com/a/396665.html
圣诞节教堂有什么活动的?:http://www.30bags.com/a/397669.html
男友不让我公车穿内裤 地铁被陌生人做到高潮:http://lady.shaoqun.com/a/247950.html
好想同时被两个男人舔b 老公和朋友一起来干我:http://lady.shaoqun.com/a/274580.html
强壮公的侵犯让我次次高潮 强壮的公么征服了我:http://lady.shaoqun.com/m/a/247592.html
女人喂男人吃私人部位 女人下面被吃有多爽:http://lady.shaoqun.com/m/a/247713.html
信:男朋友太好色了。我该不该和他分手?:http://lady.shaoqun.com/a/425257.html
陕西高中老师亲17岁女生补课,教师资格将被撤销:http://lady.shaoqun.com/a/425258.html
一次旅行,发现男朋友不行。我该不该和他分手?:http://lady.shaoqun.com/a/425259.html
在恋爱中如何有效拒绝他的性要求?这些经验值得收集:http://lady.shaoqun.com/a/425260.html

没有评论:

发表评论