首页
统计
关于
Search
1
Sealos3.0离线部署K8s集群
1,101 阅读
2
类的加载
748 阅读
3
Spring Cloud OAuth2.0
729 阅读
4
SpringBoot自动装配原理
695 阅读
5
集合不安全问题
591 阅读
笔记
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
蘇阿細
累计撰写
392
篇文章
累计收到
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
页面
统计
关于
搜索到
392
篇与
的结果
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日
281 阅读
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日
206 阅读
0 评论
0 点赞
2021-04-29
Nacos
服务注册和配置中心的组合:Nacos = Eureka + config + bus一、安装1、环境:java8、Mavennacos地址:https://github.com/alibaba/nacos2、启动# 注:单机启动,需修改bin目录下的startup.cmd为`standalone`模式 set MODE="standalone" set FUNCTION_MODE="all" set SERVER=nacos-server set MODE_INDEX=-1 set FUNCTION_MODE_INDEX=-1 set SERVER_INDEX=-1 set EMBEDDED_STORAGE_INDEX=-1 set EMBEDDED_STORAGE=""windows环境下,双击startup.cmd启动3、访问Nacos# nacos默认监听8848 # 默认账号:nacos,密码:nacos localhost:8848二、测试1、payment模块新建cloudalibaba-provider-payment9001、cloudalibaba-provider-payment9002两个模块pom<!-- Nacos --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</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>ymlserver: port: 9001 spring: application: name: nacos-payment-provider cloud: nacos: discovery: server-addr: localhost:8848 management: endpoints: web: exposure: include: '*'主启动类@SpringBootApplication @EnableDiscoveryClient public class PaymentMain9001 { public static void main(String[] args) { SpringApplication.run(PaymentMain9001.class, args); } }controller@RestController @RequestMapping("/payment") public class PaymentController { @Value("${server.port}") private String serverPort; @GetMapping("/nacos/{id}") public String getPayment(@PathVariable("id")int id){ return "nacos registry, serverPort: " + serverPort + "\t id: " + id; } }2、order模块pom同理paymentymlserver: port: 8088 spring: application: name: nacos-payment-consumer cloud: nacos: discovery: server-addr: localhost:8848 # 消费者将要去访问的微服务名称(注册进nacos的服务提供者) service-url: nacos-user-service: http://nacos-payment-provider主启动类@SpringBootApplication @EnableDiscoveryClient public class ConsumerMain80 { public static void main(String[] args) { SpringApplication.run(ConsumerMain80.class, args); } }config@Configuration public class ApplicationContextConfig { @Bean @LoadBalanced public RestTemplate getRestTemplate(){ return new RestTemplate(); } }controller@RestController @RequestMapping("/consumer") public class ConsumerController { @Autowired private RestTemplate restTemplate; @Value("${service-url.nacos-user-service}") private String serverURL; @GetMapping("/payment/nacos/{id}") public String paymentInfo(@PathVariable("id")int id){ return restTemplate.getForObject(serverURL + "/payment/nacos/" + id, String.class); } }
2021年04月29日
114 阅读
0 评论
0 点赞
2021-04-29
Spring Cloud Stream
一、概述 Spring Cloud Stream 是一个构建消息驱动微服务的框架,应用程序通过inputs(生产者)或outputs(消费者)来与Spring Cloud Stream中binder对象交互,binder主要负责与消息中间件交互(开发人员只需操作Stream,而不用关心底层使用的是什么MQ)。注:目前仅支持RabbitMQ和kafka二、如何屏蔽底层差异在没有绑定器这个概念的情况下,SpringBoot应用在直接与消息中间件交互的时候,由于各MQ的设计初衷有不同,细节上存在较大的差异。通过定义绑定器作为中间层,完美的实现了应用程序与消息中间件细节之间的隔离;通过向应用程序暴露统一的channel频道,使得应用程序不需要再考虑各种MQ的实现。Stream对消息中间件的进一步封装,可以做到代码层面对中间件的无感知,甚至于动态的切换中间件(RabbitMQ<==>kafka),使得开发高度解耦,更加专注于自己的业务流程。Spring Cloud Stream处理架构三、通信模式Stream消息通信遵循发布-订阅模式Spring Cloud Stream的业务流程source:发布消息sink:接收消息图片来源:尚硅谷 - 周阳 - Spring Cloud Alibaba四、常用注解和API名称说明Middleware中间件Binder应用与消息中间件之间的封装,目前实现了RabbitMQ和Kafka的Binder,利用Binder可以很方便的连接MQ,可以动态的改变消息类型(RabbitMQ--exchange,Kafaka--topic),可以通过yml文件的配置来实现@Input输入@Output输出@StreamListener监听队列@EnableBinding绑定频道五、测试实例1、提供者pom<!-- stream rabbitmq --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-stream-rabbit</artifactId> </dependency> <!-- Eureka-client --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</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>ymlserver: port: 8801 spring: application: name: cloud-stream-provider rabbitmq: host: x.x.x.x port: 5672 username: admin password: 123456 cloud: stream: binders: # 配置要绑定的rabbitmq的服务信息 defaultRabbit: # 定义的名称,用于binding整合 type: rabbit # 消息组件类型 bindings: # 服务整合处理 output: # 通道名称 destination: StreamExChange # 交换机的名字 content-type: application/json # 消息类型 binder: defaultRabbit # 设置要绑定的消息服务的具体设置 eureka: client: service-url: defaultZone: http://localhost:7001/eureka instance: lease-renewal-interval-in-seconds: 2 # 心跳时间间隔 lease-expiration-duration-in-seconds: 5 # 默认90s instance-id: send-8801.com # 在信息列表显示主机名称 prefer-ip-address: true # 访问路径显示ip 主启动类@SpringBootApplication public class StreamMQMain8801 { public static void main(String[] args) { SpringApplication.run(StreamMQMain8801.class, args); } }Service@EnableBinding(Source.class) //定义消息的推送通道 public class MessageProviderImpl implements MessageProvider { @Autowired private MessageChannel output; @Override public String send() { String serial = UUID.randomUUID().toString(); output.send(MessageBuilder.withPayload(serial).build()); System.out.println("======>" + serial); return null; } }controller@RestController public class SendMessageController { @Autowired private MessageProvider service; @GetMapping("/send") public String sendMessage(){ return service.send(); } }2、消费者==创建8802、8803两个消费者==pom同理消费者ymlserver: port: 8802 spring: application: name: cloud-stream-consumer rabbitmq: host: x.x.x.x port: 5672 username: admin password: 123456 cloud: stream: binders: # 配置要绑定的rabbitmq的服务信息 defaultRabbit: # 定义的名称,用于binding整合 type: rabbit # 消息组件类型 bindings: # 服务整合处理 input: # 通道名称 destination: StreamExChange # 交换机的名字 content-type: application/json # 消息类型 binder: defaultRabbit # 设置要绑定的消息服务的具体设置 group: GroupA8802 eureka: client: service-url: defaultZone: http://localhost:7001/eureka instance: lease-renewal-interval-in-seconds: 2 # 心跳时间间隔 lease-expiration-duration-in-seconds: 5 # 默认90s instance-id: recive-8802.com # 在信息列表显示主机名称 prefer-ip-address: true # 访问路径显示ip 启动类@SpringBootApplication public class StreamMQMain8802 { public static void main(String[] args) { SpringApplication.run(StreamMQMain8802.class, args); } }controller@Component @EnableBinding(Sink.class) public class ReciveController { @Value("${server.port}") private String serverPort; @StreamListener(Sink.INPUT) public void input(Message<String> msg){ System.out.println("消费者8802,接收到消息:" + msg.getPayload() + "\t serverPort:" + serverPort); } }六、重复消费的问题启动以上的测试实例,会发现8801生产者发送一条消息,8802、8803都收到了消息如何解决?通过将消费者分组来解决:即将原先GroupA8802、GroupA8803两个分组改为同一个分组GroupA注:在同一个分组中,多个消费者是竞争关系,这样就能保证消息只会被分组中的一个消费者消费server: port: 8802 spring: application: name: cloud-stream-consumer rabbitmq: host: x.x.x.x port: 5672 username: admin password: 123456 cloud: stream: binders: # 配置要绑定的rabbitmq的服务信息 defaultRabbit: # 定义的名称,用于binding整合 type: rabbit # 消息组件类型 bindings: # 服务整合处理 input: # 通道名称 destination: StreamExChange # 交换机的名字 content-type: application/json # 消息类型 binder: defaultRabbit # 设置要绑定的消息服务的具体设置 group: GroupA eureka: client: service-url: defaultZone: http://localhost:7001/eureka instance: lease-renewal-interval-in-seconds: 2 # 心跳时间间隔 lease-expiration-duration-in-seconds: 5 # 默认90s instance-id: recive-8802.com # 在信息列表显示主机名称 prefer-ip-address: true # 访问路径显示ip消息持久化问题在分组解决重复消费的问题是,分组同时也实现了消息的持久化
2021年04月29日
52 阅读
0 评论
0 点赞
2021-04-24
Sleuth分布式链路
Spring Cloud Sleuth提供了一套完整的服务跟踪解决方案,并且兼容支持zipkinTrace Id链路关系图片来源:尚硅谷-周阳 Spring CLoud AlibabaTrace:类似于树结构的span集合,表示一条调用链路,存在唯一标识span:表示调用链路来源(也就是一次请求信息)测试
2021年04月24日
38 阅读
0 评论
0 点赞
2021-04-24
Bus消息总线
一、概述在微服务架构的系统中,通常会使用轻量级的消息代理来构建一个共用的消息主题,并让系统中所有微服务实例都连接上来。由于该主题中产生的消息会被所有实例监听和消费,所以称它为消息总线.二、基本原理ConfigClient实例都监听MQ中同一个topic(默认Spring Cloud Bus),当一个服务刷新数据的时候,它会把这个消息放到topic中,这样其他监听同一个topic的服务就能收到通知,然后去更新自身的配置。三、流程四、手动定点刷新curl -X POSt "http://localhost:3344/actuator/bus-refresh/config-client:3355"五、通过分组解决消息重复消费的问题图片来源:尚硅谷-周阳 Spring CLoud Alibaba注:通过分组解决消息重复消费的同时,也实现了消息持久化
2021年04月24日
51 阅读
0 评论
0 点赞
2021-04-23
Gateway
一、概述Spring Cloud GateWay作为Spring Cloud生态系统中的网关,目的是代替zuul。其基于WebFlux框架,底层使用高性能的Reactor模式的通信框架Netty。提供统一的路由方式且基于Filter链的方式提供网关的基本功能,如:安全、监控/指标、限流等。二、特性1、基于Spring Framework 5,Project Reactor,SpringBoot 2.0进行构建2、动态路由:能够匹配任何请求属性3、可以对路由指定Predicates(断言)和Filter(过滤器)4、集成Hystrix的断路器功能5、集成SpringCloud服务发现功能6、请求限流7、路径重写……三、三个概念1、Route(路由)路由是构建网关的基本模块,由ID、目标URI和一系列的断言、过滤器组成,如果断言为true则匹配该路由2、Predicates(断言)匹配Http请求中的所有内容(请求头或请求参数等)3、Filter(过滤)指Spring框架中GatewayFilter的实例,使用过滤时,可以在请求被路由之前或之后对请求做出修改四、工作流程客户端向Spring Cloud GateWay发出请求,然后在Gateway Handler Mapping中找到与请求相匹配的路由,将其发送到Gateway Web Handler;Handler再通过指定的过滤器链将请求发送到实际的执行业务逻辑,然后返回(过滤器可能会在发送代理请求之前(pre)或之后(post)执行业务逻辑);Filter在“pre”类型的过滤器可以做参数校验、权限校验、流量监控、日志输出、协议转换等;在“post”类型的过滤器可以做内容响应、响应头的修改,日志的输出、流量监控等功能Predicates cookies路由规则HeaderHostMethodQuery图片来源:尚硅谷-周阳 Spring CLoud Alibaba
2021年04月23日
44 阅读
0 评论
0 点赞
2021-04-18
分布式事务
一、概述指事务的操作位于不同的节点上,需要保证事务的ACID原则,如:订单与库存不在同一个节点上,但需要保证两个事务的一致性(下单—减少库存,取消订单—库存恢复)二、实现分布式事务的方式1、两段提交(2PC)需要数据库厂商的支持,java组件有atomikos等两阶段提交(Two-phase Commit),通过引入协调者(Coordinator)来协调参与者的行为,并最终决定这些参与者是否要真正执行事务准备阶段协调者询问参与者事务是否执行成功,参与者返执行回结果提交阶段如果事务在每个参与者上都执行成功,事务协调者发送通知让参与者提交事务;否则反之,即回滚事务注:参与者在准备阶段执行成功,但未提交事务,只有在提交阶段收到协调者的消息,才会执行提交或回滚存在的问题1、同步阻塞,所有参与者在等待其他参与者相应的时候都处于同步阻塞状态,无法进行其他操作2、单点问题,协调者在2PC中起到非常大的作用,产生故障时影响也非常大3、数据不一致,在阶段二,如果协调者只发送了部分Commit消息,此时如果产生网络异常,则只有接收到Commit消息的参与者提交了事务,使得数据不一致4、任意一个节点失败,就会导致整个事务失败,容错机制不完善2、补偿事务(TCC)针对每个操作,都注册一个与其对应的确认和补偿(撤销)操作,分为三个阶段:Try 对业务系统做检测及资源预留Confirm 对业务系统做确认提交,Try阶段执行成功并开始执行Confirm阶段时,默认Confirm阶段是不会出错的(只要Try成功,Confirm一定成功)Cancel 在业务执行错误,需要回滚时执行业务的取消,释放预留资源优缺点实现流程相较于2PC简单,但数据一致性比2PC要更差一些TCC属于应用层的一种补偿方式,所以在实现业务的时候需要编写很多的补偿代码,在一些业务场景中,业务处理不太友好3、本地消息表(异步确保)本地消息表与业务数据表处于同一个数据库中,这样就能利用本地事务来保证在对这两个表的操作满足事务特性,并且使用消息队列保证最终一致性。在分布式事务操作的一方完成写业务数据的操作之后向本地消息表发送一个消息,本地事务能保证这个消息一定会被写入本地消息表中之后将本地消息表的消息转发到Kafka等消息队列中,如果转发成功则将消息从本地消息表中删除,否则继续重新转发在分布式事务操作的另一方从消息队列中读取一个消息,并执行消息中的操作优缺点1、避免了分布式事务,实现数据一致性2、消息表会耦合到业务系统中,耦合度太高4、MQ事务消息一些第三方的MQ是支持事务消息的,如RocketMQ,它们支持事务的方式类似于二阶段提交,流程大致为:第一阶段:Prepared消息,拿到消息的地址;第二阶段:执行本地事务;第三阶段:通过第一阶段拿到的地址去访问消息,并修改状态也就是说在业务方法内要让消息队列提交两次请求,一次发送消息,一次确认消息。如果确认消息发送失败了,RabbitMQ会定期扫描消息集群中的事务消息,这时候发现了Prepared消息,它会向消息发送者确认,所以生产方需要实现一个check接口,RabbitMQ会根据发送端设置的策略来决定回滚还是继续发送确认消息,这样就保证了消息发送与本地事务同时成功或同时失败优缺点1、实现最终一致性,不需要依赖本地数据库事务2、实现难度大,主流MQ不支持
2021年04月18日
59 阅读
0 评论
0 点赞
1
...
22
23
24
...
49