概念
Nacos是阿里巴巴的产品,现在是springcloud的一个组件,相比于Eureka更加丰富。
启动 (单机启动)
进入nacos\bin目录,cmd进入控制台,输入startup.cmd -m standalone
data:image/s3,"s3://crabby-images/0c1be/0c1be07310067c7743ec350bb6205a060ebe346a" alt=""
浏览器输入地址:http://192.168.0.101:8848/nacos/index.html#/login
默认账号密码均为:nacos
data:image/s3,"s3://crabby-images/c219c/c219ccdc2ef6aa3d965fb93a3ee474b5e7cd97d5" alt=""
springboot中添加nacos
添加依赖
父工程的pom.xml添加依赖:
xml
<!-- nacos -->
<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>
data:image/s3,"s3://crabby-images/d755d/d755d6ebff2dfef0ef7882a78801453795aa756a" alt=""
子工程客户端添加依赖:
xml
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
data:image/s3,"s3://crabby-images/08269/08269b73a85b5392c0bd40af80f3d6c4d066557d" alt=""
修改子工程中的application.yml文件
yaml
spring:
cloud:
nacos:
discovery:
server-addr: localhost:8848
data:image/s3,"s3://crabby-images/459f9/459f9d5889a3261ea6c5ac4231234ea5b4d3dd8a" alt=""
启动测试
data:image/s3,"s3://crabby-images/dcbe3/dcbe3ab442c17c8a22e5c04f6b8abe8438dba48f" alt=""
分级存储模型
- 一级是服务,例如userservice
- 二级是集群,例如地点上海或者杭州
- 三级是机房,例如杭州的机房部署了userservice服务器
对于同一集群的服务器,消费者会优先调用同一集群的生产者服务器,若同一集群的生产者服务器宕机,则调用其他集群的服务器。
如何修改
在application.xml文件,添加spring.cloud.nacos.discovery.cluster-name属性
data:image/s3,"s3://crabby-images/8a6c6/8a6c6ccaff65169e3e105836d8273b3219c473d2" alt=""
data:image/s3,"s3://crabby-images/116b0/116b00826da063c8196e32bee0f9c835bb15505d" alt=""
查看
data:image/s3,"s3://crabby-images/2292a/2292a5a083542b170c15d11d67fa34a0be583fda" alt=""
data:image/s3,"s3://crabby-images/799e4/799e4186e3e1221f71f074f52d16a8526b4abb18" alt=""
负载均衡
设置
修改消费者的apllication.yml,设置Rule
(生产者为userservice,消费者为orderservice)
yaml
userservice:
ribbon:
NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule
NacosRule 策略:
- 优先选择同一集群的服务者实例
- 本地集群找不到,才回去其他集群查找
- 确定好服务者实例后,采用随机选择
data:image/s3,"s3://crabby-images/77538/77538e1dd34861a89e3cbb39e89dc4b52e9ad8b4" alt=""
相关策略:
data:image/s3,"s3://crabby-images/219f5/219f5c597c8087e36248c74fca37fcb5c9dfb318" alt=""
权重控制
若权重设为0,理论上消费者不会调用该生产者,那么即使是在白天,也可以进行服务器的升级
data:image/s3,"s3://crabby-images/7ac8a/7ac8aa92215f6989827773bbb67d7d2612df44e3" alt=""
环境隔离
data:image/s3,"s3://crabby-images/3e8c4/3e8c418b58584704262e1ac494473be0eb966b03" alt=""
复制命名空间id:24a1cb4c-91be-4177-a914-1fbdd4f898c1
data:image/s3,"s3://crabby-images/a84d3/a84d32c88c904c98f7a483b1dcae9eaa05aa20bb" alt=""
application.yml 中添加 namespace: 24a1cb4c-91be-4177-a914-1fbdd4f898c1
data:image/s3,"s3://crabby-images/8d704/8d704149beb3e2d0fbcaba7adaf1ac6fd0ec13dc" alt=""
data:image/s3,"s3://crabby-images/c5506/c550689d993298fe33a4994a7a4508912753a083" alt=""
热部署
nacoss上新建配置
data:image/s3,"s3://crabby-images/1d6e6/1d6e6f7356ff4a0b187f83f90eb327fc19b7a5fd" alt=""
文本框内容按照自己需求编写
data:image/s3,"s3://crabby-images/a5521/a55215255a80fc0c8ecf24b6dfb87b3f17664baf" alt=""
客户端导入依赖
xml
<dependency>
<groupId>com.alibaba.cloud </groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
从application.yml中抽取需要单独修改的配置,bootstrap的优先级高于application
data:image/s3,"s3://crabby-images/5e8f7/5e8f7ebfacc13d6699e6da76604cee442ed8588e" alt=""
法一:添加注解
@RefreshScope + @Value("${pattern.deteformat}")
data:image/s3,"s3://crabby-images/23317/23317f1dd8476522b943f76aa4e654e210297ae6" alt=""
法二:方法中注入
data:image/s3,"s3://crabby-images/5561d/5561dc6854f71ac0c3e4e9d6d2a7d46c5faf8a1e" alt=""
data:image/s3,"s3://crabby-images/0d49a/0d49a5e0f6fa9cfe752cb700968fc6764003c776" alt=""
多环境配置共享
优先级:服务名-profile.yaml > 服务名.yaml > 本地配置
如: userservice-dev.yaml > userservice.yaml > application.yaml