本文整理匯總了Golang中github.com/griesbacher/nagflux/logging.GetLogger函數的典型用法代碼示例。如果您正苦於以下問題:Golang GetLogger函數的具體用法?Golang GetLogger怎麽用?Golang GetLogger使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了GetLogger函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: run
//Delegates the files to its workers.
func (s *NagiosSpoolfileCollector) run() {
promServer := statistics.GetPrometheusServer()
for {
select {
case <-s.quit:
s.quit <- true
return
case <-time.After(IntervalToCheckDirectory):
pause := config.PauseNagflux.Load().(bool)
if pause {
logging.GetLogger().Debugln("NagiosSpoolfileCollector in pause")
continue
}
logging.GetLogger().Debug("Reading Directory: ", s.spoolDirectory)
files, _ := ioutil.ReadDir(s.spoolDirectory)
promServer.SpoolFilesOnDisk.Set(float64(len(files)))
for _, currentFile := range files {
select {
case <-s.quit:
s.quit <- true
return
case s.jobs <- path.Join(s.spoolDirectory, currentFile.Name()):
case <-time.After(time.Duration(1) * time.Minute):
logging.GetLogger().Warn("NagiosSpoolfileCollector: Could not write to buffer")
}
}
}
}
}
示例2: run
//Checks if the files are old enough, if so they will be added in the queue
func (nfc FileCollector) run() {
for {
select {
case <-nfc.quit:
nfc.quit <- true
return
case <-time.After(spoolfile.IntervalToCheckDirectory):
pause := config.PauseNagflux.Load().(bool)
if pause {
logging.GetLogger().Debugln("NagfluxFileCollector in pause")
continue
}
for _, currentFile := range spoolfile.FilesInDirectoryOlderThanX(nfc.folder, spoolfile.MinFileAge) {
for _, p := range nfc.parseFile(currentFile) {
for _, r := range nfc.results {
select {
case <-nfc.quit:
nfc.quit <- true
return
case r <- p:
case <-time.After(time.Duration(1) * time.Minute):
nfc.log.Warn("NagfluxFileCollector: Could not write to buffer")
}
}
}
err := os.Remove(currentFile)
if err != nil {
logging.GetLogger().Warn(err)
}
}
}
}
}
示例3: NewPrometheusServer
//NewPrometheusServer creates a new PrometheusServer
func NewPrometheusServer(address string) PrometheusServer {
pMutex.Lock()
server = initServerConfig()
pMutex.Unlock()
if address != "" {
go func() {
http.Handle("/metrics", prometheus.Handler())
if err := http.ListenAndServe(address, nil); err != nil {
logging.GetLogger().Warn(err.Error())
}
}()
logging.GetLogger().Infof("serving prometheus metrics at %s/metrics", address)
}
return server
}
示例4: NewGearmanWorker
//NewGearmanWorker generates a new GearmanWorker.
//leave the key empty to disable encryption, otherwise the gearmanpacketes are expected to be encrpyten with AES-ECB 128Bit and a 32 Byte Key.
func NewGearmanWorker(address, queue, key string, results map[data.Datatype]chan collector.Printable, livestatusCacheBuilder *livestatus.CacheBuilder) *GearmanWorker {
var decrypter *crypto.AESECBDecrypter
if key != "" {
byteKey := ShapeKey(key, 32)
var err error
decrypter, err = crypto.NewAESECBDecrypter(byteKey)
if err != nil {
panic(err)
}
}
worker := &GearmanWorker{
quit: make(chan bool),
results: results,
nagiosSpoolfileWorker: spoolfile.NewNagiosSpoolfileWorker(-1, make(chan string), make(map[data.Datatype]chan collector.Printable), livestatusCacheBuilder),
aesECBDecrypter: decrypter,
worker: createGearmanWorker(address),
log: logging.GetLogger(),
jobQueue: queue,
}
go worker.run()
go worker.handleLoad()
go worker.handlePause()
return worker
}
示例5: TestConnectToLivestatus
func TestConnectToLivestatus(t *testing.T) {
//Create Livestatus mock
livestatus := MockLivestatus{"localhost:6557", "tcp", map[string]string{"test\n\n": "foo;bar\n"}, true}
go livestatus.StartMockLivestatus()
connector := LivestatusConnector{logging.GetLogger(), livestatus.LivestatusAddress, livestatus.ConnectionType}
csv := make(chan []string)
finished := make(chan bool)
go connector.connectToLivestatus("test\n\n", csv, finished)
expected := []string{"foo", "bar"}
waitingForTheEnd := true
for waitingForTheEnd {
select {
case line := <-csv:
if !reflect.DeepEqual(line, expected) {
t.Errorf("Expected:%s result:%s", expected, line)
}
case result := <-finished:
if !result {
t.Error("Connector exited with error")
}
waitingForTheEnd = false
case <-time.After(time.Duration(3) * time.Second):
t.Error("Livestatus connection timed out")
}
}
livestatus.StopMockLivestatus()
}
示例6: run
//Checks if the files are old enough, if so they will be added in the queue
func (nfc NagfluxFileCollector) run() {
for {
select {
case <-nfc.quit:
nfc.quit <- true
return
case <-time.After(spoolfile.IntervalToCheckDirectory):
for _, currentFile := range spoolfile.FilesInDirectoryOlderThanX(nfc.folder, spoolfile.MinFileAgeInSeconds) {
data, err := ioutil.ReadFile(currentFile)
if err != nil {
break
}
for _, line := range strings.SplitAfter(string(data), "\n") {
line = strings.TrimSpace(line)
if line == "" {
continue
}
select {
case <-nfc.quit:
nfc.quit <- true
return
case nfc.results <- line:
case <-time.After(time.Duration(1) * time.Minute):
nfc.log.Warn("NagfluxFileCollector: Could not write to buffer")
}
}
err = os.Remove(currentFile)
if err != nil {
logging.GetLogger().Warn(err)
}
}
}
}
}
示例7: Stop
//Stops his workers and itself.
func (s *NagiosSpoolfileCollector) Stop() {
s.quit <- true
<-s.quit
for _, worker := range s.workers {
worker.Stop()
}
logging.GetLogger().Debug("SpoolfileCollector stopped")
}
示例8: TestNewCacheBuilder
func TestNewCacheBuilder(t *testing.T) {
logging.InitTestLogger()
connector := &Connector{logging.GetLogger(), "localhost:6558", "tcp"}
builder := NewLivestatusCacheBuilder(connector)
if builder == nil {
t.Error("Constructor returned null pointer")
}
}
示例9: NagiosSpoolfileWorkerGenerator
//Generates a worker and starts it.
func NagiosSpoolfileWorkerGenerator(jobs chan string, results chan interface{}, fieldseperator string, livestatusCacheBuilder *livestatus.LivestatusCacheBuilder) func() *NagiosSpoolfileWorker {
workerId := 0
regexPerformancelable, err := regexp.Compile(`([^=]+)=(U|[\d\.\-]+)([\w\/%]*);?([\d\.\-:[email protected]]+)?;?([\d\.\-:[email protected]]+)?;?([\d\.\-]+)?;?([\d\.\-]+)?;?\s*`)
if err != nil {
logging.GetLogger().Error("Regex creation failed:", err)
}
regexAltCommand, err := regexp.Compile(`.*\[(.*)\]\s?$`)
if err != nil {
logging.GetLogger().Error("Regex creation failed:", err)
}
return func() *NagiosSpoolfileWorker {
s := &NagiosSpoolfileWorker{workerId, make(chan bool), jobs, results, statistics.NewCmdStatisticReceiver(), fieldseperator, livestatusCacheBuilder, regexPerformancelable, regexAltCommand}
workerId++
go s.run()
return s
}
}
示例10: GetYearMonthFromStringTimeMs
//GetYearMonthFromStringTimeMs returns the year and the month of a string which is in ms.
func GetYearMonthFromStringTimeMs(timeString string) (int, int) {
i, err := strconv.ParseInt(timeString[:len(timeString)-3], 10, 64)
if err != nil {
logging.GetLogger().Warn(err.Error())
}
date := time.Unix(i, 0)
return date.Year(), int(date.Month())
}
示例11: Print
//Prints the data in influxdb lineformat
func (notification LivestatusNotificationData) Print(version float32) string {
notification.sanitizeValues()
if version >= 0.9 {
var tags string
if notification.notification_type == "HOST\\ NOTIFICATION" {
tags = ",type=host_notification"
} else if notification.notification_type == "SERVICE\\ NOTIFICATION" {
tags = ",type=service_notification"
} else {
logging.GetLogger().Warn("This notification type is not supported:" + notification.notification_type)
}
value := fmt.Sprintf("%s:<br> %s", strings.TrimSpace(notification.notification_level), notification.comment)
return notification.genInfluxLineWithValue(tags, value)
} else {
logging.GetLogger().Fatalf("This influxversion [%f] given in the config is not supportet", version)
return ""
}
}
示例12: PrintForElasticsearch
//PrintForElasticsearch prints in the elasticsearch json format
func (notification NotificationData) PrintForElasticsearch(version, index string) string {
if helper.VersionOrdinal(version) >= helper.VersionOrdinal("2.0") {
text := notificationToText(notification.notificationType)
value := fmt.Sprintf("%s:<br> %s", strings.TrimSpace(notification.notificationLevel), notification.comment)
return notification.genElasticLineWithValue(index, text, value, notification.entryTime)
}
logging.GetLogger().Criticalf("This elasticsearchversion [%f] given in the config is not supported", version)
panic("")
}
示例13: TestNewLivestatusCollector
func TestNewLivestatusCollector(t *testing.T) {
livestatus := &MockLivestatus{"localhost:6559", "tcp", map[string]string{}, true}
go livestatus.StartMockLivestatus()
connector := &LivestatusConnector{logging.GetLogger(), "localhost:6559", "tcp"}
collector := NewLivestatusCollector(make(chan interface{}), connector, "&")
if collector == nil {
t.Error("Constructor returned null pointer")
}
collector.Stop()
}
示例14: PrintForElasticsearch
//PrintForElasticsearch prints in the elasticsearch json format
func (downtime DowntimeData) PrintForElasticsearch(version, index string) string {
if helper.VersionOrdinal(version) >= helper.VersionOrdinal("2.0") {
typ := `downtime`
start := downtime.genElasticLineWithValue(index, typ, strings.TrimSpace("Downtime start: <br>"+downtime.comment), downtime.entryTime)
end := downtime.genElasticLineWithValue(index, typ, strings.TrimSpace("Downtime end: <br>"+downtime.comment), downtime.endTime)
return start + "\n" + end
}
logging.GetLogger().Criticalf("This elasticsearchversion [%f] given in the config is not supported", version)
panic("")
}
示例15: TestNewLivestatusCollector
func TestNewLivestatusCollector(t *testing.T) {
livestatus := &MockLivestatus{"localhost:6559", "tcp", map[string]string{}, true}
go livestatus.StartMockLivestatus()
connector := &Connector{logging.GetLogger(), "localhost:6559", "tcp"}
collector := NewLivestatusCollector(make(map[data.Datatype]chan collector.Printable), connector, false)
if collector == nil {
t.Error("Constructor returned null pointer")
}
collector.Stop()
}