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>

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

<!-- nacos客户端起步依赖 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>


在这里插入图片描述

1.1 修改配置文件

# 注册cloud
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos 服务地址

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

2.NacosRule负载均衡

2.1.配置集群属性

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

2.2 根据集群配置负载均衡

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

添加以下配置文件

spring:
userservice: #要做配置的微服务名称
	ribbon:
		NFLoadBalancerRuLeClassName: 配置负载均衡的规则

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

2.3 根据权重负载均衡

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

3.环境隔离

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

3.1 新建空间

在这里插入图片描述

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

3.2 代码对接命名空间

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

4.和Eureka的区别

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

5.Nacos配置管理

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

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

5.2 微服务配置拉取

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

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

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

spring:
  application:
    name: userservice
  profiles:
    active: dev # 环境
  cloud:
    nacos:
      server-addr: nacos:8848 # nacos地址
      config:
        file-extension: yaml # 文件后缀名

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

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

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

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;
}

注入到方法中

    @GetMapping("prop")
    public PatternProperties properties(){
        return properties;
    }
        @GetMapping("now")
    public String now(){
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(properties.getDateformat()));
    }

在这里插入图片描述

5.4 多环境配置共享

在这里插入图片描述

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

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

拉取环境的优先顺序

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

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

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

6.Nacos的集群搭建

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

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

配置负载均衡

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值