Documentation ¶
Index ¶
- Variables
- func DefaultAccountCallback(name string, id int, start, end time.Time)
- func FlowMessageToJSON(fmsg *flowmessage.FlowMessage) string
- func FlowMessageToString(fmsg *flowmessage.FlowMessage) string
- func GetServiceAddresses(srv string) (addrs []string, err error)
- func UDPRoutine(name string, decodeFunc decoder.DecoderFunc, workers int, addr string, ...) error
- type BaseMessage
- type DefaultErrorCallback
- type DefaultJSONTransport
- type DefaultLogTransport
- type Logger
- type StateNFLegacy
- type StateNetFlow
- type StateSFlow
- type TemplateSystem
- type Transport
Constants ¶
This section is empty.
Variables ¶
View Source
var ( MetricTrafficBytes = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_traffic_bytes", Help: "Bytes received by the application.", }, []string{"remote_ip", "remote_port", "local_ip", "local_port", "type"}, ) MetricTrafficPackets = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_traffic_packets", Help: "Packets received by the application.", }, []string{"remote_ip", "remote_port", "local_ip", "local_port", "type"}, ) MetricPacketSizeSum = prometheus.NewSummaryVec( prometheus.SummaryOpts{ Name: "flow_traffic_summary_size_bytes", Help: "Summary of packet size.", Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.99: 0.001}, }, []string{"remote_ip", "remote_port", "local_ip", "local_port", "type"}, ) DecoderStats = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_decoder_count", Help: "Decoder processed count.", }, []string{"worker", "name"}, ) DecoderErrors = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_decoder_error_count", Help: "Decoder processed error count.", }, []string{"worker", "name"}, ) DecoderTime = prometheus.NewSummaryVec( prometheus.SummaryOpts{ Name: "flow_summary_decoding_time_us", Help: "Decoding time summary.", Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.99: 0.001}, }, []string{"name"}, ) DecoderProcessTime = prometheus.NewSummaryVec( prometheus.SummaryOpts{ Name: "flow_summary_processing_time_us", Help: "Processing time summary.", Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.99: 0.001}, }, []string{"name"}, ) NetFlowStats = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_nf_count", Help: "NetFlows processed.", }, []string{"router", "version"}, ) NetFlowErrors = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_nf_errors_count", Help: "NetFlows processed errors.", }, []string{"router", "error"}, ) NetFlowSetRecordsStatsSum = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_nf_flowset_records_sum", Help: "NetFlows FlowSets sum of records.", }, []string{"router", "version", "type"}, ) NetFlowSetStatsSum = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_nf_flowset_sum", Help: "NetFlows FlowSets sum.", }, []string{"router", "version", "type"}, ) NetFlowTimeStatsSum = prometheus.NewSummaryVec( prometheus.SummaryOpts{ Name: "flow_process_nf_delay_summary_seconds", Help: "NetFlows time difference between time of flow and processing.", Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.99: 0.001}, }, []string{"router", "version"}, ) NetFlowTemplatesStats = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_nf_templates_count", Help: "NetFlows Template count.", }, []string{"router", "version", "obs_domain_id", "template_id", "type"}, ) SFlowStats = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_sf_count", Help: "sFlows processed.", }, []string{"router", "agent", "version"}, ) SFlowErrors = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_sf_errors_count", Help: "sFlows processed errors.", }, []string{"router", "error"}, ) SFlowSampleStatsSum = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_sf_samples_sum", Help: "SFlows samples sum.", }, []string{"router", "agent", "version", "type"}, ) SFlowSampleRecordsStatsSum = prometheus.NewCounterVec( prometheus.CounterOpts{ Name: "flow_process_sf_samples_records_sum", Help: "SFlows samples sum of records.", }, []string{"router", "agent", "version", "type"}, ) )
View Source
var (
MessageFields = flag.String("message.fields", defaultFields, "The list of fields to include in flow messages")
)
Functions ¶
func DefaultAccountCallback ¶
func FlowMessageToJSON ¶
func FlowMessageToJSON(fmsg *flowmessage.FlowMessage) string
func FlowMessageToString ¶
func FlowMessageToString(fmsg *flowmessage.FlowMessage) string
func GetServiceAddresses ¶
Types ¶
type BaseMessage ¶
type DefaultErrorCallback ¶
type DefaultErrorCallback struct {
Logger Logger
}
type DefaultJSONTransport ¶
type DefaultJSONTransport struct { }
func (*DefaultJSONTransport) Publish ¶
func (s *DefaultJSONTransport) Publish(msgs []*flowmessage.FlowMessage)
type DefaultLogTransport ¶
type DefaultLogTransport struct { }
func (*DefaultLogTransport) Publish ¶
func (s *DefaultLogTransport) Publish(msgs []*flowmessage.FlowMessage)
type StateNFLegacy ¶
func (*StateNFLegacy) DecodeFlow ¶
func (s *StateNFLegacy) DecodeFlow(msg interface{}) error
func (*StateNFLegacy) FlowRoutine ¶
type StateNetFlow ¶
type StateNetFlow struct { Transport Transport Logger Logger // contains filtered or unexported fields }
func (*StateNetFlow) DecodeFlow ¶
func (s *StateNetFlow) DecodeFlow(msg interface{}) error
func (*StateNetFlow) FlowRoutine ¶
func (*StateNetFlow) InitTemplates ¶
func (s *StateNetFlow) InitTemplates()
func (*StateNetFlow) ServeHTTPTemplates ¶
func (s *StateNetFlow) ServeHTTPTemplates(w http.ResponseWriter, r *http.Request)
type StateSFlow ¶
type StateSFlow struct { Transport Transport Logger Logger Config *producer.SFlowProducerConfig }
func (*StateSFlow) DecodeFlow ¶
func (s *StateSFlow) DecodeFlow(msg interface{}) error
func (*StateSFlow) FlowRoutine ¶
type TemplateSystem ¶
type TemplateSystem struct {
// contains filtered or unexported fields
}
func (*TemplateSystem) AddTemplate ¶
func (s *TemplateSystem) AddTemplate(version uint16, obsDomainId uint32, template interface{})
func (*TemplateSystem) GetTemplate ¶
func (s *TemplateSystem) GetTemplate(version uint16, obsDomainId uint32, templateId uint16) (interface{}, error)
type Transport ¶
type Transport interface {
Publish([]*flowmessage.FlowMessage)
}
Click to show internal directories.
Click to hide internal directories.