当前位置: 首页 > news >正文

免费下载公众号网站品牌词如何优化

免费下载公众号,网站品牌词如何优化,网页文字游戏,wordpress 浮层目录 1. 事务核心组件 1.1 幂等性生产者#xff08;Idempotent Producer#xff09; 1.2 事务协调器#xff08;TransactionCoordinator#xff09; 1.3 事务日志#xff08;Transaction Log#xff09; 2. 事务执行流程 2.1 事务初始化 2.2 发送消息 2.3 事务提… 目录 1. 事务核心组件 1.1 幂等性生产者Idempotent Producer 1.2 事务协调器TransactionCoordinator 1.3 事务日志Transaction Log 2. 事务执行流程 2.1 事务初始化 2.2 发送消息 2.3 事务提交两阶段提交 2.4 事务完成 3. 消费者事务隔离 3.1 隔离级别 3.2 实现机制 4. 异常处理与容错 4.1 生产者宕机 4.2 协调器宕机 4.3 Broker宕机 5. 关键源码解析 5.1 事务协调器核心逻辑 5.2 两阶段提交实现 5.3 消费者过滤未提交消息 6. 事务配置与使用 6.1 生产者配置 6.2 消费者配置 7. 事务性能与限制 总结 幂等生产者通过ProducerID和SequenceNumber去重避免消息重复源码见ProducerStateManager。事务协调器TransactionCoordinator 每个事务绑定一个Coordinator处理BEGIN_TRANSACTION、COMMIT/ABORT请求。事务状态存储在内部Topic __transaction_state中通过TransactionStateManager管理。 两阶段提交 阶段1标记事务为“预提交”写入所有参与分区的数据。阶段2写入COMMIT标记到事务日志消费者仅可见已提交的事务消息。 Kafka事务机制通过幂等性生产者、事务协调器TransactionCoordinator 和 两阶段提交2PC 实现跨分区的原子性写入确保消息要么全部提交要么全部丢弃。以下是核心实现机制 1. 事务核心组件 1.1 幂等性生产者Idempotent Producer 作用确保单分区内消息不重复。实现机制 PIDProducer ID每个生产者实例唯一由Broker分配。Sequence Number每个消息的单调递增序列号Broker校验序列号连续性。源码类ProducerStateManager管理PID与序列号。 1.2 事务协调器TransactionCoordinator 作用管理事务生命周期协调事务提交或中止。实现机制 每个事务绑定一个协调器通过事务ID哈希选择Broker。维护事务状态机TransactionState存储在内部Topic __transaction_state。源码类TransactionCoordinator、TransactionStateManager。 1.3 事务日志Transaction Log 作用持久化事务状态防止协调器宕机后数据丢失。存储位置内部Topic __transaction_state每个分区对应一个协调器。数据格式事务ID、PID、状态PrepareCommit、Completed等、超时时间。 2. 事务执行流程 2.1 事务初始化 生产者初始化事务 调用initTransactions()向协调器注册事务ID获取PID。协调器在__transaction_state中记录事务元数据。 2.2 发送消息 发送事务消息 生产者发送消息时携带PID、序列号、事务ID。Broker将消息写入日志但标记为未提交对消费者不可见。 2.3 事务提交两阶段提交 阶段1Prepare Commit 生产者向协调器发送EndTxnRequest协调器将事务状态置为PrepareCommit并持久化到事务日志。阶段2Commit Markers写入 协调器向所有涉及的分区Leader发送WriteTxnMarkers请求Leader在日志中写入事务提交标记Control Batch。 2.4 事务完成 Broker将事务消息标记为已提交消费者可读取需配置isolation.levelread_committed。 3. 消费者事务隔离 3.1 隔离级别 read_committed仅消费已提交的事务消息跳过未提交的Control Batch。read_uncommitted消费所有消息默认模式不保证事务原子性。 3.2 实现机制 消费者在拉取消息时Broker根据隔离级别过滤未提交的事务消息。源码逻辑KafkaConsumer的fetcher模块解析Control Batch决定是否跳过消息。 4. 异常处理与容错 4.1 生产者宕机 事务超时transaction.timeout.ms协调器自动中止未完成的事务。新生产者实例需重新初始化事务旧事务状态由协调器清理。 4.2 协调器宕机 事务日志持久化在__transaction_state新协调器加载日志恢复状态。 4.3 Broker宕机 副本机制保证事务日志和消息日志的高可用Leader切换后继续处理事务。 5. 关键源码解析 5.1 事务协调器核心逻辑 //事务状态管理TransactionStateManager public class TransactionStateManager {// 持久化事务状态到__transaction_statedef appendTransactionToLog(transactionState: TransactionState): Unit {val records List(new SimpleRecord(transactionState.toBytes))transactionLog.append(records)} } 5.2 两阶段提交实现 // 协调器发送提交标记TransactionCoordinator private def sendTxnMarkers(transactionState: TransactionState): Unit { // 向所有分区Leader发送WriteTxnMarkersRequest transactionState.partitions.foreach { partition val request new WriteTxnMarkersRequest.Builder(partition, Commit)sendRequestToLeader(request)} } 5.3 消费者过滤未提交消息 // 消费者拉取消息过滤ConsumerFetcherThread private def filterCommittedMessages(records: ConsumerRecords): ConsumerRecords { if (isolationLevel IsolationLevel.READ_COMMITTED) {records.filter(_.controlBatchType ! ControlBatchType.ABORT) } else {records } } 6. 事务配置与使用 6.1 生产者配置 props.put(enable.idempotence, true); // 开启幂等性 props.put(transactional.id, my-tx-id); // 必须设置事务ID props.put(transaction.timeout.ms, 60000); // 事务超时时间 6.2 消费者配置 props.put(isolation.level, read_committed); // 仅消费已提交消息 7. 事务性能与限制 性能开销事务引入两阶段提交和日志持久化吞吐量下降约20%-30%。限制 事务仅支持单会话一个生产者实例。事务消息的消费者必须使用Kafka Consumer API不支持旧版基于ZooKeeper的消费者。 总结 Kafka事务通过以下机制实现跨分区的原子性 幂等性生产者避免单分区消息重复。事务协调器与两阶段提交确保所有分区要么全部提交要么全部回滚。事务日志持久化保障协调器故障恢复后状态一致。消费者隔离级别控制事务消息的可见性。 正确配置后Kafka事务可支持金融级场景的精确一次Exactly-Once语义
http://www.w-s-a.com/news/661809/

相关文章:

  • 小型网站搭建logo免费制作
  • dede 网站模板哈尔滨房产信息网官方网站
  • 设计师个人作品集模板班级优化大师网页版登录
  • 高端网站建设教学网站开发前期准备工作
  • 网站评论列表模板设计官网的
  • 怎么做可以访问网站ui设计自学学的出来吗
  • 网站如何接入支付宝软件开发工作内容描述
  • 廊坊网站建设搭建整合营销传播的效果表现为
  • 网站服务器在本地是指园林绿化
  • 公司网站建设需要什么科目网站代运营价格
  • 网站建设前的ER图ppt模板图片 背景
  • 做一个网站花多少钱网站导航营销步骤
  • 仙桃网站定制做房产网站能赚钱吗
  • 西安网站制作模板最新源码
  • 南京江宁网站建设大学高校网站建设栏目
  • 模板网站建设明细报价表做网站第一
  • 公司网站建设系统软件开发 上海
  • 怎么让公司建设网站固安县建设局网站
  • 360免费建站官网入口手机网站建设设计
  • 商城网站建站系统dw如何做网页
  • 网站建设的公司收费我有网站 怎么做淘宝推广的
  • 网站建设策划书事物选题手机兼职app
  • html5 微网站模版wordpress博客速度很慢
  • 怎么做五个页面网站网络推广如何收费
  • 上虞宇普电器网站建设江西建筑人才网
  • 在吗做网站商城一个网站需要服务器吗
  • 先做网站再备案吗中山微网站建设报价
  • 树莓派可以做网站的服务器吗网站建设与设计ppt
  • 网站访问速度分析网站怎么做让PC和手机自动识别
  • 网站建设要考西宁网站建设多少钱