-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjournalctl.go
105 lines (97 loc) · 2.88 KB
/
journalctl.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// +build linux
package vdlog
import (
"fmt"
"os/exec"
"strings"
)
// Mapping between journalctl and vdlog levels
// journald vdlog
// 0: emerg 0:LevelError
// 1: alert 0:LevelError
// 2: crit 0:LevelError
// 3: err 0:LevelError
// 4: warning 1:LevelWarn
// 5: notice 2:LevelInfo
// 6: info 3:LevelVerbose
// 7: debug 4:LevelDebug
func createJournaldSink(host string, port int, tcp, local bool) func(e Event) error {
return func(e Event) error {
var journaldPriority int
switch e.Level {
case LevelError:
journaldPriority = 3
break
case LevelWarn:
journaldPriority = 4
break
case LevelInfo:
journaldPriority = 5
break
case LevelVerbose:
journaldPriority = 6
break
case LevelDebug:
journaldPriority = 7
break
default:
journaldPriority = 5
}
var cmd *exec.Cmd
if local {
cmd = exec.Command("/bin/logger", "--journald")
} else {
var protoParams string
if tcp {
protoParams = "--tcp"
} else {
protoParams = "--udp"
}
cmd = exec.Command("/bin/logger",
"--journald",
fmt.Sprintf("--server %s", host),
fmt.Sprintf("--port %v", port),
protoParams,
)
}
stdin, err := cmd.StdinPipe()
if err != nil {
return err
}
//http://man7.org/linux/man-pages/man7/systemd.journal-fields.7.html
fmt.Fprintf(stdin, "MESSAGE_ID=%s\n", e.UUID)
fmt.Fprintf(stdin, "CODE_FILE=%s\n", e.Filename)
fmt.Fprintf(stdin, "CODE_LINE=%v\n", e.Line)
fmt.Fprintf(stdin, "SYSLOG_IDENTIFIER=%s\n", e.Type)
fmt.Fprintf(stdin, "MESSAGE=%s\n", fmt.Sprint(e.Metadata))
fmt.Fprintf(stdin, "PRIORITY=%d\n", journaldPriority)
fmt.Fprintf(stdin, "SYSLOG_PID=%d\n", e.Pid)
fmt.Fprintf(stdin, "OBJECT_PID=%d\n", e.Pid)
fmt.Fprintf(stdin, "VDLOG_LEVEL=%s\n", e.LevelString)
fmt.Fprintf(stdin, "VDLOG_CALLED=%s\n", e.Called)
for k, v := range e.Metadata {
fmt.Fprintf(stdin, "VDLOG_META_%s=%s\n", strings.ToUpper(k), fmt.Sprint(v))
}
err = stdin.Close()
if err != nil {
return err
}
err = cmd.Run()
if err != nil {
return err
}
return nil
}
}
//LogToLocalJournald allows to send messages directly to journald daemon via logger command
func LogToLocalJournald() {
AddSink("journald local", createJournaldSink("localhost", 514, true, true))
}
//LogToRemoteJournaldViaTCP allows to send messages directly to remote journald daemon via logger command and TCP
func LogToRemoteJournaldViaTCP(server string, port int) {
AddSink(fmt.Sprintf("journald tcp(%s:%v)", server, port), createJournaldSink(server, port, true, false))
}
//LogToRemoteJournaldViaUDP allows to send messages directly to remote journald daemon via logger command and UDP
func LogToRemoteJournaldViaUDP(server string, port int) {
AddSink(fmt.Sprintf("journald udp(%s:%v)", server, port), createJournaldSink(server, port, false, false))
}