Kafka初探

场景->需求->解决方案->应用->原理

我该如何去设计消息中间件--借鉴/完善

场景

跨进程通信(进程间生产消费模型)

需求

基本需求
  • 实现消息的发送和接收。

    NIO通信 (序列化/反序列化)--dubbo、avro、protobuf、zk(jute)

  • 实现消息的存储(持久化/非持久化)

    数据库存储、文件存储(磁盘:顺序读写、页缓存、持久化的时机(落盘策略)、零拷贝)、内存

  • 是否支持跨语言(多语言生态)

  • 消息的确认(确认机制)--在跨进程通信中 ->业务逻辑需求

  • 是否支持集群

    自己实现选举、第三方的实现(zk)

高级需求
  • 是否支持有序(业务逻辑)

  • 是否支持事务消息(业务逻辑)->最终一致性

  • 是否支持高并发和大数据的存储

  • 是否支持可靠性存储

  • 是否支持多协议

  • 是否收费

发展

pub/sub--金融领域--TIB(规则)

非个性化需求, 而是共性化需求

IBM websphere mq(商业)

JMS协议->Java api->AMQP(通用性)

kafka
  1. 起源:LinkedIn 活动流 运营数据 诞生之初就是为了解决大数据量的问题

  2. 简介

    实现语言:scala

  3. 架构图 

  4. 下载及安装

    单节点安装:

    sudo wget http://mirrors.tuna.tsinghua.edu.cn/apache/kafka/2.3.0/kafka_2.11-2.3.0.tgz

    注意點:

    • 必须安装zk(启动时必须先启动zk),详情请参考

      https://www.cnblogs.com/java333/p/11107166.html

    • 远程安装 必须修改一下两个属性

      #本机ip
      listeners=PLAINTEXT://‘本机ip’:9092
      #zk地址
      zookeeper.connect=localhost:2181
    • 启动命令

    sh kafka-server-start.sh -daemon server.properties

    集群安装:

    • 多机器部署

      • 下载安装同单机,主要修改配置文件server.properties文件配置

      #zookeeper地址(三个节点相同)
      zookeeper.connect=192.168.1.11:2181
      #broker.id(三个节点分别为0、1、2)
      broker.id=1
      ##监听协议(三个节点配置各自的ip地址)
      listeners=PLAINTEXT://192.168.1.12:9092

    • 伪集群部署

      在单节点创建文件目录进行设置。参考上述多机器部署。

  5. 基本操作

     

    ##创建topic--创建成功后可以在zk客户端看到此消息
    sh kafka-topics.sh --create --zookeeper 192.168.1.11:2181 -replication-factor 1 --partitions 1 --topic test
    ##消费监听消息
    sh kafka-console-consumer.sh --bootstrap-server 192.168.1.11:9092 --topic test --from-beginning
    ##生产消息
    sh kafka-console-producer.sh --broker-list 192.168.1.11:9092 --topic test

消息中间件的应用场景

不同的业务领域,异步,解耦,削峰

  1. 注册新用户(用户中心)

    ->发送理财金/优惠券;为了增加复购->赠送一些优惠券(营销服务)

  2. 秒杀场景(流量大,商品少)

分布式消息中间件之kafka设计思想及基本介绍(一)的更多相关文章

  1. AI框架精要:设计思想

    AI框架精要:设计思想 本文主要介绍飞桨paddle平台的底层设计思想,可以帮助用户理解飞桨paddle框架的运作过程,以便于在实际业务需求中,更好的完成模型代码编写与调试及飞桨paddle框架的二次 ...

  2. 分布式系列九: kafka

    分布式系列九: kafka概念 官网上的介绍是kafka是apache的一种分布式流处理平台. 最初由Linkedin开发, 使用Scala编写. 具有高性能,高吞吐量的特定. 包含三个关键能力: 发 ...

  3. Kafka/Metaq设计思想学习笔记 转

    转载自: http://my.oschina.net/geecoodeer/blog/194829 本文没有特意区分它们之间的区别,仅仅是列出其中笔者认为好的设计思想,供后续设计参考. 目前笔者并没有 ...

  4. Kafka详解四:Kafka的设计思想、理念

    问题导读 1.Kafka的设计基本思想是什么?2.Kafka消息转运过程中是如何确保消息的可靠性的? 本节主要从整体角度介绍Kafka的设计思想,其中的每个理念都可以深入研究,以后我可能会发专题文章做 ...

  5. kafka具体解释四:Kafka的设计思想、理念

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/suifeng3051/article/details/37606001      本节主要从总体角度 ...

  6. 从一般分布式设计看HDFS设计思想与架构

     要想深入学习HDFS就要先了解其设计思想和架构,这样才能继续深入使用HDFS或者深入研究源代码.懂得了"所以然"才能在实际使用中灵活运用.快速解决遇到的问题.下面这篇博文我们就先 ...

  7. Kafka 设计与原理详解

    一.Kafka简介 本文综合了我之前写的kafka相关文章,可作为一个全面了解学习kafka的培训学习资料. 转载请注明出处 : 本文链接 1.1 背景历史 当今社会各种应用系统诸如商业.社交.搜索. ...

  8. kafka之二:Kafka 设计与原理详解

    一.Kafka简介 本文综合了我之前写的kafka相关文章,可作为一个全面了解学习kafka的培训学习资料. 转载请注明出处 : 本文链接 1.1 背景历史 当今社会各种应用系统诸如商业.社交.搜索. ...

  9. [转载] 360分布式存储系统Bada的设计和应用

    原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=208931479&idx=1&sn=1dc6ea4fa28a ...

随机推荐

  1. Linux系统管理_主题01 :初识Linux_1.5 与Linux进行交互_echo_nano_Tab_whoami

    [root@izkfv3zmvcl0omz ~]# 其中,'root'为登录用户名,'izkfv3zmvcl0omz'为登录主机名,’~’ 表示当前用户正处在 root 用户的 家目录中,’#’则表示 ...

  2. 在spring的业务层获取request,response

    1.直接通过controller层获取到传输到业务层2.SpringMVC提供的RequestContextHolder可以直接获取代码: RequestAttributes requestAttri ...

  3. android#使用Intent传递对象

    参考自<第一行代码>——郭霖 Intent的用法相信你已经比较熟悉了,我们可以借助它来启动活动.发送广播.启动服务等.在进行上述操作的时候,我们还可以在Intent中添加一些附加数据,以达 ...

  4. A Mixed Flash Translation Layer Structure for SLC-MLC Combined Flash Memory System

    http://blog.sina.com.cn/s/blog_502c8cc40100pztk.html 摘要 1.In this paper, we propose the SLC-MLC mixe ...

  5. Flink与其他流处理方式的对比分析

    一.Flink与其他流处理方式的对比分析 ·1.Flink特点: Apache Flink 是一个开源的分布式,高性能,高可用,准确的流处理框架. 主要由 Java 代码实现. 支持实时流(strea ...

  6. Java-Redis JdkSerializationRedisSerializer和StringRedisSerializer

    在将redis中存储的数据进行减一操作时出现: io.lettuce.core.RedisCommandExecutionException: ERR value is not a valid flo ...

  7. 2019牛客暑期多校训练营(第九场)-D Knapsack Cryptosystem (折半搜索)

    题目链接:https://ac.nowcoder.com/acm/contest/889/D 题意:题意简单,从大小为36的集合中选若干元素使得他们的和为sum. 思路:第一感觉用搜索,复杂度为2^3 ...

  8. Shell脚本中计算字符串长度的5种方法

    有时在Linux操作系统中需要计算某个字符串的长度,通过查询资料整理了下目前Shell中获取字符串的长度的多种方法,在这里分享给大家,方法如下: 方法1: 使用wc -L命令wc -L可以获取到当前行 ...

  9. PAT A1012 Best Rank(25)

    题目描述 To evaluate the performance of our first year CS majored students, we consider their grades of ...

  10. STL algorithm 头文件下的常用函数

    algorithm 头文件下的常用函数 1. max(), min()和abs() //max(x,y)和min(x,y)分别返回x和y中的最大值和最小值,且参数必须时两个(可以是浮点数) //返回3 ...