commit | 0ab4edafde3eb22e111e75d6aa5e29faa92c30ca | [log] [tgz] |
---|---|---|
author | Serge Bazanski <serge@nexantic.com> | Fri Mar 12 17:43:57 2021 +0100 |
committer | Serge Bazanski <serge@nexantic.com> | Fri Mar 12 17:43:57 2021 +0100 |
tree | 8931f10cd69309ece470c38c3a062ef74f3699a5 | |
parent | 9411f7c2ed0afbbf617075ab37901addc76fadfb [diff] |
m/pkg/logtree: implement klog parsing This adds logtree.KLogParser, a shim which parses klog/glog-formatted lines into logtree leveled logging. This will be used to consume logs from external components (like Kubernetes services) into leveled logging inside logtree. An alternative would be to switch all Kubernetes components to 'structured' (JSON) logging - but that seems to still be experimental, and does not exactly map into something that we can log further. Maybe in the future we can switch over, and also copy these over into our own binary/structured logging. Test Plan: Adds unit tests for parsing, which is the most tricky part. X-Origin-Diff: phab/D715 GitOrigin-RevId: 9994d819f15c9542800d488f57c83ab945a35d34
This is the main repository containing Monogon's public source code, including Metropolis.
We assume a Fedora host system provisioned using rW, and IntelliJ as the IDE.
For better reproducibility, all builds are executed in containers.
Spinning up: scripts/create_container.sh
Spinning down: scripts/destroy_container.sh
Running commands: scripts/run_in_container.sh <...>
Using bazel using a wrapper script: scripts/bin/bazel <...>
(add to your local $PATH for convenience)
This repository is compatible with the IntelliJ Bazel plugin. All commands run inside the container, and necessary paths are mapped into the container.
The following steps are necessary:
Install Google's Bazel plugin in IntelliJ.
Add the absolute path to your ~/.cache/bazel-nxt
folder to your idea64.vmoptions
(Help → Edit Custom VM Options) and restart IntelliJ:
-Dbazel.bep.path=/home/leopold/.cache/bazel-nxt
Set "Bazel Binary Location" in Other Settings → Bazel Settings to the absolute path of scripts/bin/bazel
. This is a wrapper that will execute Bazel inside the container.
Use File → Import Bazel project... to create a new project from .bazelproject
.
After running the first sync, everything should now resolve in the IDE, including generated code.
It's strongly recommend to use our project presets for file watchers and other IDE features. Run this command and re-open the project in order to install them:
bazel run intellij/localconfig $(pwd)
Launch the node:
bazel run //:launch
Run a kubectl command:
bazel run //metropolis/cli/dbg -- kubectl describe