安装教程:https://blog.csdn.net/qq_44749491/article/details/126334089
<!-- 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>

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

到后台在配置文件中查看



在配置文件中添加cluster-name 设置集群昵称



NFLoadBalancerRuLeClassName 同个集群下有多个服务时会采用随机的方式来负载均衡。
添加以下配置文件
spring:
userservice: #要做配置的微服务名称
ribbon:
NFLoadBalancerRuLeClassName: 配置负载均衡的规则

出现跨集群访问时,控制台会输出警告信息,提示运维人员。




在没有设置空间下节点默认都是放在命名空间的public默认空间

命名空间后会发现多出来了一个空间ID,在会到服务列表会看到我们新增的一个命名空间


在配置文件中添加namespace:后面跟着命名空间的id


Eureka通过主动询问来判断服务是否还存活,Nacos是通过心跳的来判断。

新增配置

配置文件昵称必须是要唯一的用于统一管理,

配置内容是把有热更新需求的放进来,如固定格式的配置不需要更新的就不需要填写。




** 添加管理依赖 **
com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-config
2.2.5.RELEASE

** 新建一个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 ));
}




** 第二种方式**

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


** 创建一个配置文件**

** 在工具类中添加我们新增的属性**

** 获取属性成功**


** 设置成测试环境在测试拉取 **


可以发现拉取成功
证明他在不同环境中是共享的


** 配置文件的新建也要跟三要素一致,否则会拉取失败**

也就是后台ID的三要素

** 如果以上配置正确还是无法拉取,检查nacos版本和当前spring版本是否兼容**




** 在nacos的conf文件中修改cluster.cof添加你的集群节点地址 **

然后修改application文件

打开数据源,告诉他我们使用的是mysql的数据源

删除掉注释修改数据库表名,然后修改mysql密码

启动服务器集群

配置反向代理,修改nginx的conf目录下nginx.conf配置文件

添加内容到配置文件

启动nginx

把java的nacos地址改成nginx反向代理的地址和端口
