zoukankan      html  css  js  c++  java
  • Kafka

    kafka

    启动kafka

    命令行分别启动zookeeperkafka

    .inwindowszookeeper-server-start.bat .configzookeeper.properties
    .inwindowskafka-server-start.bat .configserver.properties
    

    终端获取kafka数据

    binwindowskafka-console-consumer.bat --bootstrap-server=127.0.0.1:9092 --topic=web_log --from-beginning
    

    生产者producer

    package main
    
    import (
    	"fmt"
    	"github.com/Shopify/sarama"
    )
    
    func main()  {
    	go kafka_producer_test()
    }
    
    func kafka_producer_test(){
    	config := sarama.NewConfig()
    	// 发送完数据需要leader和follow都确认
    	config.Producer.RequiredAcks = sarama.WaitForAll
    	// 选出一个partition
    	config.Producer.Partitioner = sarama.NewCustomPartitioner()
    	// 成功交付的消息将在success channel 返回
    	config.Producer.Return.Successes = true
    	// 构造一个消息
    	msg := &sarama.ProducerMessage{}
    	msg.Topic = "web_log"
    	msg.Value = sarama.StringEncoder("this is a test log")
    	//连接kafka
    	client, err := sarama.NewSyncProducer([]string{"127.0.0.1:9092"}, config)
    	if err !=nil{
    		fmt.Println("producer closed, err:", err)
    		return
    	}
    	defer client.Close()
    	// 发送消息
    	pid, offset, err := client.SendMessage(msg)
    	if err != nil{
    		fmt.Println("send msg failed, err:", err)
    		return
    	}
    	fmt.Printf("pid:%v offset:%v
    ", pid, offset)
    }
    
    

    消费者 consumer

    package main
    
    import (
    	"fmt"
    	"github.com/Shopify/sarama"
    	"sync"
    )
    
    func main()  {
    	go kafka_consumer_test()
    }
    
    func kafka_consumer_test(){
    	var wg sync.WaitGroup
    	consumer, err := sarama.NewConsumer([]string{"127.0.0.1:9092"}, nil)
    	if err != nil{
    		fmt.Println("Failed to start consumer: %s", err)
    		return
    	}
    	partitionList, err := consumer.Partitions("web_log")  //获得该topic所有的分区
    	if err != nil{
    		fmt.Println("Failed to get the list of partition:, ",err)
    		return
    	}
    	fmt.Println(partitionList)
    
    	for partition := range partitionList{
    		pc, err := consumer.ConsumePartition("web_log", int32(partition), sarama.OffsetNewest)
    		if err != nil{
    			fmt.Println("Failed to start consumer for partition %d: %s
    ", partition, err)
    			return
    		}
    		wg.Add(1)
    		go func(sarama.PartitionConsumer) { //为每个分区开一个go协程去取值
    			for msg := range pc.Messages(){  //阻塞直到有值发送过来,然后再继续等待
    				fmt.Printf("Partition:%d, Offset:%d, key:%s, value:%s
    ", msg.Partition, msg.Offset, string(msg.Key),string(msg.Value))
    			}
    			defer pc.AsyncClose()
    			wg.Done()
    		}(pc)
    	}
    	wg.Wait()
    	consumer.Close()
    }
    
    此时此刻,非我莫属
  • 相关阅读:
    Change the default MySQL data directory with SELinux enabled
    CentOS7使用firewalld打开关闭防火墙与端口
    常用screen参数
    Android手机上浏览器不支持带端口号wss解决方案
    How to Create Triggers in MySQL
    QT GUI @创建新的工程
    Linux内核源代码的结构(转)
    ARM体系的7种工作模式
    C语言中强制数据类型转换(转)
    Linux驱动设计—— 中断与时钟@request_irq参数详解
  • 原文地址:https://www.cnblogs.com/taozhengquan/p/14799231.html
Copyright © 2011-2022 走看看