• Kafka集群搭建与实操笔记(伪分布式)


    声明

    本笔记旨在学习针对kafka基操进行学习备忘及记录
    非详细说明与介绍,主线详情主要参照以下大牛整理的文档链接中的第一个文档

    文档链接

    kafka搭建

    https://blog.csdn.net/qq_32212587/article/details/124447901

    zookeeper:https://blog.csdn.net/chen_peng7/article/details/122456469

    规划(伪分布式)

    server1server2server3
    IP192.168.1.19:22192.168.1.19:22192.168.1.19:22
    zk2181/opt/module/zookeeper
    javaJDK8JDK8JDK8
    配置文件/opt/module/kafka/config/server1.properties/opt/module/kafka/config/server2.properties/opt/module/kafka/config/server3.properties
    kafka监听端口909290939094
    日志/tmp/kafka-logs/1/tmp/kafka-logs/2/tmp/kafka-logs/3
    kafka目录/opt/module/kafka1/opt/module/kafka2/opt/module/kafka3

    关于zookeeper的部署这边用的是简单的docker部署到2181端口(基操此处略)

    由于是伪分布式搭建,kafka的配置文件主要需要修改文件路径本身、监听端口、日志路径(最好是区分开来以便出现问题回溯)、kafka项目目录

    以下将会贴上kafka工程目录压缩包及配置范本代码。
    压缩包见附件https://download.csdn.net/download/qq_40732354/86406272

    [root@localhost config]# cat server.properties 
    # Licensed to the Apache Software Foundation (ASF) under one or more
    # contributor license agreements.  See the NOTICE file distributed with
    # this work for additional information regarding copyright ownership.
    # The ASF licenses this file to You under the Apache License, Version 2.0
    # (the "License"); you may not use this file except in compliance with
    # the License.  You may obtain a copy of the License at
    #
    #    http://www.apache.org/licenses/LICENSE-2.0
    #
    # Unless required by applicable law or agreed to in writing, software
    # distributed under the License is distributed on an "AS IS" BASIS,
    # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    # See the License for the specific language governing permissions and
    # limitations under the License.
    
    # see kafka.server.KafkaConfig for additional details and defaults
    
    ############################# Server Basics #############################
    
    # The id of the broker. This must be set to a unique integer for each broker.
    broker.id=1
    
    ############################# Socket Server Settings #############################
    
    # The address the socket server listens on. It will get the value returned from 
    # java.net.InetAddress.getCanonicalHostName() if not configured.
    #   FORMAT:
    #     listeners = listener_name://host_name:port
    #   EXAMPLE:
    #     listeners = PLAINTEXT://your.host.name:9092
    listeners=PLAINTEXT://127.0.0.1:9092
    
    # Hostname and port the broker will advertise to producers and consumers. If not set, 
    # it uses the value for "listeners" if configured.  Otherwise, it will use the value
    # returned from java.net.InetAddress.getCanonicalHostName().
    #advertised.listeners=PLAINTEXT://your.host.name:9092
    
    # Maps listener names to security protocols, the default is for them to be the same. See the config documentation for more details
    #listener.security.protocol.map=PLAINTEXT:PLAINTEXT,SSL:SSL,SASL_PLAINTEXT:SASL_PLAINTEXT,SASL_SSL:SASL_SSL
    
    # The number of threads that the server uses for receiving requests from the network and sending responses to the network
    num.network.threads=3
    
    # The number of threads that the server uses for processing requests, which may include disk I/O
    num.io.threads=8
    
    # The send buffer (SO_SNDBUF) used by the socket server
    socket.send.buffer.bytes=102400
    
    # The receive buffer (SO_RCVBUF) used by the socket server
    socket.receive.buffer.bytes=102400
    
    # The maximum size of a request that the socket server will accept (protection against OOM)
    socket.request.max.bytes=104857600
    
    
    ############################# Log Basics #############################
    
    # A comma separated list of directories under which to store log files
    log.dirs=/tmp/kafka-logs/1
    
    # The default number of log partitions per topic. More partitions allow greater
    # parallelism for consumption, but this will also result in more files across
    # the brokers.
    num.partitions=1
    
    # The number of threads per data directory to be used for log recovery at startup and flushing at shutdown.
    # This value is recommended to be increased for installations with data dirs located in RAID array.
    num.recovery.threads.per.data.dir=1
    
    ############################# Internal Topic Settings  #############################
    # The replication factor for the group metadata internal topics "__consumer_offsets" and "__transaction_state"
    # For anything other than development testing, a value greater than 1 is recommended to ensure availability such as 3.
    offsets.topic.replication.factor=1
    transaction.state.log.replication.factor=1
    transaction.state.log.min.isr=1
    
    ############################# Log Flush Policy #############################
    
    # Messages are immediately written to the filesystem but by default we only fsync() to sync
    # the OS cache lazily. The following configurations control the flush of data to disk.
    # There are a few important trade-offs here:
    #    1. Durability: Unflushed data may be lost if you are not using replication.
    #    2. Latency: Very large flush intervals may lead to latency spikes when the flush does occur as there will be a lot of data to flush.
    #    3. Throughput: The flush is generally the most expensive operation, and a small flush interval may lead to excessive seeks.
    # The settings below allow one to configure the flush policy to flush data after a period of time or
    # every N messages (or both). This can be done globally and overridden on a per-topic basis.
    
    # The number of messages to accept before forcing a flush of data to disk
    #log.flush.interval.messages=10000
    
    # The maximum amount of time a message can sit in a log before we force a flush
    #log.flush.interval.ms=1000
    
    ############################# Log Retention Policy #############################
    
    # The following configurations control the disposal of log segments. The policy can
    # be set to delete segments after a period of time, or after a given size has accumulated.
    # A segment will be deleted whenever *either* of these criteria are met. Deletion always happens
    # from the end of the log.
    
    # The minimum age of a log file to be eligible for deletion due to age
    log.retention.hours=168
    
    # A size-based retention policy for logs. Segments are pruned from the log unless the remaining
    # segments drop below log.retention.bytes. Functions independently of log.retention.hours.
    #log.retention.bytes=1073741824
    
    # The maximum size of a log segment file. When this size is reached a new log segment will be created.
    log.segment.bytes=1073741824
    
    # The interval at which log segments are checked to see if they can be deleted according
    # to the retention policies
    log.retention.check.interval.ms=300000
    
    ############################# Zookeeper #############################
    
    # Zookeeper connection string (see zookeeper docs for details).
    # This is a comma separated host:port pairs, each corresponding to a zk
    # server. e.g. "127.0.0.1:3000,127.0.0.1:3001,127.0.0.1:3002".
    # You can also append an optional chroot string to the urls to specify the
    # root directory for all kafka znodes.
    zookeeper.connect=localhost:2181
    
    # Timeout in ms for connecting to zookeeper
    zookeeper.connection.timeout.ms=18000
    
    
    ############################# Group Coordinator Settings #############################
    
    # The following configuration specifies the time, in milliseconds, that the GroupCoordinator will delay the initial consumer rebalance.
    # The rebalance will be further delayed by the value of group.initial.rebalance.delay.ms as new members join the group, up to a maximum of max.poll.interval.ms.
    # The default value for this is 3 seconds.
    # We override this to 0 here as it makes for a better out-of-the-box experience for development and testing.
    # However, in production environments the default value of 3 seconds is more suitable as this will help to avoid unnecessary, and potentially expensive, rebalances during application startup.
    group.initial.rebalance.delay.ms=0
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135
    • 136
    • 137
    • 138
    [root@localhost module]# cat cluster-kafka.sh 
    #!/bin/bash
    case $1 in
    "start"){
    	echo --------------------------------  kafka 启动 ---------------------------
    	source /etc/profile
    	/opt/module/kafka1/bin/kafka-server-start.sh -daemon /opt/module/kafka1/config/server1.properties
    	/opt/module/kafka2/bin/kafka-server-start.sh -daemon /opt/module/kafka2/config/server2.properties
    	/opt/module/kafka3/bin/kafka-server-start.sh -daemon /opt/module/kafka3/config/server3.properties
    }
    ;;
    "stop"){
    	echo --------------------------------  kafka 停止 ---------------------------
    	/opt/module/kafka1/bin/kafka-server-stop.sh
    	/opt/module/kafka2/bin/kafka-server-stop.sh
    	/opt/module/kafka3/bin/kafka-server-stop.sh
    }
    ;;
    esac
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    执行脚本后kafka集群启动。

    实操环节

    //创建主题leotest
    [root@localhost kafka1]# ./bin/kafka-topics.sh --create --bootstrap-server 127.0.0.1:9092 --replication-factor 3 --partitions 1 --topic leotest
    Created topic leotest.
    
    //查看主题列表
    [root@localhost kafka1]# ./bin/kafka-topics.sh --list --bootstrap-server 127.0.0.1:9092
    leotest
    [root@localhost kafka1]# 
    
    //让生产者对没有创建过的主题输入:报错如下
    [root@localhost kafka1]# ./bin/kafka-console-producer.sh --broker-list 127.0.0.1:9092 --topic test
    >a
    [2022-08-22 00:41:50,249] WARN [Producer clientId=console-producer] Error while fetching metadata with correlation id 3 : {test=LEADER_NOT_AVAILABLE} (org.apache.kafka.clients.NetworkClient)
    
    
    //让生产者对创建过的主题输入:如下
    [root@localhost kafka1]# ./bin/kafka-console-producer.sh --broker-list 127.0.0.1:9092 --topic leotest
    >asd
    >
    
    //启动消费者从头开始消费
    [root@localhost ~]# cd /opt/module/kafka2/
    [root@localhost kafka2]# ./bin/kafka-console-consumer.sh --bootstrap-server 127.0.0.1:9092 --topic leotest --from-beginning
    asd
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    QT学习(1)
    CF104064 E. Exchange Students(NWERC2021)
    `THREE.AudioAnalyser` 音频分析
    【luogu CF1286E】Fedya the Potter Strikes Back(字符串)(KMP)(势能分析)(线段树)
    Java List Set Map
    Android应用内设置多语言
    “Python+”集成技术高光谱遥感数据处理与机器学习深度
    Qt之自定义带游标的QSlider
    flutter系列之:flutter中常用的GridView layout详解
    解决开了burp suite ,火狐访问不了其他网站的问题
  • 原文地址:https://blog.csdn.net/qq_40732354/article/details/126456690