mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-11-04 11:22:10 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			598 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			598 B
		
	
	
	
		
			Go
		
	
	
	
	
	
package kafka
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/Shopify/sarama"
 | 
						|
	"sync"
 | 
						|
)
 | 
						|
 | 
						|
type Consumer struct {
 | 
						|
	addr          []string
 | 
						|
	WG            sync.WaitGroup
 | 
						|
	Topic         string
 | 
						|
	PartitionList []int32
 | 
						|
	Consumer      sarama.Consumer
 | 
						|
}
 | 
						|
 | 
						|
func NewKafkaConsumer(addr []string, topic string) *Consumer {
 | 
						|
	p := Consumer{}
 | 
						|
	p.Topic = topic
 | 
						|
	p.addr = addr
 | 
						|
 | 
						|
	consumer, err := sarama.NewConsumer(p.addr, nil)
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
		return nil
 | 
						|
	}
 | 
						|
	p.Consumer = consumer
 | 
						|
 | 
						|
	partitionList, err := consumer.Partitions(p.Topic)
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
		return nil
 | 
						|
	}
 | 
						|
	p.PartitionList = partitionList
 | 
						|
 | 
						|
	return &p
 | 
						|
}
 |