码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Nacos的注册和使用


    这里写目录标题

    • 前提要先安装Nacos
    • 1.服务注册导入Nacos依赖
      • 1.1 修改配置文件
    • 2.NacosRule负载均衡
      • 2.1.配置集群属性
      • 2.2 根据集群配置负载均衡
      • 2.3 根据权重负载均衡
    • 3.环境隔离
      • 3.1 新建空间
      • 3.2 代码对接命名空间
    • 4.和Eureka的区别
    • 5.Nacos配置管理
      • 5.1 创建配置文件实现热更新
      • 5.2 微服务配置拉取
        • 5.3 实现热更新
        • 5.4 多环境配置共享
          • 拉取环境的优先顺序
        • 5.5 配置文件拉取失败问题解决
    • 6.Nacos的集群搭建
        • 配置负载均衡

    前提要先安装Nacos

    安装教程:https://blog.csdn.net/qq_44749491/article/details/126334089

    1.服务注册导入Nacos依赖

    <!-- SpringCloudAlibaba有关依赖 -->
    <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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    客户端导入依赖,如果有eureka的依赖得先注掉

    <!-- nacos客户端起步依赖 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    1.1 修改配置文件

    # 注册cloud
      cloud:
        nacos:
          server-addr: localhost:8848 # nacos 服务地址
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    到后台在配置文件中查看
    在这里插入图片描述

    2.NacosRule负载均衡

    2.1.配置集群属性

    在这里插入图片描述
    在这里插入图片描述
    在配置文件中添加cluster-name 设置集群昵称
    在这里插入图片描述

    2.2 根据集群配置负载均衡

    在这里插入图片描述
    在这里插入图片描述
    NFLoadBalancerRuLeClassName 同个集群下有多个服务时会采用随机的方式来负载均衡。

    添加以下配置文件

    spring:
    userservice: #要做配置的微服务名称
    	ribbon:
    		NFLoadBalancerRuLeClassName: 配置负载均衡的规则
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    出现跨集群访问时,控制台会输出警告信息,提示运维人员。
    在这里插入图片描述

    2.3 根据权重负载均衡

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

    3.环境隔离

    在这里插入图片描述
    在没有设置空间下节点默认都是放在命名空间的public默认空间在这里插入图片描述

    3.1 新建空间

    在这里插入图片描述

    命名空间后会发现多出来了一个空间ID,在会到服务列表会看到我们新增的一个命名空间
    在这里插入图片描述

    3.2 代码对接命名空间

    在这里插入图片描述
    在配置文件中添加namespace:后面跟着命名空间的id
    在这里插入图片描述

    4.和Eureka的区别

    在这里插入图片描述
    Eureka通过主动询问来判断服务是否还存活,Nacos是通过心跳的来判断。
    在这里插入图片描述

    5.Nacos配置管理

    5.1 创建配置文件实现热更新

    新增配置
    在这里插入图片描述
    配置文件昵称必须是要唯一的用于统一管理,
    在这里插入图片描述
    配置内容是把有热更新需求的放进来,如固定格式的配置不需要更新的就不需要填写。
    在这里插入图片描述
    在这里插入图片描述

    5.2 微服务配置拉取

    在这里插入图片描述
    在这里插入图片描述
    ** 添加管理依赖 **

        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-config
            2.2.5.RELEASE
        
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    ** 新建一个bootstrap.yml配置文件 写入三要素**

    spring:
      application:
        name: userservice
      profiles:
        active: dev # 环境
      cloud:
        nacos:
          server-addr: nacos:8848 # nacos地址
          config:
            file-extension: yaml # 文件后缀名
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    ** 在把之前application.yml配置文件中重复的内容给删掉**
    在这里插入图片描述
    ** 测试拉取配置**

    // 获取配置文件的值
         @Value("${pattern.dateformat}")
         private String dateformat;
         
    
    • 1
    • 2
    • 3
    • 4
    // 获取时间格式化
        @GetMapping("now")
        public String now(){
            return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat	));
        }
        
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

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

    5.3 实现热更新

    在这里插入图片描述

    在这里插入图片描述
    ** 第二种方式**
    在这里插入图片描述

    package cn.itcast.user.config;
    
    import lombok.Data;
    import org.springframework.boot.context.properties.ConfigurationProperties;
    import org.springframework.stereotype.Component;
    
    @Data
    @Component
    @ConfigurationProperties(prefix = "pattern")
    public class PatternProperties {
        private String dateformat;
        private String envSharedValue;
        private String name;
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    注入到方法中

        @GetMapping("prop")
        public PatternProperties properties(){
            return properties;
        }
            @GetMapping("now")
        public String now(){
            return LocalDateTime.now().format(DateTimeFormatter.ofPattern(properties.getDateformat()));
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述

    5.4 多环境配置共享

    在这里插入图片描述

    ** 创建一个配置文件**
    在这里插入图片描述
    ** 在工具类中添加我们新增的属性**
    在这里插入图片描述
    ** 获取属性成功**
    在这里插入图片描述

    在这里插入图片描述
    ** 设置成测试环境在测试拉取 **
    在这里插入图片描述在这里插入图片描述
    可以发现拉取成功
    证明他在不同环境中是共享的

    拉取环境的优先顺序

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

    5.5 配置文件拉取失败问题解决

    ** 配置文件的新建也要跟三要素一致,否则会拉取失败**
    在这里插入图片描述
    也就是后台ID的三要素
    在这里插入图片描述
    ** 如果以上配置正确还是无法拉取,检查nacos版本和当前spring版本是否兼容**
    在这里插入图片描述

    6.Nacos的集群搭建

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

    ** 在nacos的conf文件中修改cluster.cof添加你的集群节点地址 **
    在这里插入图片描述
    然后修改application文件
    在这里插入图片描述
    打开数据源,告诉他我们使用的是mysql的数据源
    在这里插入图片描述
    删除掉注释修改数据库表名,然后修改mysql密码
    在这里插入图片描述
    启动服务器集群
    在这里插入图片描述

    配置负载均衡

    配置反向代理,修改nginx的conf目录下nginx.conf配置文件
    在这里插入图片描述
    添加内容到配置文件
    在这里插入图片描述
    启动nginx
    在这里插入图片描述
    把java的nacos地址改成nginx反向代理的地址和端口
    在这里插入图片描述

  • 相关阅读:
    《R语言与农业数据统计分析及建模》学习——描述性统计分析
    Flutter:安装依赖报错doesn‘t support null safety
    【蓝桥杯选拔赛真题08】C++最大值最小值平均值 青少年组蓝桥杯C++选拔赛真题 STEMA比赛真题解析
    分类预测 | Matlab实现RBF-Adaboost多特征分类预测
    浅谈java单元测试框架junit4/5
    Hbuilder开发运行真机上“同步资源失败,未得到同步资源的授权...” 错误解决
    Linux内核中ideapad-laptop.c文件全解析9
    (十七)Spring6整合JUnit
    RabbitMQ常用命令
    【遍历二叉树算法描述】
  • 原文地址:https://blog.csdn.net/qq_45007567/article/details/126386487
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号