zoukankan      html  css  js  c++  java
  • idea编译kafka 2.6 源码

    idea编译kafka 2.6 源码

    最近项目要接入kafka和flink,有时间就学一下kafka的源码,就编译了一下kafka的源码,期间还是踩了不少坑的。

    一、安装jdk

    image-20211020173549494

    二、安装scala

    image-20211020173608472

    三、安装gradle

    image-20211020173656365

    四、本地启动zookeeper

    最近在官网下载,然后解压,调整配置文件,将zoo_sample.cfg复制一份为zoo.cfg,内容如下:

    # The number of milliseconds of each tick
    tickTime=2000
    # The number of ticks that the initial 
    # synchronization phase can take
    initLimit=10
    # The number of ticks that can pass between 
    # sending a request and getting an acknowledgement
    syncLimit=5
    # the directory where the snapshot is stored.
    # do not use /tmp for storage, /tmp here is just 
    # example sakes.
    dataDir=D:/zookeeper
    # the port at which the clients will connect
    clientPort=2181
    # the maximum number of client connections.
    # increase this if you need to handle more clients
    #maxClientCnxns=60
    

    之前问题就一直出现了这里,因为我有一台服务器,zookeeper是安装在上面的,然后本地kafka的源码的配置一直是服务器上的信息,就会导致kafka一运行就停了,一开始以为是kafka的版本问题,然后放了很久了,昨天就试了一下本地的zookeeper,结果就成功了。

    运行一下cmd文件:

    image-20211020174141149

    五、将kafka生成idea项目

    在官网下载kafka的源码,我此处的版本为2.6.0,到源码的地方运行一下gradle idea,然后在idea里面安装一下scala的插件。在开始导入源码

    • 修改config下的server.properties的kafka日志的位置和zookeeper的配置信息。

    • 将log4j.properties移到到kafka-2.6.0-srccoresrcmain esourceslog4j.properties

    • 修改build.gradle文件,不然是没有日志的。如果是低版本的话,是不需要的,此处我用0.10.0.1版本测试过

      project(':core') {
        println "Building project 'core' with Scala version ${versions.scala}"
      
        apply plugin: 'scala'
        apply plugin: "org.scoverage"
        archivesBaseName = "kafka_${versions.baseScala}"
      
        dependencies {
          compile project(':clients')
          compile libs.jacksonDatabind
          compile libs.jacksonModuleScala
          compile libs.jacksonDataformatCsv
          compile libs.jacksonJDK8Datatypes
          compile libs.joptSimple
          compile libs.metrics
          compile libs.scalaCollectionCompat
          compile libs.scalaJava8Compat
          compile libs.scalaLibrary
          // only needed transitively, but set it explicitly to ensure it has the same version as scala-library
          compile libs.scalaReflect
          compile libs.scalaLogging
          compile libs.slf4jApi
          compile libs.slf4jlog4j
          compile libs.log4j
          compile(libs.zookeeper) {
      //      exclude module: 'slf4j-log4j12'
      //      exclude module: 'log4j'
          }
          // ZooKeeperMain depends on commons-cli but declares the dependency as `provided`
          compile libs.commonsCli
      
          compileOnly libs.log4j
      
          testCompile project(':clients').sourceSets.test.output
          testCompile libs.bcpkix
          testCompile libs.mockitoCore
          testCompile libs.easymock
          testCompile(libs.apacheda) {
            exclude group: 'xml-apis', module: 'xml-apis'
            // `mina-core` is a transitive dependency for `apacheds` and `apacheda`.
            // It is safer to use from `apacheds` since that is the implementation.
            exclude module: 'mina-core'
          }
          testCompile libs.apachedsCoreApi
          testCompile libs.apachedsInterceptorKerberos
          testCompile libs.apachedsProtocolShared
          testCompile libs.apachedsProtocolKerberos
          testCompile libs.apachedsProtocolLdap
          testCompile libs.apachedsLdifPartition
          testCompile libs.apachedsMavibotPartition
          testCompile libs.apachedsJdbmPartition
          testCompile libs.junit
          testCompile libs.scalatest
          testCompile libs.slf4jlog4j
          testCompile libs.jfreechart
        }
      
    • 修改启动参数

    image-20211020174512418
    • 启动

      image-20211020174941979

    六、进行测试

    生成者

    public class ProducerFastStart {
    
        //kafka集群地址
        private static final String brokerList = "localhost:9092";
        //主体名称
        private static final String topic = "dalianpai";
    
        public static void main(String[] args) {
            Properties properties = new Properties();
    
            //设置序列化器
            properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
            //设置重试次数
            properties.put(ProducerConfig.RETRIES_CONFIG,10);
    
            properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG,StringSerializer.class.getName());
    
            properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,brokerList);
            // 2 构建拦截链
            List<String> interceptors = new ArrayList<>();
            interceptors.add(CounterInterceptor.class.getName());
            interceptors.add(TimeInterceptor.class.getName());
            properties.put(ProducerConfig.INTERCEPTOR_CLASSES_CONFIG, interceptors);
    
            KafkaProducer<String, String> producer = new KafkaProducer<>(properties);
            // 3 发送消息
            for (int i = 0; i < 11; i++) {
                ProducerRecord<String, String> record = new ProducerRecord<>(topic, "Kafka-demo-001", "hello, Kafka!"+i);
                producer.send(record);
            }
    
            producer.close();
        }
    }
    
    

    消费者

    public class ConsumerFastStart {
    
        // Kafka集群地址
        private static final String brokerList = "localhost:9092";
        // 主题名称-之前已经创建
        private static final String topic = "dalianpai";
        // 消费组
        private static final String groupId = "group.demo";
    
        public static void main(String[] args) {
            Properties properties = new Properties();
    
            //设置序列化器
            properties.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
    
            properties.put("value.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
    
            properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,brokerList);
    
            properties.put("group.id", groupId);
    
            KafkaConsumer<String, String> consumer = new KafkaConsumer<>(properties);
            consumer.subscribe(Collections.singletonList(topic));
            while (true) {
                ConsumerRecords<String, String> records =
                        consumer.poll(Duration.ofMillis(1000));
                for (ConsumerRecord<String, String> record : records) {
                    System.out.println(record.value());
                }
            }
        }
    }
    

    测试结果:

    image-20211020175121137
  • 相关阅读:
    Spring IoC容器初的初始化过程
    IoC容器初始化过程
    花了一个星期,我终于把RPC框架整明白了!
    RPC简介及框架选择
    ORM框架的前世今生
    什么是索引?Mysql目前主要的几种索引类型
    面试官:谈谈你对Mysql的MVCC的理解?
    sql server 获取数据字段(表的字段和类型信息)
    YAML
    Spring Boot 整合 Mybatis 实现 Druid 多数据源详解
  • 原文地址:https://www.cnblogs.com/dalianpai/p/15429992.html
Copyright © 2011-2022 走看看