首页
统计
关于
Search
1
Sealos3.0离线部署K8s集群
1,085 阅读
2
类的加载
742 阅读
3
Spring Cloud OAuth2.0
726 阅读
4
SpringBoot自动装配原理
691 阅读
5
集合不安全问题
586 阅读
笔记
Java
多线程
注解和反射
JVM
JUC
设计模式
Mybatis
Spring
SpringMVC
SpringBoot
MyBatis-Plus
Elastic Search
微服务
Dubbo
Zookeeper
SpringCloud
Nacos
Sentinel
数据库
MySQL
Oracle
PostgreSQL
Redis
MongoDB
工作流
Activiti7
Camunda
消息队列
RabbitMQ
前端
HTML5
CSS
CSS3
JavaScript
jQuery
Vue2
Vue3
Linux
容器
Docker
Kubernetes
Python
FastApi
登录
Search
标签搜索
Java
CSS
mysql
RabbitMQ
JavaScript
Redis
JVM
Mybatis-Plus
Camunda
多线程
CSS3
Python
Spring Cloud
注解和反射
Activiti
工作流
SpringBoot
Mybatis
Spring
html5
蘇阿細
累计撰写
389
篇文章
累计收到
4
条评论
首页
栏目
笔记
Java
多线程
注解和反射
JVM
JUC
设计模式
Mybatis
Spring
SpringMVC
SpringBoot
MyBatis-Plus
Elastic Search
微服务
Dubbo
Zookeeper
SpringCloud
Nacos
Sentinel
数据库
MySQL
Oracle
PostgreSQL
Redis
MongoDB
工作流
Activiti7
Camunda
消息队列
RabbitMQ
前端
HTML5
CSS
CSS3
JavaScript
jQuery
Vue2
Vue3
Linux
容器
Docker
Kubernetes
Python
FastApi
页面
统计
关于
搜索到
31
篇与
的结果
2021-04-29
热点规则
热点规则:很多时候我们希望统计数据中访问次数最高的数据,并对其访问进行限制热点参数限流会统计传入参数中的热点参数,并根据配置的限流阈值和模式,对包含热点参数的资源调用进行限流(该策略仅对包含热点参数的资源生效)。1、测试:新增测试方法,并自定义降级方法测试结果:带参数p1访问/testHotKey,且每秒钟的请求次数触发了限流规则不带热点参数访问:2、设置热点规则的其他选项测试:测试结果:图片来源:尚硅谷 - 周阳 - Spring Cloud Alibaba
2021年04月29日
54 阅读
0 评论
0 点赞
2021-04-29
降级规则
Sentinel熔断降级会在调用链路中某个资源出现不稳定状态时(超时或异常),对这个资源的调用进行限制,让请求快速失败,避免影响到其它资源而导致级联错误。 当资源被降级后,在接下来的降级时间窗口内,对该资源的调用都会自动熔断(默认抛出DegradeException异常)。参数说明:RT(平均响应时间,秒级):平均响应时间超出阈值==且==在时间窗口内通过的请求 >= 5,两个条件同时满足后,进行服务降级,时间窗口期过后,关闭断路器RT最大4900ms(更大的值需通过-Dcsp.sentinel.statistic.max.rt=xxx设置)异常比例(秒级):QPS >= 5 ==且==异常比例([0.01-1.0])超过阈值,触发降级,时间窗口结束后,关闭断路器异常数(分钟级):异常数超过阈值时,触发降级,时间窗口结束后,关闭断路器1、RT平均响应时间Sentinel默认设置为1秒5次请求。一秒钟进入5个请求,且平均响应时间超过设置的200ms,就触发降级Jmeter压力测试:新增一个测试方法:2、异常比例 当资源的每秒请求量 >= 5,并且每秒异常总数占总通过请求数的比值超过设置的阈值,触发熔断降级,异常比例阈值范围:[0.01-1.0]测试:修改刚才新增的/testD测试方法设置降级规则:未触发降级的返回结果:触发降级的返回结果:3、异常数 当请求的资源近1分钟的异常数目超过阈值之后,会进行熔断。由于统计时间窗口是分钟级的,如果timeWindow(时间窗口期)小于60s,结束熔断后可能会再次进入熔断状态。
2021年04月29日
129 阅读
0 评论
0 点赞
2021-04-29
Sentinel流控规则
参数说明:资源名:唯一名称,默认请求路径针对来源:Sentinel可以针对调用者进行限流,可以写微服务名,默认为default(不区分来源)阈值类型/单机阈值QPS:每秒钟的请求数量,当调用该API的QPS达到阈值时,进行限流线程数:当调用该API的线程数达到阈值时,进行限流是否集群:否(不打勾即代表否)流控模式:直接:API调用达到限流条件时,直接限流关联:B关联A,B的调用达到阈值时,限流A(避免级联故障)链路:只记录指定链路上的流量(指定资源从入口资源进来的流量,达到阈值时,进行限流)流控效果:快速失败:直接失败,抛异常Warm up:根据codeFactor(冷加载因子,默认为3)的值,从阈值/codeFactor,经过预热时长,才达到设置的QPS阈值1、流控模式直接快速失败测试结果:线程数当请求/testA的线程数超过了设置的阈值,就会进行限流关联当/testA的请求达到阈值,就会对/testB的请求进行限流链路多个请求调用同一个微服务2、流控效果Warm Up预热/冷启动:当系统长期处于低请求的状态下,这时流量突然增加,瞬间大量的请求可能会把系统压垮。通过Warm Up让请求缓慢增加,在一定时间内增长到设置的阈值上限,给冷系统一个预热准备的时间,避免出现故障排队等待图片来源:尚硅谷 - 周阳 - Spring Cloud Alibaba
2021年04月29日
41 阅读
0 评论
0 点赞
2021-04-29
Sentinel
一、安装1、下载sentinel地址:https://github.com/alibaba/Sentinel2、运行java -jar sentinel-dashboard-1.8.1.jar3、注意事项sentinel默认8080端口,需注意端口冲突的问题二、微服务整合Sentinel1、启动Nacoswindows环境或Linux环境下启动startup.cmd或startup.sh2、新建Sentinel8401模块pom<!-- API 通用pom根据自己情况而定--> <dependency> <groupId>com.sw</groupId> <artifactId>cloud-api-commons</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <!-- Nacos --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- sentinel --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency> <!-- openfign --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <!-- lombok --> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency>ymlserver: port: 8401 spring: application: name: cloud-alibaba-sentinel-service cloud: nacos: discovery: server-addr: localhost:8848 sentinel: transport: # sentinel dashboard地址 dashboard: localhost:8080 # 默认8719端口,如果8719被占用,默认递增 port: 8719 management: endpoints: web: exposure: include: '*'启动类@SpringBootApplication @EnableDiscoveryClient public class MainApp8401 { public static void main(String[] args) { SpringApplication.run(MainApp8401.class, args); } } controller@Slf4j @RestController public class FlowLimitController { @GetMapping("/testa") public String testA() { return "-----testA------"; } @GetMapping("/testb") public String testB() { log.info(Thread.currentThread().getName() + "\t" + "处理了/testb请求!"); return "-----testB------"; } }3、启动测试Sentinel默认的账号密码都是sentinel因为sentinel是懒加载机制,所以需先完成一次请求,才能在sentinel控制面板看到簇点链路
2021年04月29日
204 阅读
0 评论
0 点赞
2021-04-29
Nacos集群和持久化配置
Nacos默认使用嵌入式数据库实现数据存储,如果启动多个默认配置下的nacos节点,则存在数据一致性问题,为了解决这个问题,Nacos采用集中式存储来支持集群化部署,目前仅支持MySQl。三种部署方式单机 - 用于测试和单机试用集群 - 生产环境,确保高可用多集群 - 多用于数据中心等场景1、单机版1、在MySQl新建nacos_config数据库;2、运行conf文件夹下的nacos-mysql.sql,导入数据;3、修改conf文件夹下的application.properties,末尾添加以下内容,将数据库改为MySQlspring.datasource.platform=mysql db.num=1 db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true db.user=root db.password=1234564、重启startup.cmd(nacos)之后,数据源就改为了自己的2、集群以Nginx作为vip,三个nacos节点为例1、下载Linux版Nacos2、新建nacos_config数据库3、修改数据源(同理单机版配置)4、修改cluster.conf,进去conf文件夹,执行以下命令,备份原文件cp cluster.conf.example cluster.conf运行hostname -i,查看主机名,此处以127.0.0.1为例(实际需替换为自己linux服务器执行hostname -i命令后的结果)在cluster.conf文件中添加127.0.0.1:3333 127.0.0.1:4444 127.0.0.1:55555、修改/bin/startup.sh文件在nohup $JAVA这一行添加-Dserver.port=${PORT}nohup $JAVA -Dserver.port=${PORT} ${JAVA_OPT} nacos.nacos >> ${BASE_DIR}/logs/start.out 2>&1 &注:新版的Nacos 2.0.0不需要添加case中的PORT,已自带# 为了方便使用,将2.0.0版本中的 EMBEDDED_STORAGE 改为了PORT while getopts ":m:f:s:c:p:" opt do case $opt in m) MODE=$OPTARG;; f) FUNCTION_MODE=$OPTARG;; s) SERVER=$OPTARG;; c) MEMBER_LIST=$OPTARG;; p) EMBEDDED_STORAGE=$OPTARG;; ?) echo "Unknown parameter" exit 1;; esac done6、Nginx配置# 通过1111端口反代三个Nginx集群 upstream cluster{ server 127.0.0.1:3333; server 127.0.0.1:4444; server 127.0.0.1:5555; } server { listen 1111; listen [::]:80 default_server; server_name localhost; #root /usr/share/nginx/html; # Load configuration files for the default server block. #include /etc/nginx/default.d/*.conf; location / { proxy_pass http://cluster; } 7、启动# 先启动Nacos节点 ./startup.sh -p 3333 ./startup.sh -p 4444 ./startup.sh -p 5555 # 再启动Nginx systemctl start nginx8、访问x.x.x.x:1111测试Nacos集群9、将微服务注册到Nacos集群修改yml配置文件的注册地址即可server: port: 9001 spring: application: name: nacos-payment-provider cloud: nacos: discovery: server-addr: x.x.x.x:1111 # Nginx反代的地址 management: endpoints: web: exposure: include: '*'
2021年04月29日
203 阅读
0 评论
0 点赞
2021-04-29
Nacos配置中心
使用nacos作为配置中心,在项目初始化时,要保证先从配置中心进行配置拉取,才能保证项目的正常启动1、创建配置中心模块pom<!-- Nacos discovery --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- Nacos config --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency>bootstarp.ymlserver: port: 3344 spring: application: name: nacos-config-client cloud: nacos: discovery: server-addr: localhost:8848 config: server-addr: localhost:8848 file-extension: yaml # 指定配置文件为yaml格式 group: DEV_GROUP namespace: a06b3fe5-5be9-4e82-a56d-168afa4de85b # DataId格式 # ${spring.application.name}-${spring.profile.active}-${spring.cloud.nacos.config.file-extension} # nacos-config-client-dev.yamlapplication.ymlspring: profiles: #active: info #active: test active: dev启动类@SpringBootApplication @EnableDiscoveryClient public class NacosConfigClientMain3344 { public static void main(String[] args) { SpringApplication.run(NacosConfigClientMain3344.class, args); } }controller@RestController @RequestMapping("/config") @RefreshScope //支持Nacos的动态刷新 public class ConfigController { @Value("${config.info}") private String configInfo; @GetMapping("/info") public String getConfigInfo(){ return configInfo; } } 2、Nacos配置规则配置规则:即在客户端指定如何读取配置文件以及配置文件的命名规则默认命名规则:${prefix}-${spring.profile.active}.${file-extension} # prefix # 当前服务名称,也可以通过spring.cloud.nacos.config.prefix获取 # spring.profile.active # 当前指定的开发环境 # file-extension # 当前文件的格式,目前只支持yaml和properties注:DataId配置文件名必须遵循配置规则中的命名方式图片来源:尚硅谷 - 周阳 - Spring Cloud Alibaba补充nacos默认开启了自动刷新,更改配置文件,客户端读取的配置信息也随之改变(Nacos支持Bus消息总线,会自动发送命令更新信息)3、配置分类Namespace + Group + DataId1、配置不同的DataId# 通过yml配置读取指定的配置文件 spring: profiles: #active: info #active: test active: dev2、配置不同的GroupId3、配置不同的Namespace# 客户端yml配置不同的namespace server: port: 3344 spring: application: name: nacos-config-client cloud: nacos: discovery: server-addr: localhost:8848 config: server-addr: localhost:8848 file-extension: yaml # 指定配置文件为yaml格式 group: DEV_GROUP namespace: a06b3fe5-5be9-4e82-a56d-168afa4de85b
2021年04月29日
84 阅读
0 评论
0 点赞
2021-04-29
Nacos CP、AP模式的选择
CP、AP模式选择1、如果不需要存储服务器级别的信息且服务实例通过nacos-client注册,并且能够保持心跳上报,就可以选择AP模式。AP模式为了可用性而减弱了一致性,因此AP模式下只支持注册临时实例2、如果需要在服务器级别编辑或存储配置信息,必须选CP模式(K8s和DNS服务适用于CP模式)。CP模式下支持注册持久化实例,此时是以Raft协议为集群运行模式,该模式下注册实例前必须先注册服务,如果服务不存在,则返回错误。切换模式curl -X PUT '$NACOS_SERVER:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP'
2021年04月29日
278 阅读
0 评论
0 点赞
2021-04-29
Nacos与其他注册中心对比
Nacos与其他注册中心对比 NacosEurekaConsulCoreDNSZookeeper一致性协议CP + APAPCP/CP健康检查TCP/HTTP/MySQL/Client BeatClient BeatTCP/HTTP/gRPC/Cmd/Client Beat负载均衡权重/DSL/metadata/CMDBRibbonFabioRR/雪崩保护支持支持不支持不支持不支持自动注销实例支持支持不支持不支持支持访问协议HTTP/DNS/UDPHTTPHTTP/DNSDNSTCP监听支持支持支持不支持支持多数据中心支持支持支持不支持不支持跨注册中心支持不支持支持不支持不支持Spring Cloud集成支持支持支持不支持不支持Dubbo集成支持不支持不支持不支持支持K8s集成支持不支持支持支持不支持
2021年04月29日
203 阅读
0 评论
0 点赞
1
2
3
4