热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微服务新秀之Nacos,看了就会,我说的

再讲Nacos之前,我们需要了解什么是Nacos:Nacos是阿里的一个开源产品,它是针对微服务架构中的服务发现

再讲 Nacos 之前,我们需要了解什么是 Nacos:Nacos 是阿里的一个开源产品,它是针对微服务架构中的 服务发现配置管理服务治理 的综合性解决方案。

官网给出的回答:

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您实现动态服务发现、服务配置管理、服务及流量管理。 Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。Nacos 是构建以“服务”为中心的现代应用架构(例如微服务范式、云原生范式)的服务基础设施。

综上所述,得出 Nacos 的四大特性:

  • 服务发现与服务健康检查
  • 动态配置管理
  • 动态DNS服务
  • 服务和元数据管理

附图:

微服务新秀之Nacos,看了就会,我说的
image

看到Nacos支持这么多主流的开源生态,是心动的感觉!

一、入门基操 使用方式

Nacos的使用方式也极其简单,以下为 windows 下安装方式

步骤1

点击下载地址 下载最新稳定版本

步骤2

双击 bin 目录下的 startup.cmd 启动服务器

步骤3

通过浏览器访问 http://127.0.0.1:8848/nacos 打开 nacos 控制台登录页面,默认用户名密码皆为:nacos,登录成功后便可访问主页面。

微服务新秀之Nacos,看了就会,我说的
image
扩展使用 发布配置

我们可以通过 地址 的方式发布配置:http://127.0.0.1:8848/nacos/v1/cs/configs,使用 postman 进行测试:

微服务新秀之Nacos,看了就会,我说的
image
微服务新秀之Nacos,看了就会,我说的
image
获取配置

我们可以通过 地址 的方式获取配置:http://127.0.0.1:8848/nacos/v1/cs/configs,使用 postman 进行测试:

微服务新秀之Nacos,看了就会,我说的
image
发布服务

我们可以通过 地址 进行服务注册:http://127.0.0.1:8848/nacos/v1/ns/instance,使用 postman 进行测试:

微服务新秀之Nacos,看了就会,我说的
image
微服务新秀之Nacos,看了就会,我说的
image
服务发现

我们可以通过 地址 发现服务:http://127.0.0.1:8848/nacos/v1/ns/instance/list,

使用 postman 进行测试:

微服务新秀之Nacos,看了就会,我说的
image
外部数据库支持

nacos默认是使用嵌入式数据库实现数据的存储,如果我们要使用外部 mysql 存储 nacos数据,进行以下步骤:

  • 步骤1

安装Mysql(5.6.5 ~ 8 之间的版本)

  • 步骤2

初始化 mysql 数据库,新建数据库 nacos,然后加载 conf/nacos-mysql.sql

  • 步骤3

修改 conf/application.properties文件,添加 mysql 数据源的配置,然后重启,便可生效

微服务新秀之Nacos,看了就会,我说的
image
二、配置管理

在上述中我们已经知道Nacos其中的一个功能便是用于配置中心。配置中心是在微服务架构中,当系统从一个单体应用被拆分为分布式系统上一个个服务节点时,配置文件也必须随着迁移而分割,这样配置就分散了,而且各个配置中也存在互相冗余的部分。

微服务新秀之Nacos,看了就会,我说的
image

配置中心所担任的角色:

微服务新秀之Nacos,看了就会,我说的
image

配置中心将配置从各应用中剥离出来,对配置进行统一管理,应用自身不需要自己去管理配置

从图中我们总结流程如下:

  • 用户在配置中心更新配置信息
  • A 服务和 B 服务及时得到配置更新通知,从配置中心获取更新
发布配置
微服务新秀之Nacos,看了就会,我说的
image
  • 步骤1中我们可以创建命名空间,命名空间(NameSpace)是用于隔离多个环境的(如开发、测试、生产),而每个应用在不同环境的同一配置(如数据库配置)的值是不一样的。
  • 步骤2中我们可以切换不同命名空间来发布不同配置,命名空间下类似 UUID 的一串便是每个命名空间的唯一ID。
  • 步骤3中我们可以点击发布配置,其中 DataIdgroup 是必填项
微服务新秀之Nacos,看了就会,我说的
image

完成上面三个步骤后我们便可以看到生成了一条刚刚配置过的信息

获取配置

然后我们在项目中便可读取配置中的内容,步骤如下:

  • 步骤1

在 pom 文件中引入 nacos-client包:

com.alibaba.nacosnacos-client1.1.3
  • 步骤2

通过 nacos-client 包下提供的 API,来获取配置:

public static void main(String[] args) throws NacosException {
    //使用nacos client远程获取nacos服务上的配置信息
    //nacos server地址
    String serverAddr = "127.0.0.1:8848";
    //data id
    String dataId = "application-dev.properties";
    //group
    String group = "DEFAULT_GROUP";

    //namespace
    String namespace = "dfa1c276-69f7-47d6-9903-6850b9c248f7";
    Properties properties =new Properties();
    properties.put("serverAddr",serverAddr);
    properties.put("namespace",namespace);

    //获取配置
    ConfigService cOnfigService= NacosFactory.createConfigService(properties);

    // String dataId, String group, long timeoutMs
    String cOnfig= configService.getConfig(dataId, group, 5000);
    System.out.println(config);
}
/* OUTPUT:
spring.datasource.mysql.driverClassName = com.mysql.cj.jdbc.Driver
*/

配置的管理模型如下图所示:

微服务新秀之Nacos,看了就会,我说的
image
  • 命名空间(NameSpace)

命名空间(NameSpace)用于不同环境(开发环境、测试环境和生产环境)的配置隔离。不同的命名空间下,可以存在相同名称的配置分组(Group)或配置集。

  • 配置分组(Group)

配置分组是对配置集进行分组,不同的配置分组下可以有相同的配置集(DateId)。默认的配置分组名称为 DEFAULT_GROUP。用于区分不同的项目或应用。

  • 配置集(DataId)

在系统中,一个配置文件通常就是一个 配置集,一个配置集可以包含了系统的各种配置信息,例如一个配置集可能包含了数据源、线程池、日志级别等配置项。每个配置集都可以定义一个有意义的名称。

微服务新秀之Nacos,看了就会,我说的
image
分布式配置

在了解通过 Nacos 集中管理多个服务的配置之前,我们先大概了解下以下概念:

传统单体架构
微服务新秀之Nacos,看了就会,我说的
image

所有功能模块打包到一起并放在一个 web 容器中运行,所有功能模块使用同一个数据库。

特点

  • 开发效率高
  • 容易测试
  • 容易部署

缺点:

  • 复杂性会逐渐变高,维护性逐渐变差
  • 版本迭代逐渐变慢
  • 阻碍技术创新
  • 无法按需伸缩
微服务架构
微服务新秀之Nacos,看了就会,我说的
image

微服务简单来说就是将一个项目拆分成多个服务。每一个微服务都是完整的应用,都有自己的业务逻辑和数据库。每一个业务模块都是用独立的服务完成,这种微服务架构模式也影响了应用和数据库之间的关系,不像传统多个业务模块共享一个数据库,微服务架构每个服务都有自己的数据库。

优点:

  • 分而治之,职责单一
  • 可伸缩
  • 局部容易修改、替换、部署,有利于持续集成和快速迭代
  • 不会受限于任何技术栈
Nacos
微服务新秀之Nacos,看了就会,我说的
image

话不多说,我们直接用代码来演示配置中心的用法:

  • 步骤1 – 发布配置

我们在Nacos主页中创建两个配置文件:

service_a.properties:

微服务新秀之Nacos,看了就会,我说的
image

service_b.properties:

微服务新秀之Nacos,看了就会,我说的
image
  • 步骤2 – 创建父工程

pom.xml 如下:

微服务新秀之Nacos,看了就会,我说的
image
  • 步骤3 – 创建子模块service-a

pom.xml 如下:

微服务新秀之Nacos,看了就会,我说的
image

bootstrap.yml如下:

微服务新秀之Nacos,看了就会,我说的
image
  • 步骤4 – 创建子模块service-b

pom.xml 如下:

微服务新秀之Nacos,看了就会,我说的
image

bootstrap.yml如下:

微服务新秀之Nacos,看了就会,我说的
image

工程目录结构如下:

微服务新秀之Nacos,看了就会,我说的
image

ConfigController如下:

微服务新秀之Nacos,看了就会,我说的
image

service-a运行结果为:

微服务新秀之Nacos,看了就会,我说的
image

service-b运行结果为:

微服务新秀之Nacos,看了就会,我说的
image

可以看到通过以上步骤成功获取到了我们在nacos中创建配置文件的内容。其中我们需要注意关键的步骤为:1. 引入 spring-cloud-alibaba-dependencies 和 spring-cloud-starter-alibaba-nacos-config 的 jar包2. 我们在 resources 下创建的配置文件必须是 bootstrap 而不能是 application 3. bootstrap.yml中的配置

bootstrap.yml另有玄机?

我们在上面看到配置核心点在于:

spring:
  application:
    name: service_a
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848                     # 配置中心地址
        # spring.application.name + file-extension = service_a.properties
        file-extension: properties                      # dataid名称的后缀
        namespace: dfa1c276-69f7-47d6-9903-6850b9c248f7 # 指定具体的namespace
        group: TEST_GROUP

这个是读取指定配置组下的指定配置,我们都知道开发讲究高内聚低耦合,如果有相同的配置项我们可以独立抽取成一个文件,这样我们就得引入多个配置文件,当然nacos也是支持的,配置如下:

spring:
  application:
    name: service_a
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848                     # 配置中心地址
        # spring.application.name + file-extension = service_a.properties
        file-extension: properties                      # dataid名称的后缀
        namespace: dfa1c276-69f7-47d6-9903-6850b9c248f7 # 指定具体的namespace
        group: TEST_GROUP
        # 通过 ext-config 来配合使用
        ext-config[0]:
          data-id: service-common_1.properties
        ext-config[1]:
          data-id: service-common_2.properties
          group: GLOBALE_GROUP
        ext-config[2]:
          data-id: service-common_3.properties
          group: REFRESH_GROUP
          refresh: true  #动态刷新配置

注意ext-config 得从 0 开始,其中 refresh 标签用来实现动态刷新,就是配置文件修改后,项目不用重启也能实时读取最新的配置文件。

可能你会觉得通过 ext-config 有点麻烦,需要写那么多,为了简化我们还可以使用 shared-dataids 和 refreshable-dataids 实现同上一样的功能,如下:

spring:
  application:
    name: service_a
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848                     # 配置中心地址
        # spring.application.name + file-extension = service_a.properties
        file-extension: properties                      # dataid名称的后缀
        namespace: dfa1c276-69f7-47d6-9903-6850b9c248f7 # 指定具体的namespace
        group: TEST_GROUP

        shared-dataids: service-common_1.properties,service-common_2.properties,service-common_3.properties
        refreshable-dataids: service-common_3.properties

通过 shared-dataids 来支持多个共享 Data Id 的配置,多个之间用逗号隔开。 通过 refreshable-dataids 来支持哪些共享配置的 Data Id 在配置变化时,应用中是否可动态刷新,感知到最新的配置值,多个 Data Id 之间用逗号隔开。如果没有明确配置,默认情况下所有共享配置的 Data Id 都不支持动态刷新。

配置项的优先级

#方式1
file-extension: properties                      # dataid名称的后缀
namespace: dfa1c276-69f7-47d6-9903-6850b9c248f7 # 指定具体的namespace
group: TEST_GROUP

#方式2
ext-config[0]:
data-id: service-common_1.properties
ext-config[1]:
data-id: service-common_2.properties
group: GLOBALE_GROUP
ext-config[2]:
data-id: service-common_3.properties
group: REFRESH_GROUP
refresh: true  #动态刷新配置

#方式3
shared-dataids: service-common_1.properties,service-common_2.properties,service-common_3.properties
refreshable-dataids: service-common_3.properties

以上我们了解到了 nacos 有三种配置方式,其中优先级:

方式1 > 方式2(内部比较:n越大,优先级越高) > 方式3

以上我们已经了解完了Nacos作为配置中心的使用,接下来我们来看看Nacos作为服务的注册中心有什么奥秘!

三、服务发现 什么是服务发现

在微服务架构中,整个系统会按职责划分为多个服务,通过服务之间且做来实现业务目标。这样在我们的代码中免不了要进行服务间的远程调用,服务的消费方要调用服务的生产方,为了完成这一次请求,消费方需要知道服务生产方的网络位置(IP地址和端口号

微服务新秀之Nacos,看了就会,我说的
image
服务发现中心对比
微服务新秀之Nacos,看了就会,我说的
image
服务发现入门

百说不如一练,咱们话不多说,直接上代码:

  • 步骤1 – 新建父工程

pom.xml如下:

微服务新秀之Nacos,看了就会,我说的
image
  • 步骤2 – 新建服务生产者

pom.xml如下:

微服务新秀之Nacos,看了就会,我说的
image

application.yml如下:

微服务新秀之Nacos,看了就会,我说的
image

启动类如下:

微服务新秀之Nacos,看了就会,我说的
image

ProviderController.java如下:

微服务新秀之Nacos,看了就会,我说的
image

以上便是生成者的代码,其中关键点在于:1. 引入 spring-cloud-starter-alibaba-nacos-discovery jar包 2. 在启动类标注 @EnableDiscoveryClient 注解 3. 在 application.yml 中配置nacos服务中心的地址 4. 在 controller 中暴露服务

  • 步骤3 – 新建服务消费者

pom.xml如下:

微服务新秀之Nacos,看了就会,我说的
image

application.yml如下:

微服务新秀之Nacos,看了就会,我说的
image

启动类如下:

微服务新秀之Nacos,看了就会,我说的
image

ConsumerController.java如下:

微服务新秀之Nacos,看了就会,我说的
image

以上便是消费者的代码,其中关键点在于:1. 引入 spring-cloud-starter-alibaba-nacos-discovery jar包 2. 在启动类标注 @EnableDiscoveryClient 注解 3. 在 application.yml 中配置nacos服务中心的地址 4. 在 controller 中使用RestTemplate 调用服务。

以上我们可以看到在Nacos中注册了两个服务,分别是 service-provider 和 service-consumer,我们也可以在Nacos控制台看到:

微服务新秀之Nacos,看了就会,我说的
image

同样,服务注册也支持命名空间的隔离,我们只需在application.yml中添加配置:

server:
  port: 8083

spring:
  application:
    name: service-consumer
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
        # 命名空间
        namespace: dfa1c276-69f7-47d6-9903-6850b9c248f7
        cluster-name: DEFAULT
Feign 的使用

Feign是Netflix开发的声明式、模板化的HTTP客户端,Feign可以帮助我们更快捷、优雅地调用HTTP API。

Feign的使用方式也十分简单,几个步骤如下:

  • 步骤1

声明 Feign 客户端:

@FeignClient(value = "service-provider") //生产者名称
public interface ConsumerService {

    @GetMapping("/getData")
    String getDate();
}
  • 步骤2

启动类 添加 @EnableFeignClients 注解

  • 步骤3

在 controller 层进行调用:

@RestController
public class ConsumerController {

    @Autowired
    private ConsumerService consumerService;

    @GetMapping("/getData")
    public String getData() {
        String date = consumerService.getDate();
        return "consumer consumer ---" + date;
    }
}

结果

微服务新秀之Nacos,看了就会,我说的
image

简单的使用,减少了与业务无关的 HTTP 请求相关代码的编写,使业务逻辑清晰。


推荐阅读
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
author-avatar
真理往往是废话
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有