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()
    }
    
    此时此刻,非我莫属
  • 相关阅读:
    layui
    JSON
    jQuery
    实例——模拟验证码
    实例——表格的相关操作:添加行,删除行,编辑单元格
    实例——省市区三级联动 & 还可以输入字符统计
    实例练习——轮播图 & 全选/全不选
    练习-计算器
    定时器 & 日期时间对象 & 正则
    ThinkPHP实现分页
  • 原文地址:https://www.cnblogs.com/taozhengquan/p/14799231.html
Copyright © 2011-2022 走看看