分布式基础

目录

SpringCloud和SpringCloud Alibaba引入微服务治理方案

概述

SpringCloud Alibaba-Nacos

Nacos注册中心

Nacos配置中心

SpringCloud-Feign

Springcloud -Getway:API网关 

跨域

elasticsearch

基本概念

初步检索

1._cat

3 .索引一个文档(保存)

4.查询请求文档

5.更新文档

6. 删除文档

7.bulk批量API


SpringCloud和SpringCloud Alibaba引入微服务治理方案

概述

SpringCloud的痛点

SpringCloud部分组件停止维护和更新,给开发带来不便

SpringCloud部分环境搭建复杂,没有完善的可视化界面,我们需要二次开发和定制。

SprigCloud配置复杂,部分配置差别难以区分和合理应用

SpringCloud Alibaba的优势

性能强悍,设计合理,开源,有可视化界面给运维开发带来极大的便利

结合SpringCloud Alibaba,我们最终的技术方案:

SpringCloud Alibaba-Nacos:注册中心(服务发现与注册)

SpringCloud Alibaba-Nacos:配置中心(动态配置管理)

SpringCloud-Ribbon:负载均衡

SpringCloud-Feign:调用远程服务

SpringCloud Alibaba -Sentinel:服务容错(限流,降级,熔断)

Springcloud -Getway:API网关(webflux编程模式)

SpringCloud-sleuth:调用链监控

SpringCloud-Alibaba-Seata:原fescar,分布式事务解决方案

SpringCloud与Springcloud alibaba与Springboot的对应关系

 首先引入SpringCloud,SpringCloudAlibaba和Springboot的相关依赖(注意版本对应),因为后面要用SpringCloud,SpringCloudAlibaba的相关组件所以要引入我们SpringCloud,SpringCloudAlibaba的相关依赖。

SpringCloud Alibaba-Nacos

Nacos注册中心

首先下载nacos服务器

1.将Nacos Discovery的依赖引入,功能是将我们的微服务注册到我们的注册中心,包括发现其他微服务,对服务注册发现的功能,放在com文件下,那么其他的微服务也具有了服务发现注册的功能。

<!--        服务注册/发现-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

2.将 Nacos 服务器地址配置添加到 /src/main/resources/application.yml 文件中。那个微服务需要配置到注册中心就要在该服务中配置nacos服务器地址,那么该服务一旦上线就可以在nacos服务器中找到。 localhost:8848是注册中心地址,并且要为每个服务取一个应用的名字,不然nacos的客户端找不到该服务 Application:name。

  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
  application:
    name: ncpmall-coupon

 3.使用@EnableDiscoveryClient注解开启服务注册与发现功能,运行该服务,nacos服务器就能发现该微服务。

@MapperScan("com.lizude.ncpmall.ncpmallcoupon.dao")
@SpringBootApplication
@EnableDiscoveryClient
public class NcpmallCouponApplication {
    public static void main(String[] args) {
        SpringApplication.run(NcpmallCouponApplication.class, args);
    }
}

4.启动该服务之前我们需要先打开Nacos服务器,然后启动该服务

Nacos配置中心

1.引入配置中心的依赖,该服务在配置一些配置文件之后就能连接配置中心

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

2.将 Nacos config 元数据配置添加到文件 /src/main/resources/bootstrap.properties (这个文件会优先于application.properties加载)

spring.application.name=ncpmall-coupon
spring.cloud.nacos.config.server-addr=localhost:8848

没有使用nacos之前如果要修改配置十分麻烦,需要在application里面修改,然后重新发布到服务器上,但是如果服务器一多就会十分麻烦,现在我们只需要在nacos修改一处,处处生效 。

3.在nacos的配置页面点加号

然后在运行的服务的console中找那个微服务配置文件的名字填到上面的配置图片中,我们是ncpmall-coupon.properties .

4.最后如果项目已经上线不方便重启,就使用@refreshScope,当配置信息改变,就不需要重启微服务

@Value("$(配置项名字)");获取到配置

如果配置中心和当前应用的配置文件都配置了相同的项,优先使用配置中心的配置

@RefreshScope//刷新配置信息
@RestController
@RequestMapping("ncpmallcoupon/coupon")
public class CouponController {
    @Autowired
    private CouponService couponService;

    @Value("${coupon.user.name}")
    private  String name;
    @Value("${user.age}")
    private Integer age;
    @RequestMapping("/test")
    public R test(){
        return R.ok().put("name",name).put("age",age);
    }

    @RequestMapping("/menber/list")
    public R menbercoupons(){
        CouponEntity couponEntity = new CouponEntity();
        couponEntity.setCouponName("满一百减10");
        return R.ok().put("coupons",Arrays.asList(couponEntity));
    }

    /**
     * 列表

5.细节:

命名空间:起配置隔离作用:

默认:public(保留空间):默认新增的所有配置都在public空间

    1.在开发(dev),测试(test),生产发布(prop)的配置不一样:利用命名空间做环境隔离

                 注意要在bootstrap.properties:配置上,需要使用那个命名空间下的配置。

2.基于每一个微服务互相隔离配置,每一个微服务都创建自己的一个命名空间,这样只加载自己命名空间的所有配置

    2.我们可以在不同的开发阶段开启不同的配置

 怎么在不同的开发开启不同的配置

只需要在bootstrap.properties中设置就好

spring.application.name=ncpmall-coupon
spring.cloud.nacos.config.server-addr=localhost:8848
#或者dev,prop,test
spring.cloud.nacos.config.namespace=47c04e7e-4096-4f5c-8e83-c04a5d252902

配置集:一组相关或者不相关的配置项的集合叫做配置集,比如说application.yml

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/npcmall_sms
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: root
#配置注册发现微服务的nocos地址,那个微服务需要配置到注册中心就要在该服务中配置nacos服务器地址,那么该服务一旦上线就可以在macos服务器中找到。 localhost:8848是注册中心地址
#使用@EnableDiscoveryClient注解开启服务注册与发现功能
#要为每个服务取一个应用的名字,不然nacos的客户端找不到该服务 Application:name:
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
  application:
    name: ncpmall-coupon
mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
server:
  port: 8000

配置集ID:类似于配置文件名

  

配置分组:默认所有的配置集都属于:DEFAULT_GROUP

指定配置分组在bootstrap.properties文件中

spring.application.name=ncpmall-coupon
spring.cloud.nacos.config.server-addr=localhost:8848
#或者dev,prop,test的名称空间
spring.cloud.nacos.config.namespace=47c04e7e-4096-4f5c-8e83-c04a5d252902
spring.cloud.nacos.config.group=11

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值