一、前言

        接下来是开展一系列的 SpringCloud 的学习之旅,从传统的模块之间调用,一步步的升级为 SpringCloud 模块之间的调用,此篇文章为第十三篇,即介绍 SpringCloud Alibaba Sentinel 简介和安装。

二、Sentinel 简介

2.1 Sentinel 是什么

        简单的解释:就是之前我们讲解过的 Hystrix,其中文文档的地址在这。

2.2 下载地址

        下载地址在这,选择适合自己的版本,如下图:

2.3 作用

2.4 解决问题

        这个组件可以解决服务雪崩、服务降级、服务熔断、服务限流等功能。

三、安装 Sentinel 控制台

3.1 组成部分

        Sentinel 分为两个部分:第一部分为核心库(Java 客户端),能够运行于所有 Java 运行环境,同时对 Dubbo / Spring Cloud 等框架也有较好的支持。第二部分为控制台(Dashboard)基于 Spring Boot 开发,打包后可以直接运行,不需要额外的 Tomcat 等应用容器。

3.2 安装步骤

3.2.1 下载

        下载地址在这,选择适合自己的版本,如下图:

3.2.2 运行

        运行的前提为有 java8 环境,并且 8080 端口未被占用,输入 java -jar sentinel-dashboard-1.8.7.jar 启动项目,如下图:

3.2.3 访问

        启动成功后,在浏览器输入 http://localhost:8080 进行访问,如下图,用户名和密码都是 sentinel

四、初始化演示工程

4.1 启动 Nacos 注册中心

        首先确保我们的注册中心是正常启动的,如下图:

4.2 创建工程

        创建一个名为 cloudalibaba-sentinel-service8401 的子模块,pom.xml 内容如下所示:

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

com.springcloud

SpringCloud

1.0-SNAPSHOT

cloudalibaba-sentinel-service8401

8

8

UTF-8

com.springcloud

cloud-api-commons

${project.version}

com.alibaba.cloud

spring-cloud-starter-alibaba-nacos-discovery

com.alibaba.csp

sentinel-datasource-nacos

com.alibaba.cloud

spring-cloud-starter-alibaba-sentinel

org.springframework.cloud

spring-cloud-starter-openfeign

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-starter-actuator

org.springframework.boot

spring-boot-devtools

runtime

true

cn.hutool

hutool-all

4.6.3

org.projectlombok

lombok

true

org.springframework.boot

spring-boot-starter-test

test

        application.yml 内容如下所示:

server:

port: 8401

spring:

application:

name: cloudalibaba-sentinel-service

cloud:

nacos:

discovery:

server-addr: localhost:8848 # Nacos服务注册中心地址

sentinel:

transport:

dashboard: localhost:8080 # 配置Sentinel dashboard地址

# 默认8719端口,假如被占用会自动从8719开始依次+1扫描,直至找到未被占用的端口

port: 8719

management:

endpoints:

web:

exposure:

include: '*'

        主启动类代码如下所示:

package com.springcloud;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@EnableDiscoveryClient

@SpringBootApplication

public class MainApp8401

{

public static void main(String[] args) {

SpringApplication.run(MainApp8401.class, args);

}

}

        业务类 controller 代码如下所示:

package com.springcloud.controller;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RestController;

@RestController

public class FlowLimitController {

@GetMapping("/testA")

public String testA(){

return "------testA";

}

@GetMapping("/testB")

public String testB(){

return "------testB";

}

}

4.3 启动测试

        启动我们刚才创建模块,并启动 Sentinel,打开 Sentinel 的管理界面,如下图:

        可以看到,什么都没有

4.4 懒加载机制

        Sentinel 采用的是懒加载机制,只有调用过该模块对外服务的接口,才能够在管理界面上进行显示,调用 http://localhost:8401/testA,再次刷新管理界面,如下图:

        可以看到 sentinel8080 正在监控微服务 8401。

精彩链接

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。

大家都在找:

spring cloud:spring cloud面试题