本文整理匯總了Golang中github.com/mailgun/kafka-pixy/Godeps/_workspace/src/github.com/mailgun/log.Infof函數的典型用法代碼示例。如果您正苦於以下問題:Golang Infof函數的具體用法?Golang Infof怎麽用?Golang Infof使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Infof函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestMultipleTopics
// Different topics can be consumed at the same time.
func (s *SmartConsumerSuite) TestMultipleTopics(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.1")
s.kh.ResetOffsets("group-1", "test.4")
produced1 := s.kh.PutMessages("multiple.topics", "test.1", map[string]int{"A": 1})
produced4 := s.kh.PutMessages("multiple.topics", "test.4", map[string]int{"B": 1, "C": 1})
log.Infof("*** GIVEN 1")
sc, err := Spawn(testhelpers.NewTestConfig("consumer-1"))
c.Assert(err, IsNil)
// When
log.Infof("*** WHEN")
consumed := s.consume(c, sc, "group-1", "test.4", 1)
consumed = s.consume(c, sc, "group-1", "test.1", 1, consumed)
consumed = s.consume(c, sc, "group-1", "test.4", 1, consumed)
// Then
log.Infof("*** THEN")
assertMsg(c, consumed["A"][0], produced1["A"][0])
assertMsg(c, consumed["B"][0], produced4["B"][0])
assertMsg(c, consumed["C"][0], produced4["C"][0])
sc.Stop()
}
示例2: register
// register listens for topic subscription updates on the `topicsCh` channel
// and updates the member registration in ZooKeeper accordingly.
func (cgr *consumerGroupRegistry) register() {
cid := cgr.baseCID.NewChild("register")
defer cid.LogScope()()
defer cgr.retry(cgr.groupMemberZNode.Deregister,
func(err error) bool { return err != nil && err != kazoo.ErrInstanceNotRegistered },
fmt.Sprintf("<%s> failed to deregister", cid))
for {
var topics []string
select {
case topics = <-cgr.topicsCh:
case <-cgr.stoppingCh:
return
}
sort.Sort(sort.StringSlice(topics))
log.Infof("<%s> registering...: id=%s, topics=%v", cid, cgr.groupMemberZNode.ID, topics)
if cgr.retry(
func() error {
if err := cgr.groupMemberZNode.Deregister(); err != nil && err != kazoo.ErrInstanceNotRegistered {
return fmt.Errorf("could not deregister: err=(%s)", err)
}
return cgr.groupMemberZNode.Register(topics)
},
nil, fmt.Sprintf("<%s> failed to register", cid),
) {
return
}
log.Infof("<%s> registered: id=%s, topics=%v", cid, cgr.groupMemberZNode.ID, topics)
}
}
示例3: TestTooFewPartitions
// When there are more consumers in a group then partitions in a topic then
// some consumers get assigned no partitions and their consume requests timeout.
func (s *SmartConsumerSuite) TestTooFewPartitions(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.1")
produced := s.kh.PutMessages("few", "test.1", map[string]int{"": 3})
sc1, err := Spawn(testhelpers.NewTestConfig("consumer-1"))
c.Assert(err, IsNil)
log.Infof("*** GIVEN 1")
// Consume first message to make `consumer-1` subscribe for `test.1`
consumed := s.consume(c, sc1, "group-1", "test.1", 2)
assertMsg(c, consumed[""][0], produced[""][0])
// When:
log.Infof("*** WHEN")
sc2, err := Spawn(testhelpers.NewTestConfig("consumer-2"))
c.Assert(err, IsNil)
_, err = sc2.Consume("group-1", "test.1")
// Then: `consumer-2` request times out, when `consumer-1` requests keep
// return messages.
log.Infof("*** THEN")
if _, ok := err.(ErrRequestTimeout); !ok {
c.Errorf("Expected ErrConsumerRequestTimeout, got %s", err)
}
s.consume(c, sc1, "group-1", "test.1", 1, consumed)
assertMsg(c, consumed[""][1], produced[""][1])
sc1.Stop()
sc2.Stop()
}
示例4: sendMembershipUpdate
// sendMembershipUpdate retrieves registration records for the specified members
// from ZooKeeper and sends current list of members along with topics they are
// subscribed to down the `membershipChangesCh`. The method can be interrupted
// any time by the stop signal.
//
// FIXME: It is assumed that all members of the group are registered with the
// FIXME: `static` pattern. If a member that pattern is either `white_list` or
// FIXME: `black_list` joins the group the result will be unpredictable.
func (cgr *consumerGroupRegistry) sendMembershipUpdate(cid *sarama.ContextID, members []*kazoo.ConsumergroupInstance) {
log.Infof("<%s> fetching group subscriptions...", cid)
subscriptions := make(map[string][]string, len(members))
for _, member := range members {
var registration *kazoo.Registration
if cgr.retry(
func() error {
var err error
registration, err = member.Registration()
return err
},
nil, fmt.Sprintf("<%s> failed to get member registration", cid),
) {
return
}
// Sort topics to ensure deterministic output.
topics := make([]string, 0, len(registration.Subscription))
for topic := range registration.Subscription {
topics = append(topics, topic)
}
sort.Sort(sort.StringSlice(topics))
subscriptions[member.ID] = topics
}
log.Infof("<%s> group subscriptions changed: %v", cid, subscriptions)
select {
case cgr.membershipChangesCh <- subscriptions:
case <-cgr.stoppingCh:
return
}
}
示例5: TestRequestDuringTimeout
// This test makes an attempt to exercise the code path where a message is
// received when a down stream dispatch tier is being stopped due to
// registration timeout, in that case a successor tier is created that will be
// started as soon as the original one is completely shutdown.
//
// It is impossible to see from the service behavior if the expected code path
// has been exercised by the test. The only way to check that is through the
// code coverage reports.
func (s *SmartConsumerSuite) TestRequestDuringTimeout(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.4")
s.kh.PutMessages("join", "test.4", map[string]int{"A": 30})
cfg := testhelpers.NewTestConfig("consumer-1")
cfg.Consumer.RegistrationTimeout = 200 * time.Millisecond
cfg.Consumer.ChannelBufferSize = 1
sc, err := Spawn(cfg)
c.Assert(err, IsNil)
// When/Then
for i := 0; i < 10; i++ {
for j := 0; j < 3; j++ {
begin := time.Now()
log.Infof("*** consuming...")
consMsg, err := sc.Consume("group-1", "test.4")
c.Assert(err, IsNil)
log.Infof("*** consumed: in=%s, by=%s, topic=%s, partition=%d, offset=%d, message=%s",
time.Now().Sub(begin), sc.baseCID.String(), consMsg.Topic, consMsg.Partition, consMsg.Offset, consMsg.Value)
}
time.Sleep(200 * time.Millisecond)
}
sc.Stop()
}
示例6: TestMultiplePartitions
// If we consume from a topic that has several partitions then partitions are
// selected for consumption in random order.
func (s *SmartConsumerSuite) TestMultiplePartitions(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.4")
s.kh.PutMessages("multiple.partitions", "test.4", map[string]int{"A": 100, "B": 100})
log.Infof("*** GIVEN 1")
sc, err := Spawn(testhelpers.NewTestConfig("consumer-1"))
c.Assert(err, IsNil)
// When: exactly one half of all produced events is consumed.
log.Infof("*** WHEN")
consumed := s.consume(c, sc, "group-1", "test.4", 1)
// Wait until first messages from partitions `A` and `B` are fetched.
waitFirstFetched(sc, 2)
// Consume 100 messages total
consumed = s.consume(c, sc, "group-1", "test.4", 99, consumed)
// Then: we have events consumed from both partitions more or less evenly.
log.Infof("*** THEN")
if len(consumed["A"]) < 25 || len(consumed["A"]) > 75 {
c.Errorf("Consumption disbalance: consumed[A]=%d, consumed[B]=%d", len(consumed["A"]), len(consumed["B"]))
}
sc.Stop()
}
示例7: TestSequentialConsume
// If we stop one consumer and start another, the new one picks up where the
// previous one left off.
func (s *SmartConsumerSuite) TestSequentialConsume(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.1")
produced := s.kh.PutMessages("sequencial", "test.1", map[string]int{"": 3})
cfg := testhelpers.NewTestConfig("consumer-1")
sc1, err := Spawn(cfg)
c.Assert(err, IsNil)
log.Infof("*** GIVEN 1")
consumed := s.consume(c, sc1, "group-1", "test.1", 2)
assertMsg(c, consumed[""][0], produced[""][0])
assertMsg(c, consumed[""][1], produced[""][1])
// When: one consumer stopped and another one takes its place.
log.Infof("*** WHEN")
sc1.Stop()
sc2, err := Spawn(cfg)
c.Assert(err, IsNil)
// Then: the second message is consumed.
log.Infof("*** THEN")
consumed = s.consume(c, sc2, "group-1", "test.1", 1, consumed)
assertMsg(c, consumed[""][2], produced[""][2])
sc2.Stop()
}
示例8: TestLotsOfPartitions
// A topic that has a lot of partitions can be consumed.
func (s *SmartConsumerSuite) TestLotsOfPartitions(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.64")
cfg := testhelpers.NewTestConfig("consumer-1")
sc, err := Spawn(cfg)
c.Assert(err, IsNil)
// Consume should stop by timeout and nothing should be consumed.
msg, err := sc.Consume("group-1", "test.64")
if _, ok := err.(ErrRequestTimeout); !ok {
c.Fatalf("Unexpected message consumed: %v", msg)
}
s.kh.PutMessages("lots", "test.64", map[string]int{"A": 7, "B": 13, "C": 169})
// When
log.Infof("*** WHEN")
consumed := s.consume(c, sc, "group-1", "test.64", consumeAll)
// Then
log.Infof("*** THEN")
c.Assert(7, Equals, len(consumed["A"]))
c.Assert(13, Equals, len(consumed["B"]))
c.Assert(169, Equals, len(consumed["C"]))
sc.Stop()
}
示例9: TestRebalanceOnTimeout
// When a consumer registration times out the partitions that used to be
// assigned to it are redistributed among active consumers.
func (s *SmartConsumerSuite) TestRebalanceOnTimeout(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.4")
s.kh.PutMessages("join", "test.4", map[string]int{"A": 10, "B": 10})
sc1, err := Spawn(testhelpers.NewTestConfig("consumer-1"))
c.Assert(err, IsNil)
cfg2 := testhelpers.NewTestConfig("consumer-2")
cfg2.Consumer.RegistrationTimeout = 300 * time.Millisecond
sc2, err := Spawn(cfg2)
c.Assert(err, IsNil)
// Consume the first message to make the consumers join the group and
// subscribe to the topic.
log.Infof("*** GIVEN 1")
consumed1 := s.consume(c, sc1, "group-1", "test.4", 1)
consumed2 := s.consume(c, sc2, "group-1", "test.4", 1)
if len(consumed1["B"]) == 0 {
c.Assert(len(consumed1["A"]), Equals, 1)
} else {
c.Assert(len(consumed1["A"]), Equals, 0)
}
c.Assert(len(consumed2["A"]), Equals, 0)
c.Assert(len(consumed2["B"]), Equals, 1)
// Consume 4 more messages to make sure that each consumer pulls from a
// particular assigned to it.
log.Infof("*** GIVEN 2")
consumed1 = s.consume(c, sc1, "group-1", "test.4", 4, consumed1)
consumed2 = s.consume(c, sc2, "group-1", "test.4", 4, consumed2)
if len(consumed1["B"]) == 1 {
c.Assert(len(consumed1["A"]), Equals, 4)
} else {
c.Assert(len(consumed1["A"]), Equals, 5)
}
c.Assert(len(consumed2["A"]), Equals, 0)
c.Assert(len(consumed2["B"]), Equals, 5)
drainFirstFetched(sc1)
// When: `consumer-2` registration timeout elapses, the partitions get
// rebalanced so that `consumer-1` becomes assigned to all of them...
log.Infof("*** WHEN")
// Wait for partition `B` reassigned back to sc1.
waitFirstFetched(sc1, 1)
// ...and consumes the remaining messages from all partitions.
log.Infof("*** THEN")
consumed1 = s.consume(c, sc1, "group-1", "test.4", 10, consumed1)
c.Assert(len(consumed1["A"]), Equals, 10)
c.Assert(len(consumed1["B"]), Equals, 5)
c.Assert(len(consumed2["A"]), Equals, 0)
c.Assert(len(consumed2["B"]), Equals, 5)
sc2.Stop()
sc1.Stop()
}
示例10: dispatch
// dispatch implements message processing and graceful shutdown. It receives
// messages from `dispatchedCh` where they are send to by `Produce` method and
// submits them to the embedded `sarama.AsyncProducer`. The dispatcher main
// purpose is to prevent loss of messages during shutdown. It achieves that by
// allowing some graceful period after it stops receiving messages and stopping
// the embedded `sarama.AsyncProducer`.
func (gp *GracefulProducer) dispatch() {
cid := gp.baseCID.NewChild("dispatch")
defer cid.LogScope()()
nilOrDispatcherCh := gp.dispatcherCh
var nilOrProdInputCh chan<- *sarama.ProducerMessage
pendingMsgCount := 0
// The normal operation loop is implemented as two-stroke machine. On the
// first stroke a message is received from `dispatchCh`, and on the second
// it is sent to `prodInputCh`. Note that producer results can be received
// at any time.
prodMsg := (*sarama.ProducerMessage)(nil)
channelOpened := true
for {
select {
case prodMsg, channelOpened = <-nilOrDispatcherCh:
if !channelOpened {
goto gracefulShutdown
}
pendingMsgCount += 1
nilOrDispatcherCh = nil
nilOrProdInputCh = gp.saramaProducer.Input()
case nilOrProdInputCh <- prodMsg:
nilOrDispatcherCh = gp.dispatcherCh
nilOrProdInputCh = nil
case prodResult := <-gp.resultCh:
pendingMsgCount -= 1
gp.handleProduceResult(cid, prodResult)
}
}
gracefulShutdown:
// Give the `sarama.AsyncProducer` some time to commit buffered messages.
log.Infof("<%v> About to stop producer: pendingMsgCount=%d", cid, pendingMsgCount)
shutdownTimeoutCh := time.After(gp.shutdownTimeout)
for pendingMsgCount > 0 {
select {
case <-shutdownTimeoutCh:
goto shutdownNow
case prodResult := <-gp.resultCh:
pendingMsgCount -= 1
gp.handleProduceResult(cid, prodResult)
}
}
shutdownNow:
log.Infof("<%v> Stopping producer: pendingMsgCount=%d", cid, pendingMsgCount)
gp.saramaProducer.AsyncClose()
for prodResult := range gp.resultCh {
gp.handleProduceResult(cid, prodResult)
}
}
示例11: claimPartition
func (cgr *consumerGroupRegistry) claimPartition(cid *sarama.ContextID, topic string, partition int32, cancelCh <-chan none) func() {
if !retry(func() error { return cgr.groupMemberZNode.ClaimPartition(topic, partition) }, nil,
fmt.Sprintf("<%s> failed to claim partition", cid), cgr.config.Consumer.BackOffTimeout, cancelCh,
) {
log.Infof("<%s> partition claimed", cid)
}
return func() {
if !retry(func() error { return cgr.groupMemberZNode.ReleasePartition(topic, partition) },
func(err error) bool { return err != nil && err != kazoo.ErrPartitionNotClaimed },
fmt.Sprintf("<%s> failed to release partition", cid), cgr.config.Consumer.BackOffTimeout, cancelCh,
) {
log.Infof("<%s> partition released", cid)
}
}
}
示例12: GenMessages
func GenMessages(c *C, prefix, topic string, keys map[string]int) map[string][]*sarama.ProducerMessage {
config := NewConfig()
config.ClientID = "producer"
config.Kafka.SeedPeers = testKafkaPeers
producer, err := SpawnGracefulProducer(config)
c.Assert(err, IsNil)
messages := make(map[string][]*sarama.ProducerMessage)
var wg sync.WaitGroup
var lock sync.Mutex
for key, count := range keys {
for i := 0; i < count; i++ {
key := key
message := fmt.Sprintf("%s:%s:%d", prefix, key, i)
spawn(&wg, func() {
keyEncoder := sarama.StringEncoder(key)
msgEncoder := sarama.StringEncoder(message)
prodMsg, err := producer.Produce(topic, keyEncoder, msgEncoder)
c.Assert(err, IsNil)
log.Infof("*** produced: topic=%s, partition=%d, offset=%d, message=%s",
topic, prodMsg.Partition, prodMsg.Offset, message)
lock.Lock()
messages[key] = append(messages[key], prodMsg)
lock.Unlock()
})
}
}
wg.Wait()
// Sort the produced messages in ascending order of their offsets.
for _, keyMessages := range messages {
sort.Sort(MessageSlice(keyMessages))
}
return messages
}
示例13: TestBufferOverflowError
// A `ErrConsumerBufferOverflow` error can be returned if internal buffers are
// filled with in-flight consume requests.
func (s *SmartConsumerSuite) TestBufferOverflowError(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.1")
s.kh.PutMessages("join", "test.1", map[string]int{"A": 30})
cfg := testhelpers.NewTestConfig("consumer-1")
cfg.Consumer.ChannelBufferSize = 1
sc, err := Spawn(cfg)
c.Assert(err, IsNil)
// When
var overflowErrorCount int32
var wg sync.WaitGroup
for i := 0; i < 3; i++ {
spawn(&wg, func() {
for i := 0; i < 10; i++ {
_, err := sc.Consume("group-1", "test.1")
if _, ok := err.(ErrBufferOverflow); ok {
atomic.AddInt32(&overflowErrorCount, 1)
}
}
})
}
wg.Wait()
// Then
c.Assert(overflowErrorCount, Not(Equals), 0)
log.Infof("*** overflow was hit %d times", overflowErrorCount)
sc.Stop()
}
示例14: waitFirstFetched
func waitFirstFetched(sc *T, count int) {
var partitions []int32
for i := 0; i < count; i++ {
ec := <-firstMessageFetchedCh
partitions = append(partitions, ec.partition)
}
log.Infof("*** first messages fetched: partitions=%v", partitions)
}
示例15: TestRebalanceOnJoin
// When a new consumer joins a group the partitions get evenly redistributed
// among all consumers.
func (s *SmartConsumerSuite) TestRebalanceOnJoin(c *C) {
// Given
s.kh.ResetOffsets("group-1", "test.4")
s.kh.PutMessages("join", "test.4", map[string]int{"A": 10, "B": 10})
sc1, err := Spawn(testhelpers.NewTestConfig("consumer-1"))
c.Assert(err, IsNil)
// Consume the first message to make the consumer join the group and
// subscribe to the topic.
log.Infof("*** GIVEN 1")
consumed1 := s.consume(c, sc1, "group-1", "test.4", 1)
// Wait until first messages from partitions `A` and `B` are fetched.
waitFirstFetched(sc1, 2)
// Consume 4 messages and make sure that there are messages from both
// partitions among them.
log.Infof("*** GIVEN 2")
consumed1 = s.consume(c, sc1, "group-1", "test.4", 4, consumed1)
c.Assert(len(consumed1["A"]), Not(Equals), 0)
c.Assert(len(consumed1["B"]), Not(Equals), 0)
consumedBeforeJoin := len(consumed1["B"])
// When: another consumer joins the group rebalancing occurs.
log.Infof("*** WHEN")
sc2, err := Spawn(testhelpers.NewTestConfig("consumer-2"))
c.Assert(err, IsNil)
// Then:
log.Infof("*** THEN")
consumed2 := s.consume(c, sc2, "group-1", "test.4", consumeAll)
consumed1 = s.consume(c, sc1, "group-1", "test.4", consumeAll, consumed1)
// Partition "A" has been consumed by `consumer-1` only
c.Assert(len(consumed1["A"]), Equals, 10)
c.Assert(len(consumed2["A"]), Equals, 0)
// Partition "B" has been consumed by both consumers, but ever since
// `consumer-2` joined the group the first one have not got any new messages.
c.Assert(len(consumed1["B"]), Equals, consumedBeforeJoin)
c.Assert(len(consumed2["B"]), Not(Equals), 0)
c.Assert(len(consumed1["B"])+len(consumed2["B"]), Equals, 10)
// `consumer-2` started consumer from where `consumer-1` left off.
c.Assert(consumed2["B"][0].Offset, Equals, consumed1["B"][len(consumed1["B"])-1].Offset+1)
sc2.Stop()
sc1.Stop()
}