婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang如何使用sarama訪問kafka

golang如何使用sarama訪問kafka

熱門標簽:西部云谷一期地圖標注 浙江高速公路地圖標注 南通如皋申請開通400電話 中國地圖標注省會高清 學海導航地圖標注 地圖標注的汽車標 江西轉化率高的羿智云外呼系統 高德地圖標注口訣 廣州呼叫中心外呼系統

下面一個客戶端代碼例子訪問kafka服務器,來發送和接受消息。

使用方式

1、命令行參數

$ ./kafkaclient -h
Usage of ./client:
 -ca string
  CA Certificate (default "ca.pem")
 -cert string
  Client Certificate (default "cert.pem")
 -command string
  consumer|producer (default "consumer")
 -host string
  Common separated kafka hosts (default "localhost:9093")
 -key string
  Client Key (default "key.pem")
 -partition int
  Kafka topic partition
 -tls
  TLS enable
 -topic string
  Kafka topic (default "test--topic")

2、作為producer啟動

$ ./kafkaclient -command producer \

 -host kafka1:9092,kafka2:9092

## TLS-enabled
$ ./kafkaclient -command producer \

 -tls -cert client.pem -key client.key -ca ca.pem \

 -host kafka1:9093,kafka2:9093

producer發送消息給kafka:

> aaa
2018/12/15 07:11:21 Produced message: [aaa]
> bbb
2018/12/15 07:11:30 Produced message: [bbb]
> quit

3、作為consumer啟動

$ ./kafkaclient -command consumer \

 -host kafka1:9092,kafka2:9092

## TLS-enabled
$ ./kafkaclient -command consumer \

 -tls -cert client.pem -key client.key -ca ca.pem \

 -host kafka1:9093,kafka2:9093

consumer從kafka接受消息:

2018/12/15 07:11:21 Consumed message: [aaa], offset: [4]
2018/12/15 07:11:30 Consumed message: [bbb], offset: [5]

完整源代碼如下

這個代碼使用到了Shopify/sarama庫,請自行下載使用。

$ cat kafkaclient.go
package main

import (
 "flag"
 "fmt"
 "log"
 "os"
 "io/ioutil"
 "bufio"
 "strings"

 "crypto/tls"
 "crypto/x509"

 "github.com/Shopify/sarama"
)

var (
 command  string
 tlsEnable bool
 hosts  string
 topic  string
 partition int
 clientcert string
 clientkey string
 cacert  string
)

func main() {
 flag.StringVar(command, "command",  "consumer",   "consumer|producer")
 flag.BoolVar(tlsEnable, "tls",   false,    "TLS enable")
 flag.StringVar(hosts,  "host",   "localhost:9093", "Common separated kafka hosts")
 flag.StringVar(topic,  "topic",  "test--topic",  "Kafka topic")
 flag.IntVar(partition,  "partition", 0,     "Kafka topic partition")
 flag.StringVar(clientcert, "cert",   "cert.pem",   "Client Certificate")
 flag.StringVar(clientkey, "key",   "key.pem",   "Client Key")
 flag.StringVar(cacert,  "ca",   "ca.pem",   "CA Certificate")
 flag.Parse()

 config := sarama.NewConfig()
 if tlsEnable {
  //sarama.Logger = log.New(os.Stdout, "[sarama] ", log.LstdFlags)
  tlsConfig, err := genTLSConfig(clientcert, clientkey, cacert)
  if err != nil {
   log.Fatal(err)
  }

  config.Net.TLS.Enable = true
  config.Net.TLS.Config = tlsConfig
 }
 client, err := sarama.NewClient(strings.Split(hosts, ","), config)
 if err != nil {
  log.Fatalf("unable to create kafka client: %q", err)
 }

 if command == "consumer" {
  consumer, err := sarama.NewConsumerFromClient(client)
  if err != nil {
   log.Fatal(err)
  }
  defer consumer.Close()
  loopConsumer(consumer, topic, partition)
 } else {
  producer, err := sarama.NewAsyncProducerFromClient(client)
  if err != nil {
   log.Fatal(err)
  }
  defer producer.Close()
  loopProducer(producer, topic, partition)
 }
}

func genTLSConfig(clientcertfile, clientkeyfile, cacertfile string) (*tls.Config, error) {
 // load client cert
 clientcert, err := tls.LoadX509KeyPair(clientcertfile, clientkeyfile)
 if err != nil {
  return nil, err
 }

 // load ca cert pool
 cacert, err := ioutil.ReadFile(cacertfile)
 if err != nil {
  return nil, err
 }
 cacertpool := x509.NewCertPool()
 cacertpool.AppendCertsFromPEM(cacert)

 // generate tlcconfig
 tlsConfig := tls.Config{}
 tlsConfig.RootCAs = cacertpool
 tlsConfig.Certificates = []tls.Certificate{clientcert}
 tlsConfig.BuildNameToCertificate()
 // tlsConfig.InsecureSkipVerify = true // This can be used on test server if domain does not match cert:
 return tlsConfig, err
}

func loopProducer(producer sarama.AsyncProducer, topic string, partition int) {
 scanner := bufio.NewScanner(os.Stdin)
 fmt.Print("> ")
 for scanner.Scan() {
  text := scanner.Text()
  if text == "" {
  } else if text == "exit" || text == "quit" {
   break
  } else {
   producer.Input() - sarama.ProducerMessage{Topic: topic, Key: nil, Value: sarama.StringEncoder(text)}
   log.Printf("Produced message: [%s]\n",text)
  }
  fmt.Print("> ")
 }
}

func loopConsumer(consumer sarama.Consumer, topic string, partition int) {
 partitionConsumer, err := consumer.ConsumePartition(topic, int32(partition), sarama.OffsetNewest)
 if err != nil {
  log.Println(err)
  return
 }
 defer partitionConsumer.Close()

 for {
  msg := -partitionConsumer.Messages()
  log.Printf("Consumed message: [%s], offset: [%d]\n", msg.Value, msg.Offset)
 }
}

編譯:

$ go build kafkaclient.go

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 在Golang中使用http.FileServer返回靜態文件的操作
  • 解決golang http.FileServer 遇到的坑
  • 解決golang處理http response碰到的問題和需要注意的點
  • golang bad file descriptor問題的解決方法
  • golang復用http.request.body的方法示例
  • golang連接kafka消費進ES操作

標簽:吐魯番 許昌 保定 東營 德宏 曲靖 貴州 常州

巨人網絡通訊聲明:本文標題《golang如何使用sarama訪問kafka》,本文關鍵詞  golang,如何,使用,sarama,訪問,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang如何使用sarama訪問kafka》相關的同類信息!
  • 本頁收集關于golang如何使用sarama訪問kafka的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品久久久影院| 午夜伦理一区二区| 久久99国产精品免费网站| 欧美日韩一级大片网址| 一区二区三区在线视频观看 | 久久综合久久综合久久| 日韩精品欧美精品| 欧美日韩一区精品| 亚洲蜜臀av乱码久久精品| av男人天堂一区| 久久精品一区二区| 国产精品一区二区三区四区| 91精品国产全国免费观看| 亚洲男人天堂av网| 不卡高清视频专区| 2024国产精品| 国内欧美视频一区二区| 欧美一级二级三级蜜桃| 青青草原综合久久大伊人精品| 欧美日精品一区视频| 亚洲动漫第一页| 91福利精品第一导航| 亚洲一本大道在线| 欧美日韩精品欧美日韩精品| 亚洲一区二区三区免费视频| 欧美三级日韩三级| 免费看欧美女人艹b| 精品黑人一区二区三区久久| 国产成人啪免费观看软件| 国产精品欧美一级免费| 99re免费视频精品全部| 亚洲国产va精品久久久不卡综合| 欧美日本在线视频| 精品一区二区精品| 国产精品日韩精品欧美在线| 91免费版在线| 免费在线观看成人| 国产偷国产偷精品高清尤物| 99久久久免费精品国产一区二区| 一卡二卡三卡日韩欧美| 欧美一区二区视频在线观看2020| 国内久久精品视频| 亚洲欧洲综合另类| 欧美成人精品3d动漫h| av网站一区二区三区| 日韩国产精品久久久| 久久久国产精品午夜一区ai换脸| www.66久久| 日本不卡的三区四区五区| 久久久.com| 欧美日韩国产综合久久| 国产做a爰片久久毛片| 亚洲国产毛片aaaaa无费看| 精品剧情在线观看| 在线区一区二视频| 国产成人综合在线| 日本在线播放一区二区三区| 国产精品国产自产拍在线| 4438成人网| 在线观看国产精品网站| 国产精品99久久久久久宅男| 亚洲自拍偷拍综合| 国产欧美视频在线观看| 91 com成人网| 97se亚洲国产综合在线| 蜜桃av一区二区| 一区二区视频免费在线观看| 久久精品欧美日韩精品| 宅男在线国产精品| 91成人在线观看喷潮| 成人激情免费视频| 国产精品一区二区久久精品爱涩 | 欧美一区二区三区男人的天堂| av不卡在线播放| 国产在线精品不卡| 日本不卡视频在线| 午夜婷婷国产麻豆精品| 国产精品久久影院| 国产日韩在线不卡| 久久免费看少妇高潮| 日韩一区二区在线观看视频播放| 欧美日韩一区视频| 欧美日韩午夜精品| 日本精品一区二区三区高清| 国产精品白丝jk黑袜喷水| 精品一区二区三区久久| 久久超碰97中文字幕| 亚洲成av人综合在线观看| 一区二区三区欧美久久| 亚洲女厕所小便bbb| 国产精品久久久久影院亚瑟| 国产欧美一区视频| 日本一区二区三区电影| 国产农村妇女毛片精品久久麻豆 | 中文字幕精品一区二区精品绿巨人| 日韩一级完整毛片| 欧美色窝79yyyycom| 欧美性videosxxxxx| 色悠悠久久综合| 日本高清成人免费播放| 99精品视频在线免费观看| 高清av一区二区| 狠狠色丁香婷综合久久| 日韩av电影天堂| 蜜桃视频在线观看一区| 美国十次综合导航| 天天免费综合色| 另类欧美日韩国产在线| 韩国毛片一区二区三区| 国产精品一区免费视频| 国产ts人妖一区二区| eeuss鲁片一区二区三区| 色88888久久久久久影院野外| 欧美日韩日本视频| 精品国产髙清在线看国产毛片| 久久亚洲综合av| 国产精品国产三级国产三级人妇 | 欧美久久婷婷综合色| 精品国产乱码久久久久久蜜臀| 欧美精品一区二区三区蜜桃视频 | 亚洲尤物视频在线| 日本中文字幕一区二区视频| 国产精品一区二区你懂的| 99精品在线观看视频| 欧美一级片在线观看| 久久精品日产第一区二区三区高清版| 国产精品国产馆在线真实露脸| 亚洲婷婷国产精品电影人久久| 亚洲精品国产无套在线观| 日本女人一区二区三区| 成人免费高清在线观看| 欧美另类高清zo欧美| 久久无码av三级| 亚洲综合免费观看高清完整版| 久久精品国产一区二区| 91丨porny丨在线| 日韩免费观看2025年上映的电影| 国产精品视频观看| 日韩成人免费看| 99视频有精品| 精品嫩草影院久久| 亚洲尤物视频在线| 高清shemale亚洲人妖| 日韩丝袜美女视频| 亚洲黄色小说网站| 粉嫩aⅴ一区二区三区四区| 欧美日韩黄色一区二区| 久久一留热品黄| 一区二区三区欧美日| 激情文学综合网| 成人app软件下载大全免费| 日本精品一区二区三区高清 | 亚洲国产精品v| 日韩成人一区二区三区在线观看| 91偷拍与自偷拍精品| 国产日韩欧美精品一区| 婷婷久久综合九色综合伊人色| 成人a免费在线看| 久久久久久一二三区| 麻豆成人在线观看| 欧美福利视频一区| 亚洲影院久久精品| 99re视频精品| 综合久久一区二区三区| 成人高清免费观看| 欧美激情一区二区三区蜜桃视频| 五月激情综合网| 欧美综合欧美视频| 中文字幕精品一区| 久久精品国产免费看久久精品| 欧美亚洲禁片免费| 亚洲欧美成aⅴ人在线观看 | 成人综合在线视频| 91精品国产麻豆国产自产在线 | 国产成人夜色高潮福利影视| 国产区在线观看成人精品| 国产大陆亚洲精品国产| 国产精品久久综合| 欧美综合在线视频| 蜜桃91丨九色丨蝌蚪91桃色| 久久久亚洲国产美女国产盗摄 | 狠狠色综合日日| 中文一区一区三区高中清不卡| 99国产精品一区| 亚洲成人av免费| 欧美成人免费网站| www.日本不卡| 免费观看日韩av| 国产欧美日韩精品a在线观看| 91视频一区二区三区| 秋霞电影网一区二区| 久久精品一区二区| 欧美午夜理伦三级在线观看| 九九久久精品视频| 国产精品短视频| 日韩一级免费一区| jizz一区二区| 日韩成人一级片| 亚洲婷婷在线视频| 精品国产一区二区三区四区四 |