婷婷综合国产,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
    日本久久电影网| 欧美精品日韩综合在线| 色欧美日韩亚洲| 国产欧美日韩麻豆91| 国产不卡免费视频| 韩国欧美国产一区| 欧美日韩五月天| 亚洲va国产va欧美va观看| 久久精品国内一区二区三区| 久久综合色之久久综合| 亚洲精品视频自拍| 懂色av一区二区三区免费看| 日韩亚洲欧美一区| 亚洲免费视频成人| 成人免费黄色大片| 久久久91精品国产一区二区三区| 婷婷国产在线综合| 在线视频一区二区三| 国产精品久久久久国产精品日日 | 欧美日韩在线精品一区二区三区激情| 亚洲精品一线二线三线无人区| 亚洲成人福利片| 国产在线精品一区二区三区不卡| 91精品国产色综合久久不卡电影| 亚洲日本va午夜在线影院| 国产成人精品aa毛片| 久久网站热最新地址| 精品影视av免费| 精品国产免费一区二区三区四区 | 午夜精品一区二区三区免费视频| 91丨porny丨蝌蚪视频| 国产精品欧美一区二区三区| 国产精品综合视频| 国产视频一区二区在线| 国产.精品.日韩.另类.中文.在线.播放| 久久婷婷国产综合精品青草| 国产高清一区日本| 日韩欧美视频一区| 成人av午夜电影| 亚洲天堂成人网| 在线精品视频一区二区三四| 亚洲一区在线免费观看| 久久午夜色播影院免费高清| 国产激情视频一区二区三区欧美| 中文成人综合网| 欧美私模裸体表演在线观看| 亚洲天堂a在线| 不卡电影一区二区三区| 亚洲综合在线五月| 在线成人免费观看| 激情六月婷婷久久| 亚洲免费在线电影| 精品日韩在线一区| 国产精品美女久久福利网站 | 午夜电影久久久| 精品国产99国产精品| 成人动漫av在线| 青青青伊人色综合久久| 中文字幕一区二区三区在线不卡 | 欧美最猛黑人xxxxx猛交| 亚洲一区二区免费视频| 国产亚洲精品资源在线26u| 亚洲va天堂va国产va久| 国产亚洲欧洲一区高清在线观看| 99re成人精品视频| 国产福利91精品| 美国三级日本三级久久99| 亚洲三级视频在线观看| 精品国产免费一区二区三区四区| 色吊一区二区三区| 成人99免费视频| 另类小说图片综合网| 亚洲成年人影院| 欧美va亚洲va在线观看蝴蝶网| 99精品欧美一区| 国产一区二区三区在线观看免费| 亚洲综合免费观看高清完整版| 久久久精品天堂| 91精品欧美福利在线观看| 一本色道久久综合亚洲aⅴ蜜桃 | 国产精品美女久久久久高潮| 欧美老肥妇做.爰bbww| 99r精品视频| 在线观看成人小视频| 色av一区二区| 色狠狠色狠狠综合| 在线观看91av| 久久九九久精品国产免费直播| 久久久亚洲高清| 国产精品久久久久久久久图文区| 亚洲人成影院在线观看| 亚洲综合无码一区二区| 久久国产剧场电影| 国产91富婆露脸刺激对白| av动漫一区二区| 精品污污网站免费看| 日韩亚洲欧美在线观看| 国产午夜亚洲精品不卡| 亚洲精品高清在线观看| 日韩精品国产欧美| 国产乱码精品一区二区三区忘忧草 | 国产老肥熟一区二区三区| 国产成人精品一区二| 欧美日韩电影在线播放| 久久午夜老司机| 亚洲一区二区三区爽爽爽爽爽| 美女任你摸久久| 色久综合一二码| 精品国产乱码久久久久久牛牛 | 国产精品亚洲一区二区三区在线| 国产suv精品一区二区883| 在线观看日韩电影| 久久夜色精品一区| 天天色综合成人网| 白白色 亚洲乱淫| 日韩亚洲电影在线| 一区二区三区中文免费| 国产呦精品一区二区三区网站| 91成人免费在线视频| 国产精品久久久久久久第一福利| 美日韩一区二区三区| 91国产精品成人| 国产精品久久久久婷婷| 国产精品888| 精品国产凹凸成av人网站| 亚洲成人午夜影院| av资源网一区| 国产精品女同一区二区三区| 美女视频黄频大全不卡视频在线播放| 91一区在线观看| 自拍视频在线观看一区二区| 韩国理伦片一区二区三区在线播放 | 国产综合一区二区| 欧美日本高清视频在线观看| 亚洲愉拍自拍另类高清精品| 国产91在线|亚洲| www成人在线观看| 九九精品一区二区| 精品国产乱码久久久久久影片| 美国欧美日韩国产在线播放| 91精品国产一区二区三区 | 欧美影院一区二区三区| 日韩一区欧美一区| 成人app在线| 中文字幕二三区不卡| 不卡欧美aaaaa| 亚洲精品国产a| 91精品国产综合久久精品| 久久草av在线| 久久久久久久久久美女| 成人黄色电影在线| 中文字幕中文乱码欧美一区二区| 91免费看视频| 亚洲成a人v欧美综合天堂下载| 欧美亚日韩国产aⅴ精品中极品| 亚洲国产另类av| 精品国产91乱码一区二区三区| 国产又粗又猛又爽又黄91精品| 国产精品麻豆99久久久久久| eeuss鲁一区二区三区| 中文字幕一区在线观看| 91丨国产丨九色丨pron| 亚洲国产日产av| 精品国产sm最大网站免费看| 丁香一区二区三区| 亚洲最大成人网4388xx| 精品国产欧美一区二区| 91啪亚洲精品| 久久激情五月婷婷| 中文字幕一区二区在线播放| 3d成人h动漫网站入口| 国产精品系列在线观看| 亚洲激情图片qvod| 日韩欧美亚洲国产另类| 91在线云播放| 亚洲va欧美va人人爽| 久久精品人人做人人综合| 视频一区国产视频| 精品sm捆绑视频| 日本不卡在线视频| 日韩精品在线看片z| 日本精品一区二区三区高清 | 一区二区三区四区亚洲| 成人影视亚洲图片在线| 日本不卡高清视频| 国产精品久久国产精麻豆99网站 | 欧美mv日韩mv国产网站app| 99久免费精品视频在线观看| 亚洲精品一区二区三区四区高清| 色爱区综合激月婷婷| 国产综合久久久久久鬼色| 国产片一区二区三区| 欧美xxxx在线观看| 粉嫩一区二区三区在线看| 日韩av中文字幕一区二区 | 国产精品美女久久久久aⅴ国产馆| av在线一区二区三区| 国产一区欧美日韩| 无码av中文一区二区三区桃花岛| 日韩免费高清视频|