Add support for NSQLookupd to nsq_consumer (#3215)
This commit is contained in:
		
							parent
							
								
									837e6b1a32
								
							
						
					
					
						commit
						a4b8805f7f
					
				
							
								
								
									
										2
									
								
								Godeps
								
								
								
								
							
							
						
						
									
										2
									
								
								Godeps
								
								
								
								
							|  | @ -44,7 +44,7 @@ github.com/naoina/go-stringutil 6b638e95a32d0c1131db0e7fe83775cbea4a0d0b | ||||||
| github.com/nats-io/go-nats ea9585611a4ab58a205b9b125ebd74c389a6b898 | github.com/nats-io/go-nats ea9585611a4ab58a205b9b125ebd74c389a6b898 | ||||||
| github.com/nats-io/nats ea9585611a4ab58a205b9b125ebd74c389a6b898 | github.com/nats-io/nats ea9585611a4ab58a205b9b125ebd74c389a6b898 | ||||||
| github.com/nats-io/nuid 289cccf02c178dc782430d534e3c1f5b72af807f | github.com/nats-io/nuid 289cccf02c178dc782430d534e3c1f5b72af807f | ||||||
| github.com/nsqio/go-nsq a53d495e81424aaf7a7665a9d32a97715c40e953 | github.com/nsqio/go-nsq eee57a3ac4174c55924125bb15eeeda8cffb6e6f | ||||||
| github.com/opencontainers/runc 89ab7f2ccc1e45ddf6485eaa802c35dcf321dfc8 | github.com/opencontainers/runc 89ab7f2ccc1e45ddf6485eaa802c35dcf321dfc8 | ||||||
| github.com/opentracing-contrib/go-observer a52f2342449246d5bcc273e65cbdcfa5f7d6c63c | github.com/opentracing-contrib/go-observer a52f2342449246d5bcc273e65cbdcfa5f7d6c63c | ||||||
| github.com/opentracing/opentracing-go 06f47b42c792fef2796e9681353e1d908c417827 | github.com/opentracing/opentracing-go 06f47b42c792fef2796e9681353e1d908c417827 | ||||||
|  |  | ||||||
|  | @ -2595,8 +2595,12 @@ | ||||||
| 
 | 
 | ||||||
| # # Read NSQ topic for metrics. | # # Read NSQ topic for metrics. | ||||||
| # [[inputs.nsq_consumer]] | # [[inputs.nsq_consumer]] | ||||||
| #   ## An string representing the NSQD TCP Endpoint | #   ## Server option still works but is deprecated, we just prepend it to the nsqd array. | ||||||
| #   server = "localhost:4150" | #   # server = "localhost:4150" | ||||||
|  | #   ## An array representing the NSQD TCP HTTP Endpoints | ||||||
|  | #   nsqd = ["localhost:4150"] | ||||||
|  | #   ## An array representing the NSQLookupd HTTP Endpoints | ||||||
|  | #   nsqlookupd = ["localhost:4161"] | ||||||
| #   topic = "telegraf" | #   topic = "telegraf" | ||||||
| #   channel = "consumer" | #   channel = "consumer" | ||||||
| #   max_in_flight = 100 | #   max_in_flight = 100 | ||||||
|  | @ -2764,4 +2768,3 @@ | ||||||
| # [[inputs.zipkin]] | # [[inputs.zipkin]] | ||||||
| #   # path = "/api/v1/spans" # URL path for span data | #   # path = "/api/v1/spans" # URL path for span data | ||||||
| #   # port = 9411            # Port on which Telegraf listens | #   # port = 9411            # Port on which Telegraf listens | ||||||
| 
 |  | ||||||
|  |  | ||||||
|  | @ -8,8 +8,12 @@ topic and adds messages to InfluxDB. This plugin allows a message to be in any o | ||||||
| ```toml | ```toml | ||||||
| # Read metrics from NSQD topic(s) | # Read metrics from NSQD topic(s) | ||||||
| [[inputs.nsq_consumer]] | [[inputs.nsq_consumer]] | ||||||
|   ## An array of NSQD HTTP API endpoints |   ## Server option still works but is deprecated, we just prepend it to the nsqd array. | ||||||
|   server = "localhost:4150" |   # server = "localhost:4150" | ||||||
|  |   ## An array representing the NSQD TCP HTTP Endpoints | ||||||
|  |   nsqd = ["localhost:4150"] | ||||||
|  |   ## An array representing the NSQLookupd HTTP Endpoints | ||||||
|  |   nsqlookupd = ["localhost:4161"] | ||||||
|   topic = "telegraf" |   topic = "telegraf" | ||||||
|   channel = "consumer" |   channel = "consumer" | ||||||
|   max_in_flight = 100 |   max_in_flight = 100 | ||||||
|  |  | ||||||
|  | @ -6,12 +6,14 @@ import ( | ||||||
| 	"github.com/influxdata/telegraf" | 	"github.com/influxdata/telegraf" | ||||||
| 	"github.com/influxdata/telegraf/plugins/inputs" | 	"github.com/influxdata/telegraf/plugins/inputs" | ||||||
| 	"github.com/influxdata/telegraf/plugins/parsers" | 	"github.com/influxdata/telegraf/plugins/parsers" | ||||||
| 	"github.com/nsqio/go-nsq" | 	nsq "github.com/nsqio/go-nsq" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| //NSQConsumer represents the configuration of the plugin
 | //NSQConsumer represents the configuration of the plugin
 | ||||||
| type NSQConsumer struct { | type NSQConsumer struct { | ||||||
| 	Server      string | 	Server      string | ||||||
|  | 	Nsqd        []string | ||||||
|  | 	Nsqlookupd  []string | ||||||
| 	Topic       string | 	Topic       string | ||||||
| 	Channel     string | 	Channel     string | ||||||
| 	MaxInFlight int | 	MaxInFlight int | ||||||
|  | @ -21,8 +23,12 @@ type NSQConsumer struct { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| var sampleConfig = ` | var sampleConfig = ` | ||||||
|   ## An string representing the NSQD TCP Endpoint |   ## Server option still works but is deprecated, we just prepend it to the nsqd array. | ||||||
|   server = "localhost:4150" |   # server = "localhost:4150" | ||||||
|  |   ## An array representing the NSQD TCP HTTP Endpoints | ||||||
|  |   nsqd = ["localhost:4150"] | ||||||
|  |   ## An array representing the NSQLookupd HTTP Endpoints | ||||||
|  |   nsqlookupd = ["localhost:4161"] | ||||||
|   topic = "telegraf" |   topic = "telegraf" | ||||||
|   channel = "consumer" |   channel = "consumer" | ||||||
|   max_in_flight = 100 |   max_in_flight = 100 | ||||||
|  | @ -71,7 +77,11 @@ func (n *NSQConsumer) Start(acc telegraf.Accumulator) error { | ||||||
| 		message.Finish() | 		message.Finish() | ||||||
| 		return nil | 		return nil | ||||||
| 	}), n.MaxInFlight) | 	}), n.MaxInFlight) | ||||||
| 	n.consumer.ConnectToNSQD(n.Server) | 
 | ||||||
|  | 	if len(n.Nsqlookupd) > 0 { | ||||||
|  | 		n.consumer.ConnectToNSQLookupds(n.Nsqlookupd) | ||||||
|  | 	} | ||||||
|  | 	n.consumer.ConnectToNSQDs(append(n.Nsqd, n.Server)) | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -40,6 +40,7 @@ func TestReadsMetricsFromNSQ(t *testing.T) { | ||||||
| 		Topic:       "telegraf", | 		Topic:       "telegraf", | ||||||
| 		Channel:     "consume", | 		Channel:     "consume", | ||||||
| 		MaxInFlight: 1, | 		MaxInFlight: 1, | ||||||
|  | 		Nsqd:        []string{"127.0.0.1:4155"}, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	p, _ := parsers.NewInfluxParser() | 	p, _ := parsers.NewInfluxParser() | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue