Comments (5)
From what i read, journalD looks like a Key:Value logging mechanism - Key & Value are both strings. Sent to the systemD which will compress it and store it (log rotate it etc). There are methods to retrieve it / query it etc..
Any client of journalD will need to send a Priority + Message + (Key+Value) Pairs - over a unix socket to journalD or systemD.
Is my understand right ?? If so, this will be another kind of writer - like consoleWriter.. instead of formatting the log message for printing to console - this journaldWriter will convert logs to journalD format (Prio + Msg + KV Pairs) and send it to systemd ??
CBOR (binary) encoding does not add much value to it - since the logs are to be converted to strings to be sent to journalD.
from zerolog.
My understanding is that journald fields is a flat structure with no typing support. We might just want to create a writer that would set the priority field and set the message field with the JSON payload.
from zerolog.
I have written a writer that will write to journald. I tested it by writing an example program. I could use some ideas on how to write a go-test to add tests. First cut diff: toravir@163f52c
from zerolog.
Fixed by #57
from zerolog.
Note to the OP that the way you log to journald (redirecting stdout/stderr or using its socket) is not related to the logs being persistent. If you want journald logs to be persistent, you need to configure it so by setting the Storage option to persistent
or creating the output directory if it's set to auto
. Otherwise they will be in memory only (for most distributions) and will be lost on reboot.
from zerolog.
Related Issues (20)
- Caller confusion when using caller multiple times HOT 2
- Revert #597 HOT 1
- InterfaceMarshalFunc is not called when encoding JSON HOT 2
- Understanding "Zero Allocation" HOT 1
- Is there a recommended way to do batching of log lines and write at once ? HOT 1
- Logs as bytes in Stderr HOT 6
- Deep Example
- Latest official tagged release not up to date in github? HOT 1
- Add an option to limit max log's size after escaping
- Give debug level logs a color again
- ConsoleWriter uses the `level` field key to be invalid or panic? HOT 1
- diode writer does not flush when program exits HOT 1
- Should journald keys be sanitized to strip/replace invalid characters? HOT 2
- Differentiating Error Level Log Output in Terminal and Hook HOT 1
- getting name of the function where a log being called HOT 5
- Use TimestampFunc for sampling HOT 1
- Yu
- level, message are built-in keywords? Field keywords level or message are invalid HOT 1
- Hook after writing
- Support for msgpack encoder
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from zerolog.