SpringCloudAlibaba整合开发

1、Nacos :服务注册与发现

一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台

获取GIT上Nacos文件,打包并启动

克隆:git clone https://github.com/alibaba/nacos.git

打包:mvn -Prelease-nacos clean install -U

服务注册列表地址:http://192.168.43.20:8848/nacos/index.html

Nacas服务端点检查:http://localhost:8081/actuator/nacos-discovery(登录:nacos/naocs)

服务提供者与服务消费者

负载均衡:LoadBalancerClient替代原有的ribbon

Fegin用法保持不变

java 复制代码
#提供者配置
spring:
  application:
    name: nacos-provider
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

@RestController
public class NacosController {
    @GetMapping(value = "/provide/{message}")
    public String echo(@PathVariable(value = "message") String message) {
        return "Hello Nacos " + message;
    }
}


#消费者配置
spring:
  application:
    name: nacos-consumer
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848


@RestController
public class ConsumerController {

    @Autowired
    public LoadBalancerClient loadBalancerClient;

    @Autowired
    private RestTemplate restTemplate;

    @Value("${spring.application.name}")
    private String appName;

    @GetMapping(value = "/duan/app/name")
    public String duan() {
        ServiceInstance instance = loadBalancerClient.choose("nacos-provider");
        String url = String.format("http://%s:%s/provide/%s",
                instance.getHost(),
                instance.getPort(),
                appName);
        return restTemplate.getForObject(url, String.class);
    }
}

2、Sentinel :熔断器机制

把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务稳定性

克隆:git clone https://github.com/alibaba/Sentinel.git

打包:mvn clean package

启动参数:java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=127.0.0.1:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

Dashboard监控网址:localhost:8080(登录:sentinel/ sentinel)

java 复制代码
#配置文件application.yml
spring:
  application:
    name: nacos-consumer-fegin-sentinel
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
    sentinel:
      transport:
        port: 8719
        dashboard: localhost:8080

3、Gateway :路由网关

动态设置路由网关,通过注册在nacos上的微服务的名称访问消费者与提供者

采用LoadBalanceClient的方式,以lb://开头,后面是注册在nacos上的服务名:

uri: lb://nacos-consumer(通过注册的微服务名访问)

java 复制代码
#配置文件application.yml
spring:
  application:
    name: spring-gateway
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
    sentinel:
     transport:
        port: 8718
        dashboard: localhost:8080
    gateway:
      discovery:
        locator:
          enabled: true
      routes:
      #采用自定义路由的ID(有固定的用法,不同的id有不同的功能)
        - id: NACOS-CONSUMER
          #采用LoadBalanceClient的方式,以lb://开头,后面是注册在nacos上的服务名
          uri: lb://nacos-consumer
          #Predicate 翻译为"谓词"的意思,必须。主要用来匹配用户的请求,有多种写法
          predicates:
            #Method 方法谓词,这里匹配GET与POST请求
            - Method=GET,POST
        - id: NACOS-CONSUMER-FEIGN
          uri: lb://nacos-consumer-feign
          predicates:
            - Method=GET,POST


public class AuthFilter implements GlobalFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String token = exchange.getRequest().getQueryParams().getFirst("token");
        if(token==null || token.isEmpty())
        {
            exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
            return exchange.getResponse().setComplete();
        }
        return chain.filter(exchange);
    }

}

4、Nacos-config :动态配置以及多环境

配置管理-配置列表-新增配置

多环境-启用环境:spring.profiles.active=prod

应用名为Nacos Config中的Data ID,实际应用名称以配置中心的为准:

spring.application.name=nacos-provider-config
指定查找名为nacos-provider-config.yaml的文件:

spring.cloud.nacos.config.file-extension=yaml

Nacos Server的地址:spring.cloud.nacos.config.server-addr=127.0.0.1:8848

关闭动态刷新 spring.cloud.nacos.config.refresh.enabled=false

获取最新环境变量,获取配置信息

@Autowired

private ConfigurableApplicationContext applicationContext;

String name = applicationContext.getEnvironment().getProperty("user.name");

java 复制代码
#多环境-启用环境
spring.profiles.active=prod
#应用名为Nacos Config中的Data ID,实际应用名称以配置中心的为准
spring.application.name=nacos-provider-config
#指定查找名为nacos-provider-config.yaml的文件
spring.cloud.nacos.config.file-extension=yaml
#Nacos Server的地址
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#关闭动态刷新 
spring.cloud.nacos.config.refresh.enabled=false
相关推荐
Mr.wangh1 天前
SpringCloudConfig(配置中心)
大数据·elasticsearch·搜索引擎·springcloud·config
阿拉斯攀登6 天前
Spring Cloud Alibaba 生态中 RocketMQ 最佳实践
分布式·微服务·rocketmq·springcloud·cloudalibaba
阿拉斯攀登11 天前
SpringCloudAlibaba之Nacos
微服务·服务发现·springcloud
阿拉斯攀登12 天前
深入微服务配置中心:Nacos注册中心的实操细节
java·微服务·云原生·springcloud
小坏讲微服务13 天前
Spring Boot 4.0 与 MyBatis Plus 整合完整指南
java·spring boot·后端·mybatis·springcloud·mybatis plus·java开发
咖啡不甜不好喝14 天前
sentinel踩坑记录
sentinel·springcloud
她说..14 天前
Spring AOP 操作日志框架(CV可用)
java·jvm·spring·springboot·springcloud
better_liang15 天前
每日Java面试场景题知识点之-分布式事务处理
java·微服务·面试·springcloud·分布式事务
ruleslol20 天前
Spring Cloud Gateway 断言完全讲解
springcloud
whltaoin20 天前
【 Java微服务 】Spring Cloud Alibaba :Nacos 注册中心与配置中心全攻略(含服务发现、负载均衡与动态配置)
java·微服务·nacos·springcloud·注册中心·配置中心