草庐IT

Nacos全面解析

Mr Tang 2023-07-18 原文

目录

一.Nacos概要

1.Nacos简介

2.Nacos安装

3.Nacos配置外部数据源

二.Nacos应用

1.注册发现

2.负载均衡

3.配置中心

4.多环境切换

5.配置刷新

6.共享/扩展配置

7.灰度发布


一.Nacos概要

1.Nacos简介

Nacos是阿里巴巴开源的一款支持 服务注册与发现配置管理服务管理 的组件。

取代以前常用的注册中心(zookeeper , eureka等等),以及配置中心(spring cloud config等等)

2.Nacos安装

1.下载安装包

官网地址:Releases · alibaba/nacos · GitHub 1.0

Releases · alibaba/nacos (github.com) 2.0

2.0.2下载地址:

链接:https://pan.baidu.com/s/1V4S1aNpgnj0h4GKlN5bnag 
提取码:0gyl

 说明:1.4.0以下使用的mysql驱动是8.0以下的,1.4.0以上使用的驱动就是8.0以上的了,所以大家在使用的nacos的时候要注意与mysql的对应版本问题,否则会因为nacos与mysql的版本不对应导致的nacos无法加载数据源。

2.解压使用启动脚本启动 

ps:直接启动可能会报错:java.net.UnknownHostException: jmenv.tbsite.net

默认是集群模式启动,如果报错可以按照如下方式启动

进入命令行执行:startup.cmd -m standalone 启动

也可以在application.properties中配置nacos.core.member.lookup.type=file

3.访问

nacos启动后访问控制台地址:http://localhost:8848/nacos/index.html#/login

用户名密码默认都是:nacos

3.Nacos配置外部数据源

修改D:\software\nacos-2.0.2\conf\application.properties

#下面这两行注释一定要打开,不打开下面配置的mysql数据源就不生效了
spring.datasource.platform=mysql
db.num=1

db.url.0=jdbc:mysql://localhost:3306/jg_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user=root
db.password=root

二.Nacos应用

1.注册发现

1.项目中引入nacos的相关依赖

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

2.配置文件如下

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

3.启动类加服务发现的注解

@SpringBootApplication
@EnableDiscoveryClient
public class NacosDemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(NacosDemoApplication.class, args);
    }

}

4.查看nacos界面,服务列表

注意:可以通过在配置文件中配置namespace 属性控制服务属于哪个命名空间下的,默认不配置namespace都是在public的命名空间下,可以在命令空间菜单下新建命名空间。(namespace 是通过id与nacos命名空间 关联的,命名空间可是实现数据隔离)

5.测试

localhost:10086/nacos/hellohttp://localhost:10086/nacos/hello调用controller接口正确返回,说明服务注册和发现正常

2.负载均衡

1.初始化负载均衡算法

@Configuration
public class NacosDemoConfig {
    /***
     * Nacos负载均衡算法
     * @return
     */
    @Bean
    @Scope(value="prototype")
    public IRule loadBalanceRule(){
        return new NacosRule();
    }
}

2.在配置文件中配置权重 weight: 1

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        namespace: public
        server-addr: 127.0.0.1:8848
        weight: 1

3.再起一个服务权重设置为weight: 2

-Dserver.port=10087 -Dspring.cloud.nacos.discovery.weight=2

4.启动后查看控制台

 5.通过网关测试,发现调用比例为1:2

3.配置中心

需要把配置文件名称改为优先加载的bootstrap.yaml文件,否则加载不到nacos的配置

1.新建命名空间nacos-demo(实现数据隔离)id为2,配置文件中指定namespace为2

配置服务名称:name: nacos-demo

配置文件后缀名:file-extension: yaml

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        namespace: 2
        server-addr: 127.0.0.1:8848
        weight: 1
      config:
        server-addr: 127.0.0.1:8848
        namespace: 2
        file-extension: yaml

2.在配置管理>配置列表中新建配置

(1)Data_id默认加载${spring.application.name}.${file-extension}(服务名.文件后缀)

 3.项目中使用配置

@RestController
@RequestMapping("/nacos")
public class NacosDemoController {

    @Value("${nacostest}")
    private String nacostest;

    @GetMapping("hello")
    public String helloNacos(){
        return "Hello Nacos:"+nacostest;
    }

}

4.测试

http://localhost:10086/nacos/hello

 返回成功,配置数据生效。

4.多环境切换

通过配置Data Id实现多环境切换

配置格式为:服务名-环境.文件后缀

${spring.application.name}-${profile}.${file-extension:properties}

1.配置开发环境配置文件如下

 2.工程配置文件中指定环境配置

spring:
  application:
    name: nacos-demo
  profiles:
    active: dev

3.测试

    @Value("${nacosenv}")
    private String nacosenv;

    @GetMapping("hello")
    public String helloNacos(){
        return "Nacos Env is:"+nacosenv;
    }

4.访问成功,环境配置完成

5.配置刷新

默认情况下nacos已经实现了自动配置刷新功能,如果需要刷新配置直接在控制器中加入@RefreshScope注解即可

6.共享/扩展配置

(1)创建一个public.yaml作为共享配置

(2)在工程配置文件中引入共享配置       

shared-configs[0]:
          dataId: public.yaml
          refresh: true

spring:
  application:
    name: nacos-demo
  profiles:
    active: dev
  cloud:
    nacos:
      discovery:
        namespace: 2
        server-addr: 127.0.0.1:8848
        weight: 1
      config:
        server-addr: 127.0.0.1:8848
        namespace: 2
        file-extension: yaml
        shared-configs[0]:
          dataId: public.yaml
          refresh: true

 (3)测试

        获取public.yaml内容成功,共享配置生效

7.灰度发布

1.概述

        Nacos支持以IP为粒度的灰度配置

2.灰度发布配置步骤:

(1)讲服务在不同的服务器部署,有多个实例

(2)编辑配置文件点击Beta发布

(3)填写需要发布到的ip,以逗号分割

(4)点击【发布Beta】,点击后,可以通过【停止Beata】按钮停止灰度发布

 

有关Nacos全面解析的更多相关文章

  1. Ruby 解析字符串 - 2

    我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?

  2. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  3. ruby - 用逗号、双引号和编码解析 csv - 2

    我正在使用ruby​​1.9解析以下带有MacRoman字符的csv文件#encoding:ISO-8859-1#csv_parse.csvName,main-dialogue"Marceu","Giveittohimóhe,hiswife."我做了以下解析。require'csv'input_string=File.read("../csv_parse.rb").force_encoding("ISO-8859-1").encode("UTF-8")#=>"Name,main-dialogue\r\n\"Marceu\",\"Giveittohim\x97he,hiswife.\"\

  4. ruby-on-rails - 我更新了 ruby​​ gems,现在到处都收到解析树错误和弃用警告! - 2

    简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und

  5. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

  6. ruby - 用 YAML.load 解析 json 安全吗? - 2

    我正在使用ruby2.1.0我有一个json文件。例如:test.json{"item":[{"apple":1},{"banana":2}]}用YAML.load加载这个文件安全吗?YAML.load(File.read('test.json'))我正在尝试加载一个json或yaml格式的文件。 最佳答案 YAML可以加载JSONYAML.load('{"something":"test","other":4}')=>{"something"=>"test","other"=>4}JSON将无法加载YAML。JSON.load("

  7. ruby - 如何使用 Nokogiri 解析纯 HTML 表格? - 2

    我想用Nokogiri解析HTML页面。页面的一部分有一个表,它没有使用任何特定的ID。是否可以提取如下内容:Today,3,455,34Today,1,1300,3664Today,10,100000,3444,Yesterday,3454,5656,3Yesterday,3545,1000,10Yesterday,3411,36223,15来自这个HTML:TodayYesterdayQntySizeLengthLengthSizeQnty345534345456563113003664354510001010100000344434113622315

  8. python - 帮我找到合适的 ruby​​/python 解析器生成器 - 2

    我使用的第一个解析器生成器是Parse::RecDescent,它的指南/教程很棒,但它最有用的功能是它的调试工具,特别是tracing功能(通过将$RD_TRACE设置为1来激活)。我正在寻找可以帮助您调试其规则的解析器生成器。问题是,它必须用python或ruby​​编写,并且具有详细模式/跟踪模式或非常有用的调试技术。有人知道这样的解析器生成器吗?编辑:当我说调试时,我并不是指调试python或ruby​​。我指的是调试解析器生成器,查看它在每一步都在做什么,查看它正在读取的每个字符,它试图匹配的规则。希望你明白这一点。赏金编辑:要赢得赏金,请展示一个解析器生成器框架,并说明它的

  9. ruby - 如何用 Nokogiri 解析连续的标签? - 2

    我有这样的HTML代码:Label1Value1Label2Value2...我的代码不起作用。doc.css("first").eachdo|item|label=item.css("dt")value=item.css("dd")end显示所有首先标记,然后标记标签,我需要“标签:值” 最佳答案 首先,您的HTML应该有和中的元素:Label1Value1Label2Value2...但这不会改变您解析它的方式。你想找到s并遍历它们,然后在每个你可以使用next_element得到;像这样:doc=Nokogiri::HTML(

  10. ruby-on-rails - 如何在 Rails 3 中禁用 XML 解析 - 2

    我想禁用HTTP参数的自动XML解析。但我发现命令仅适用于Rails2.x,它们都不适用于3.0:config.action_controller.param_parsers.deleteMime::XML(application.rb)ActionController::Base.param_parsers.deleteMime::XMLRails3.0中的等价物是什么? 最佳答案 根据CVE-2013-0156的最新安全公告你可以将它用于Rails3.0。3.1和3.2ActionDispatch::ParamsParser::

随机推荐