码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 微服务之Nacos注册管理


    文章目录

    • 一、Nacos安装步骤
      • 1.安装地址
      • 2.安装版本
      • 3.目录说明
      • 4.端口配置
      • 5.启动
    • 二、Nacos服务注册
      • 1.Nacos依赖
      • 2.客户端修改配置文件
      • 3.启动效果图
      • 4.总结
    • 三、Nacos服务集群属性
      • 1.服务跨集群调用问题
      • 2.服务集群属性
      • 3.总结
    • 四、Nacos根据集群负载均衡
      • 1.修改配置文件
      • 2.设置集群服务类型
      • 3.跨集群访问
      • 4.总结
    • 五、Nacos根据权重负载均衡
      • 1.编写操作
      • 2.总结
    • 六、Nacos环境隔离-namespace
      • 1.命名空间创建操作
      • 2.总结
    • 七、Nacos临时实例和非临时实例
      • 1.配置临时实例和非临时实例
      • 2.总结


    一、Nacos安装步骤

    1.安装地址

    博主是在windows下进行安装的,所以如果想在Linux下安装请看官方详细教程

    在Nacos的GitHub页面,提供有下载链接,可以下载编译好的Nacos服务端或者源代码:

    GitHub主页:https://github.com/alibaba/nacos

    GitHub的Release下载页:https://github.com/alibaba/nacos/releases

    2.安装版本

    博主这边采用的nacos版本是1.4.1的,其他版本请看官网详细教程

    在这里插入图片描述

    3.目录说明

    注意:请解压至无中文目录的文件夹内

    目录说明:

    • bin:启动脚本
    • conf:配置文件

    在这里插入图片描述

    4.端口配置

    Nacos的默认端口是8848,如果你电脑上的其它进程占用了8848端口,请先尝试关闭该进程。

    如果无法关闭占用8848端口的进程,也可以进入nacos的conf目录,修改application.properties文件中的端口:
    在这里插入图片描述

    5.启动

    启动非常简单,进入bin目录,结构如下:
    在这里插入图片描述
    windows下的启动命令

    startup.cmd -m standalone
    
    • 1

    -m:表示模式
    standalone:表示单机启动

    执行效果图如下:
    在这里插入图片描述
    点击链接输入用户名:nacos,密码:nacos,即可进入nacos控制台
    在这里插入图片描述

    二、Nacos服务注册

    1.Nacos依赖

    父工程

    <dependency>
        <groupId>com.alibaba.cloudgroupId>
        <artifactId>spring-cloud-alibaba-dependenciesartifactId>
        <version>2.2.5.RELEASEversion>
        <type>pomtype>
        <scope>importscope>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    客户端:

    
    <dependency>
        <groupId>com.alibaba.cloudgroupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
    dependency>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    2.客户端修改配置文件

    修改客户端项目中的application.yml文件,注释eureka地址,添加nacos地址:

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

    3.启动效果图

    在这里插入图片描述

    4.总结

    在这里插入图片描述

    三、Nacos服务集群属性

    1.服务跨集群调用问题

    服务调用尽可能选择本地集群的服务,跨集群调用延迟较高
    本地集群不可访问时,再去访问其它集群

    在这里插入图片描述

    2.服务集群属性

    修改客户端服务者的application.yml文件,添加如下内容:

    spring:
      cloud:
        nacos:
          server-addr: localhost:8848 #nacos服务地址
          discovery:
            cluster-name: HZ #集群名称,这里HZ代指杭州
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    分别启动UserApplication1和UserApplicattion2,然后修改cluster-name的名字改为SH,接着启动UserApplication3,即可得到两个集群:
    在这里插入图片描述

    3.总结

    在这里插入图片描述

    四、Nacos根据集群负载均衡

    1.修改配置文件

    修改客户端服务消费者中的application.yml,设置集群为HZ:

    spring:
      cloud:
        nacos:
          server-addr: localhost:8848 #nacos服务地址
          discovery:
            cluster-name: HZ #集群名称,这里HZ代指杭州
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    2.设置集群服务类型

    然后在客户端服务消费者中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务:

    userservice:
      ribbon:
        NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
    
    • 1
    • 2
    • 3

    3.跨集群访问

    当我们HZ集群内的实例都没被启动,但SH集群的实例启动时,会出现跨集群访问,此时我们可以在控制台的日志中查看到一个跨集群访问的提示:
    在这里插入图片描述

    4.总结

    在这里插入图片描述

    五、Nacos根据权重负载均衡

    1.编写操作

    我们可以根据Nacos控制台的实例编辑功能来修改实例的权重:
    在这里插入图片描述

    在这里插入图片描述

    当我们给权重设为0时,此时实例则不会被访问。

    2.总结

    在这里插入图片描述

    六、Nacos环境隔离-namespace

    Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离
    在这里插入图片描述

    1.命名空间创建操作

    在Nacos控制台可以创建namespace,用来隔离不同环境
    在这里插入图片描述
    然后填写一个新的命名空间信息:
    在这里插入图片描述
    保存后会在控制台看到这个命名空间的id:
    在这里插入图片描述
    修改客户端服务消费者的application.yml,添加namespace:

    spring:
      datasource:
        url: jdbc:mysql://localhost:3306/cloud_order?useSSL=false
        username: root
        password: SHIyb021010
        driver-class-name: com.mysql.jdbc.Driver
      application:
        name: orderservice #user服务的服务名称
      cloud:
        nacos:
          server-addr: localhost:8848 #nacos服务地址
          discovery:
            cluster-name: HZ #集群名称,这里HZ代指杭州
            namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    重启客户端服务消费者后,再来查看控制台:
    在这里插入图片描述
    在这里插入图片描述
    此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错:
    在这里插入图片描述

    2.总结

    在这里插入图片描述

    七、Nacos临时实例和非临时实例

    在这里插入图片描述

    1.配置临时实例和非临时实例

    服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置:

    spring:
      cloud:
        nacos:
          discovery:
            ephemeral: false #设置非临时实例
    
    • 1
    • 2
    • 3
    • 4
    • 5

    临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会

    2.总结

    在这里插入图片描述

  • 相关阅读:
    在springboot项目中显示Services面板的方法
    Java多商户新零售超市外卖商品系统
    千兆工业交换机和百兆以太网交换机有什么区别?
    CDISC SDTM IG 3.3 版本相比于 3.2版本的变化 (下)
    智能音箱中采用的数字音频功放
    机器学习之 Jupyter Notebook 使用
    oracle使用regexp_substr来拆分,CONNECT BY LEVEL查询卡死,速度慢的问题。
    氨基NH2/羧酸COOH/马来酰亚胺MAL/叠氮N3/巯基SH/生物素Biotin修饰CdTe/CdS量子点
    Fritzing软件绘制Arduino面包板接线图传感器模块库文件216
    串口工作流程硬核解析,没有比这更简单的了!
  • 原文地址:https://blog.csdn.net/m0_64074924/article/details/134236181
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号