六、分布式SpringCloud环境--谷粒商城

发布时间 2023-05-06 18:04:32作者: 93丶Fss

分布式SpringCloud环境

一、注册中心:SpringCloud Alibaba Nacos  版本:nacos1.1.3 链接:https://github.com/alibaba/nacos/releases?page=4

主机端使用:

(1)、下载zip,并解压,打开bin里的startup.cmd

 (2)、引入依赖、修改配置文件:导入nacos配置

引入依赖

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

修改配置文件:导入nacos配置

  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

  application:
    name: gulimall-member

(3)、启动项添加注解

@EnableDiscoveryClient

 

 

配置中心:SpringCloud Alibaba Nacos  版本:nacos1.1.3 链接:https://github.com/alibaba/nacos/releases?page=4

在完成上一步的前提下:

1)、引入依赖,
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2)、创建一个bootstrap.properties
spring.application.name=gulimall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
3)、需要给配置中心默认添加一个叫 数据集(Data Id)gulimall-coupon.properties。默认规则,应用名.properties
4)、给 应用名.properties 添加任何配置
5)、动态获取配置。
@RefreshScope:动态获取并刷新配置
@Value("${配置项的名}"):获取到配置。
如果配置中心和当前应用的配置文件中都配置了相同的项,优先使用配置中心的配置。

2、细节
1)、命名空间:配置隔离;
      默认:public(保留空间);默认新增的所有配置都在public空间。
1、开发,测试,生产:利用命名空间来做环境隔离。
注意:在bootstrap.properties;配置上,需要使用哪个命名空间下的配置,
spring.cloud.nacos.config.namespace=9de62e44-cd2a-4a82-bf5c-95878bd5e871
2、每一个微服务之间互相隔离配置,每一个微服务都创建自己的命名空间,只加载自己命名空间下的所有配置

2)、配置集:所有的配置的集合

3)、配置集ID:类似文件名。
Data ID:类似文件名

4)、配置分组:
默认所有的配置集都属于:DEFAULT_GROUP;
1111,618,1212

项目中的使用:每个微服务创建自己的命名空间,使用配置分组区分环境,dev,test,prod

3、同时加载多个配置集
1)、微服务任何配置信息,任何配置文件都可以放在配置中心中
2)、只需要在bootstrap.properties说明加载配置中心中哪些配置文件即可
3)、@Value,@ConfigurationProperties。。。
以前SpringBoot任何方法从配置文件中获取值,都能使用。
配置中心有的优先使用配置中心中的,



负载均衡:SpringCloud Ribbon

声明式HTTP客户端:SpringCloud Feign ——调用远程服务

负载均衡:SpringCloud Ribbon —— feign中已经整合,无需显示引用

服务容错:SpringCloud Alibaba Sentinel ——限流、降级、熔断

API网关:SpringCloud Gateway ——webflux 编程模式

调用链路监控:SpringCloud Sleuth

分布式事务:SpringCloud Alibaba Seata ——原Fescar