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

wordpress 页面归类手机网站怎么做seo

wordpress 页面归类,手机网站怎么做seo,wordpress添加用户注册登录界面,昆明学习网站建设目录 前言 kafka consumer 设计原理 多线程的方案 参考资料 前言 目前,计算机的硬件条件已经大大改善,即使是在普通的笔记本电脑上,多核都已经是标配了,更不用说专业的服务器了。如果跑在强劲服务器机器上的应用程序依然是单…

目录

前言

kafka consumer 设计原理

多线程的方案 

参考资料


前言

目前,计算机的硬件条件已经大大改善,即使是在普通的笔记本电脑上,多核都已经是标配了,更不用说专业的服务器了。如果跑在强劲服务器机器上的应用程序依然是单线程架构,那实在是有点暴殄天物了。不过,Kafka Java Consumer 就是单线程的设计,你是不是感到很惊讶。所以,探究它的多线程消费方案,就显得非常必要了。

kafka consumer 设计原理

 从 Kafka 0.10.1.0 版本开始,KafkaConsumer 就变为了双线程的设计,即用户主线程和心跳线程。

 所谓用户主线程,就是你启动 Consumer 应用程序 main 方法的那个线程,而新引入的心跳线程(Heartbeat Thread)只负责定期给对应的 Broker 机器发送心跳请求,以标识消费者应用的存活性(liveness)。引入这个心跳线程还有一个目的,那就是期望它能将心跳频率与主线程调用 KafkaConsumer.poll 方法的频率分开,从而解耦真实的消息处理逻辑与消费者组成员存活性管理。

 单线程的设计能够简化 Consumer 端的设计。Consumer 获取到消息后,处理消息的逻辑是否采用多线程,完全由你决定。这样,你就拥有了把消息处理的多线程管理策略从 Consumer 端代码中剥离的权利。

多线程的方案 

 我们要明确的是,KafkaConsumer 类不是线程安全的 (thread-safe)。所有的网络 I/O 处理都是发生在用户主线程中,因此,你在使用过程中必须要确保线程安全。简单来说,不能在多个线程中共享同一个 KafkaConsumer 实例,否则程序会抛出 ConcurrentModificationException 异常。

由于kafka consumer不是线程安全,我么你能制定两种多线程的方案。

1.消费者程序启动多个线程,每个线程维护专属的 KafkaConsumer 实例,负责完整的消息获取、消息处理流程。如下图所示:

 2.消费者程序使用单或多线程获取消息,同时创建多个消费线程执行消息处理逻辑。获取消息的线程可以是一个,也可以是多个,每个线程维护专属的 KafkaConsumer 实例,处理消息则交由特定的线程池来做,从而实现消息获取与消息处理的真正解耦。具体架构如下图所示:

我们来打个比方。比如一个完整的消费者应用程序要做的事情是 1、2、3、4、5,那么方案 1 的思路是粗粒度化的工作划分,也就是说方案 1 会创建多个线程,每个线程完整地执行 1、2、3、4、5,以实现并行处理的目标,它不会进一步分割具体的子任务;而方案 2 则更细粒度化,它会将 1、2 分割出来,用单线程(也可以是多线程)来做,对于 3、4、5,则用另外的多个线程来做。 

这两种方案的比较如下:

实现代码示例如下:

方案一的代码:

public class KafkaConsumerRunner implements Runnable {private final AtomicBoolean closed = new AtomicBoolean(false);private final KafkaConsumer consumer;public void run() {try {consumer.subscribe(Arrays.asList("topic"));while (!closed.get()) {ConsumerRecords records = consumer.poll(Duration.ofMillis(10000));//  执行消息处理逻辑}} catch (WakeupException e) {// Ignore exception if closingif (!closed.get()) throw e;} finally {consumer.close();}}// Shutdown hook which can be called from a separate threadpublic void shutdown() {closed.set(true);consumer.wakeup();}

这段代码创建了一个 Runnable 类,表示执行消费获取和消费处理的逻辑。每个 KafkaConsumerRunner 类都会创建一个专属的 KafkaConsumer 实例。在实际应用中,你可以创建多个 KafkaConsumerRunner 实例,并依次执行启动它们,以实现方案 1 的多线程架构

方案2 的代码:

private final KafkaConsumer<String, String> consumer;
private ExecutorService executors;
...private int workerNum = ...;
executors = new ThreadPoolExecutor(workerNum, workerNum, 0L, TimeUnit.MILLISECONDS,new ArrayBlockingQueue<>(1000), new ThreadPoolExecutor.CallerRunsPolicy());...
while (true)  {ConsumerRecords<String, String> records = consumer.poll(Duration.ofSeconds(1));for (final ConsumerRecord record : records) {executors.submit(new Worker(record));}
}
..

参考资料

20 | 多线程开发消费者实例-极客时间

http://www.yayakq.cn/news/608283/

相关文章:

  • 深圳网站推广优住房及城乡建设部信息中心网站
  • 制作一个简单的php网站二级学院网站建设自评报告
  • 厦门网站流量优化价格防止入侵网站
  • 唐河县住房和城乡建设局网站网站建设与管理自简历
  • 芜湖网站建设推广wordpress doaction
  • 怎么识别一个网站免费网站建设公司推荐
  • 微信官方微网站吗遵义房产信息网
  • 建设行政主管部门官方网站百度搜到自己的网站
  • 搜钛建站做网站4000-262-263
  • 如何才能做好品牌网站建设策划中国室内装饰设计网
  • 扬州网站建设文章高端建站用什么软件
  • 自己如何在家做网站做简历比较好的网站叫什么
  • 建设网站 关于竣工结算的期限网站建设招聘要求
  • 徐州集团网站建设流程适合女生的十大热门专业
  • 宁波网站设计服务网络优化师是什么工作
  • 手机网站设计模板在线做图的网站
  • 营销网站建设情况调查问卷企业官网网站模板下载
  • 东莞网络推广网站郑州免费网站制作
  • 做外贸的网站公司苏州推广排名
  • 安溪哪里有学做网站网站服务器哪个好
  • 网站被篡改处理广州哪里好玩的景点推荐
  • 网站建设的不足wordpress打不开仪表盘
  • 濮阳手机网站建设最新新闻有哪些
  • 做旅游网站的工作流程图wordpress用微信登录
  • asp 手机网站网站设计潮流
  • 网站更新维护 怎么做网站推广与维护有什么不同
  • 网页设计素材螺蛳粉图seo排名软件价格
  • 做外贸网站用哪些小语种小说网站建设方案
  • 栖霞建设官方网站免费拓客软件哪个好用
  • 做网站语言最好网站框架策划