diff options
author | Vito Caputo <vcaputo@pengaru.com> | 2025-01-12 13:23:45 -0800 |
---|---|---|
committer | Vito Caputo <vcaputo@pengaru.com> | 2025-01-12 13:23:45 -0800 |
commit | 3a29d7bc88ab258e1a864f1932ba08380199125c (patch) | |
tree | 29fc70284af353c10b8827ea713a2b6d0ba3d00a /TODO-vmon.txt | |
parent | 8bc0ad2e099b348db6a1e100ea774545d6087c1b (diff) |
This is an early stab at writing down some vmon-specific TODO
items along with some cash bounties for any frends/users
interested in hacking on this stuff for some cash on the side.
I may work on these myself, anyone interested in doing these
things and expecting to get paid _must_ email me first to avoid
racing with me or others working on the same thing. Also I am
fairly opinionated in how these things should be done, so we'll
have to discuss the details or be prepared for disappointment.
Diffstat (limited to 'TODO-vmon.txt')
-rw-r--r-- | TODO-vmon.txt | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/TODO-vmon.txt b/TODO-vmon.txt new file mode 100644 index 0000000..b3fc1bb --- /dev/null +++ b/TODO-vmon.txt @@ -0,0 +1,126 @@ +vmon is being used internally at my $dayjob, as such I can justify paying some +bounties to anyone willing to work on these items for some cash. + +Payment is predicated on successful merging of the work, which means it must +get through review by yours truly. We're not rewriting everything, we're not +changing languages, we're making minimal changes to deliver what's asked. + +Before beginning any work listed here, please email <vcaputo@pengaru.com> to +verify nobody else has started work on the same item, as well as to clarify +what your intentions are and discuss any implementation details. Dollar +amounts listed below are estimates, we will arrive at a firmer number in +email. If you don't communicate with me before working on these things, be +prepared for disappointment. + +There is no commitment being made here to merge anything you deliver, but +should the work get merged, you will be paid. + +-------------------------------------------------------------------------------- + +- vmon needs a generalized mechanism for runtime-defined static rows introduced + into the charts. Stuff like WiFi signal:noise levels, or + hwmon/thermal_zone_device temperature values vs. related throttles to plot + temperature in red with the related throttling action in cyan. + + I'm leaning towards there being a CLI argument for introducing + a static row, with a syntax like: + + --source "TYPE:label" "[TYPE-specific-args...]" + + where the "--source source-args" position in argv influences its relative + order within the chart when appropriate, but --source+TYPE branches into + TYPE-specific cli handling of the rest which may or may not expect more + explicit positional/layout information regarding where to put this source in + the charts. + + Beyond that, what happens in the TYPE-specific-args is entirely polymorphic + in the sense that the TYPE-specific code does whatever's needed there. + + The first source to add should be some generic static single row wiring up + two sampled sources like /sys/ nodes producing a single stringified integer + when each read from. Targeting temperature values... with a float multiplier + to scale what's read into the row's height linearly, like a %age. + + e.g. --source "therm:radio0" "/sys/class/thermal_zone_device10/temp,min,max;/sys/class/cooling_device/throttle,min,max" + + where "therm" maps to a "therm" handler that knows how to parse and apply: + "/sys/class/thermal_zone_device10/temp,min,max;/sys/class/cooling_device/throttle,min,max" + + the "radio0" part after therm: would be what gets drawn over the row as a + label, the "therm" handler just needs to do the sampling and draw the meters + for the row. + + this must be done in a generalized manner where "therm" can be + easily replaced with "bar" for plugging in a new "bar" handler, + as there will be additional static rows to add - like the + aforementioned signal:noise row. + + Proposed bounty upon successful merge upstream: $400 + + +- Processes should have a memory row accompanying the user+sys cpu row. It's + only appropriate per-process, as threads share their process' address space. + + It's unclear to me how to determine the scale to use for the memory rows, if + it should be a %age of the total system physical memory, or something else. + Maybe it would be better as a relative growth/shrinkage plot where the red + indicates %age RSS increased from the bottom up (inverted vs. cpu) and cyan + %age RSS decreased from top down (also inverted vs. cpu) + + If the relative movement approach is used, it'd have to rely on a numberic + overlay to capture the current absolute RSS value. + + This would be desirable to capture in the snowflakes when a process exits, + alongside the cpu utilization graphs. + + A significant part of the work required to add memory rows to just the + processes will likely be breaking the assumption that it's a single row of + pixels per thread and process, uniformly. Instead it'll be double height for + only the processes. + + libvmon doesn't currently collect memory stats, so this will require libvmon + work adding that without introducing a bunch of undue overhead, in addition + to likely invasive changes to charts.c/vcr.c to deal with existing + assumptions surrounding the per-process/per-thread row height being a uniform + thing... since processes would now have another row for memory, while threads + would continue containing only cpu. + + Proposed bounty upon successful merge upstream: $1000 + + +- A CLI flag for turning vmon into a subreaper would be handy. It's fairly + trivial but does mean vmon would have to become more robust in its child + reaping to not accumulate zombies. This is regarding the + PR_SET_CHILD_SUBREAPER prctl... when you run a command under vmon in an + strace-like fashion, being a subreaper would capture orphaned descendents + like daemons so they don't leave vmon's scope upon becoming orphans inherited + by some ancestor subreaper, likely pid1. + + Proposed bounty upon successful merge upstream: $100 + + +- charts.c should do the non-zero level detection in the integer domain, to + ensure no floating point precision/rounding errors can result in 0-height + bars in the graph for non-zero but well below 1 pixel when scaled levels. + + Proposed bounty upon successful merge upstream: $50 + + +- I've noticed that when testing vmon in embedded devices experiencing large + scheduling delays, enough that the Adherence row becomes solid red, vmon + still tends to produce an inconsistent duration in the bar graph. So + there's still some work to be done here in terms of not losing/adding time + in the long run when Adherence consistently slips. + + The cases where I've observed this use 8000 width graphs with 1Hz sample + rates, combined with a heavly loaded system suffering from memory pressure + thrashing and scheduler contention. The snapshots are being saved every 25 + minutes, but the actual time passed in the graph's X axis varies as much as + several minutes. This almost certainly has to do with the Adherence + handling and sample repeating done to fill in the missed samples. It'd be + nice to firm this area up such that the X axis distance traveled accurately + reflects the time passed. It might require maintaining a cumulative + fractional error value across samples to compensate for, since cumulative + error is what's causing this. + + Proposed bounty upon successful merge upstream: $100 |