From e15aa5447150d31e86590da8b2ebd8e62acadcb8 Mon Sep 17 00:00:00 2001
From: Paul Buetow
Date: Sat, 12 Jul 2025 22:46:46 +0300
Subject: Update content for html
---
about/resources.html | 204 ++++----
about/showcase.html | 978 +++++++++++++++++--------------------
about/showcase/debroid/image-1.png | 124 ++---
3 files changed, 611 insertions(+), 695 deletions(-)
(limited to 'about')
diff --git a/about/resources.html b/about/resources.html
index a58ddcef..4999a93b 100644
--- a/about/resources.html
+++ b/about/resources.html
@@ -50,107 +50,107 @@
In random order:
-
Leanring eBPF; Liz Rice; O'Reilly
-
The Go Programming Language; Alan A. A. Donovan; Addison-Wesley Professional
-
Ultimate Go Notebook; Bill Kennedy
-
Clusterbau mit Linux-HA; Michael Schwartzkopff; O'Reilly
-
The Docker Book; James Turnbull; Kindle
-
Systemprogrammierung in Go; Frank Müller; dpunkt
-
Systems Performance Tuning; Gian-Paolo D. Musumeci and others...; O'Reilly
-
Raku Recipes; J.J. Merelo; Apress
-
Tmux 2: Productive Mouse-free Development; Brain P. Hogan; The Pragmatic Programmers
Modern Perl; Chromatic ; Onyx Neon Press
-
Think Raku (aka Think Perl 6); Laurent Rosenfeld, Allen B. Downey; O'Reilly
-
Amazon Web Services in Action; Michael Wittig and Andreas Wittig; Manning Publications
-
Site Reliability Engineering; How Google runs production systems; O'Reilly
-
DNS and BIND; Cricket Liu; O'Reilly
-
Funktionale Programmierung; Peter Pepper; Springer
+
Go Brain Teasers - Exercise Your Mind; Miki Tebeka; The Pragmatic Programmers
+
Object-Oriented Programming with ANSI-C; Axel-Tobias Schreiner
Effective awk programming; Arnold Robbins; O'Reilly
-
Higher Order Perl; Mark Dominus; Morgan Kaufmann
+
97 things every SRE should know; Emil Stolarsky, Jaime Woo; O'Reilly
+
DNS and BIND; Cricket Liu; O'Reilly
Programming Perl aka "The Camel Book"; Tom Christiansen, brian d foy, Larry Wall & Jon Orwant; O'Reilly
-
Hands-on Infrastructure Monitoring with Prometheus; Joel Bastos, Pedro Araujo; Packt
-
Polished Ruby Programming; Jeremy Evans; Packt Publishing
-
100 Go Mistakes and How to Avoid Them; Teiva Harsanyi; Manning Publications
-
Object-Oriented Programming with ANSI-C; Axel-Tobias Schreiner
+
21st Century C: C Tips from the New School; Ben Klemens; O'Reilly
+
Data Science at the Command Line; Jeroen Janssens; O'Reilly
+
Concurrency in Go; Katherine Cox-Buday; O'Reilly
+
Perl New Features; Joshua McAdams, brian d foy; Perl School
+
The KCNA (Kubernetes and Cloud Native Associate) Book; Nigel Poulton
Programming Ruby 3.3 (5th Edition); Noel Rappin, with Dave Thomas; The Pragmatic Bookshelf
-
Effective Java; Joshua Bloch; Addison-Wesley Professional
-
Java ist auch eine Insel; Christian Ullenboom;
-
Terraform Cookbook; Mikael Krief; Packt Publishing
-
C++ Programming Language; Bjarne Stroustrup;
-
97 things every SRE should know; Emil Stolarsky, Jaime Woo; O'Reilly
DevOps And Site Reliability Engineering Handbook; Stephen Fleming; Audible
+
Pro Puppet; James Turnbull, Jeffrey McCune; Apress
Raku Fundamentals; Moritz Lenz; Apress
-
Concurrency in Go; Katherine Cox-Buday; O'Reilly
-
Perl New Features; Joshua McAdams, brian d foy; Perl School
+
Ultimate Go Notebook; Bill Kennedy
+
Hands-on Infrastructure Monitoring with Prometheus; Joel Bastos, Pedro Araujo; Packt
+
Leanring eBPF; Liz Rice; O'Reilly
+
Higher Order Perl; Mark Dominus; Morgan Kaufmann
+
Systems Performance Tuning; Gian-Paolo D. Musumeci and others...; O'Reilly
+
Polished Ruby Programming; Jeremy Evans; Packt Publishing
+
Learn You a Haskell for Great Good!; Miran Lipovaca; No Starch Press
+
Systemprogrammierung in Go; Frank Müller; dpunkt
+
The DevOps Handbook; Gene Kim, Jez Humble, Patrick Debois, John Willis; Audible
+
The Docker Book; James Turnbull; Kindle
The Kubernetes Book; Nigel Poulton; Unabridged Audiobook
-
Data Science at the Command Line; Jeroen Janssens; O'Reilly
+
The Pragmatic Programmer; David Thomas; Addison-Wesley
+
Funktionale Programmierung; Peter Pepper; Springer
Kubernetes Cookbook; Sameer Naik, Sébastien Goasguen, Jonathan Michaux; O'Reilly
-
21st Century C: C Tips from the New School; Ben Klemens; O'Reilly
+
Clusterbau mit Linux-HA; Michael Schwartzkopff; O'Reilly
+
Terraform Cookbook; Mikael Krief; Packt Publishing
+
Site Reliability Engineering; How Google runs production systems; O'Reilly
+
C++ Programming Language; Bjarne Stroustrup;
+
The Practise of System and Network Administration; Thomas A. Limoncelli, Christina J. Hogan, Strata R. Chalup; Addison-Wesley Professional Pro Git; Scott Chacon, Ben Straub; Apress
+
100 Go Mistakes and How to Avoid Them; Teiva Harsanyi; Manning Publications
+
Think Raku (aka Think Perl 6); Laurent Rosenfeld, Allen B. Downey; O'Reilly
+
Raku Recipes; J.J. Merelo; Apress
Learn You Some Erlang for Great Good; Fred Herbert; No Starch Press
-
Pro Puppet; James Turnbull, Jeffrey McCune; Apress
-
Learn You a Haskell for Great Good!; Miran Lipovaca; No Starch Press
-
Go Brain Teasers - Exercise Your Mind; Miki Tebeka; The Pragmatic Programmers
Distributed Systems: Principles and Paradigms; Andrew S. Tanenbaum; Pearson
+
Effective Java; Joshua Bloch; Addison-Wesley Professional
+
Java ist auch eine Insel; Christian Ullenboom;
+
Tmux 2: Productive Mouse-free Development; Brain P. Hogan; The Pragmatic Programmers
Developing Games in Java; David Brackeen and others...; New Riders
-
The Practise of System and Network Administration; Thomas A. Limoncelli, Christina J. Hogan, Strata R. Chalup; Addison-Wesley Professional Pro Git; Scott Chacon, Ben Straub; Apress
-
The Pragmatic Programmer; David Thomas; Addison-Wesley
-
The KCNA (Kubernetes and Cloud Native Associate) Book; Nigel Poulton
-
The DevOps Handbook; Gene Kim, Jez Humble, Patrick Debois, John Willis; Audible
+
The Go Programming Language; Alan A. A. Donovan; Addison-Wesley Professional
+
Amazon Web Services in Action; Michael Wittig and Andreas Wittig; Manning Publications
Technical references
I didn't read them from the beginning to the end, but I am using them to look up things. The books are in random order:
-
Groovy Kurz & Gut; Joerg Staudemeier; O'Reilly
+
BPF Performance Tools - Linux System and Application Observability, Brendan Gregg; Addison Wesley
+
Implementing Service Level Objectives; Alex Hidalgo; O'Reilly
The Linux Programming Interface; Michael Kerrisk; No Starch Press
-
Algorithms; Robert Sedgewick, Kevin Wayne; Addison Wesley
-
Relayd and Httpd Mastery; Michael W Lucas
Go: Design Patterns for Real-World Projects; Mat Ryer; Packt
+
Groovy Kurz & Gut; Joerg Staudemeier; O'Reilly
+
Relayd and Httpd Mastery; Michael W Lucas
+
Algorithms; Robert Sedgewick, Kevin Wayne; Addison Wesley
Understanding the Linux Kernel; Daniel P. Bovet, Marco Cesati; O'Reilly
-
Implementing Service Level Objectives; Alex Hidalgo; O'Reilly
-
BPF Performance Tools - Linux System and Application Observability, Brendan Gregg; Addison Wesley
Self-development and soft-skills books
In random order:
-
The Good Enough Job; Simone Stolzoff; Ebury Edge
-
The Phoenix Project - A Novel About IT, DevOps, and Helping your Business Win; Gene Kim and Kevin Behr; Trade Select
-
101 Essays that change the way you think; Brianna Wiest; Audiobook
-
Consciousness: A Very Short Introduction; Susan Blackmore; Oxford Uiversity Press
-
Staff Engineer: Leadership beyond the management track; Will Larson; Audiobook
-
The Power of Now; Eckhard Tolle; Yellow Kite
-
Never Split the Difference; Chris Voss, Tahl Raz; Random House Business
-
Stop starting, start finishing; Arne Roock; Lean-Kanban University
-
Getting Things Done; David Allen
-
The Bullet Journal Method; Ryder Carroll; Fourth Estate
-
Slow Productivity; Cal Newport; Penguin Random House
-
The Daily Stoic; Ryan Holiday, Stephen Hanselman; Profile Books
-
Search Inside Yourself - The Unexpected path to Achieving Success, Happiness (and World Peace); Chade-Meng Tan, Daniel Goleman, Jon Kabat-Zinn; HarperOne
So Good They Can't Ignore You; Cal Newport; Business Plus
-
Deep Work; Cal Newport; Piatkus
-
Ultralearning; Anna Laurent; Self-published via Amazon
-
Ultralearning; Scott Young; Thorsons
-
Soft Skills; John Sommez; Manning Publications
+
Stop starting, start finishing; Arne Roock; Lean-Kanban University
+
Psycho-Cybernetics; Maxwell Maltz; Perigee Books
+
Influence without Authority; A. Cohen, D. Bradford; Wiley
The Complete Software Developer's Career Guide; John Sonmez; Unabridged Audiobook
-
The Obstacle Is The Way; Ryan Holiday; Profile Books Ltd
-
Buddah and Einstein walk into a Bar; Guy Joseph Ale, Claire Bloom; Blackstone Publishing
-
Time Management for System Administrators; Thomas A. Limoncelli; O'Reilly
-
Solve for Happy; Mo Gawdat (RE-READ 1ST TIME)
Who Moved My Cheese?; Dr. Spencer Johnson; Vermilion
-
Eat That Frog!; Brian Tracy; Hodder Paperbacks
-
The Off Switch; Mark Cropley; Virgin Books (RE-READ 1ST TIME)
-
The 7 Habits Of Highly Effective People; Stephen R. Covey; Simon & Schuster UK
-
Influence without Authority; A. Cohen, D. Bradford; Wiley
-
The Joy of Missing Out; Christina Crook; New Society Publishers
-
Eat That Frog; Brian Tracy
+
Ultralearning; Anna Laurent; Self-published via Amazon
+
Staff Engineer: Leadership beyond the management track; Will Larson; Audiobook
+
Deep Work; Cal Newport; Piatkus
+
Meditation for Mortals, Oliver Burkeman, Audiobook
+
The Bullet Journal Method; Ryder Carroll; Fourth Estate
Coders at Work - Reflections on the craft of programming, Peter Seibel and Mitchell Dorian et al., Audiobook
Atomic Habits; James Clear; Random House Business
-
Meditation for Mortals, Oliver Burkeman, Audiobook
+
The Obstacle Is The Way; Ryan Holiday; Profile Books Ltd
+
Time Management for System Administrators; Thomas A. Limoncelli; O'Reilly
+
Soft Skills; John Sommez; Manning Publications
+
Consciousness: A Very Short Introduction; Susan Blackmore; Oxford Uiversity Press
+
Getting Things Done; David Allen
+
Buddah and Einstein walk into a Bar; Guy Joseph Ale, Claire Bloom; Blackstone Publishing
+
Eat That Frog; Brian Tracy
+
The 7 Habits Of Highly Effective People; Stephen R. Covey; Simon & Schuster UK
+
The Good Enough Job; Simone Stolzoff; Ebury Edge
Digital Minimalism; Cal Newport; Portofolio Penguin
-
Psycho-Cybernetics; Maxwell Maltz; Perigee Books
+
Eat That Frog!; Brian Tracy; Hodder Paperbacks
+
The Daily Stoic; Ryan Holiday, Stephen Hanselman; Profile Books
+
The Joy of Missing Out; Christina Crook; New Society Publishers
+
The Power of Now; Eckhard Tolle; Yellow Kite
+
The Off Switch; Mark Cropley; Virgin Books (RE-READ 1ST TIME)
+
Slow Productivity; Cal Newport; Penguin Random House
+
The Phoenix Project - A Novel About IT, DevOps, and Helping your Business Win; Gene Kim and Kevin Behr; Trade Select
+
Solve for Happy; Mo Gawdat (RE-READ 1ST TIME)
+
Search Inside Yourself - The Unexpected path to Achieving Success, Happiness (and World Peace); Chade-Meng Tan, Daniel Goleman, Jon Kabat-Zinn; HarperOne
+
Ultralearning; Scott Young; Thorsons
+
Never Split the Difference; Chris Voss, Tahl Raz; Random House Business
+
101 Essays that change the way you think; Brianna Wiest; Audiobook
@@ -159,30 +159,30 @@
Some of these were in-person with exams; others were online learning lectures only. In random order:
-
Structure and Interpretation of Computer Programs; Harold Abelson and more...;
-
Cloud Operations on AWS - Learn how to configure, deploy, maintain, and troubleshoot your AWS environments; 3-day online live training with labs; Amazon
-
Functional programming lecture; Remote University of Hagen
-
AWS Immersion Day; Amazon; 1-day interactive online training
-
F5 Loadbalancers Training; 2-day on-site training; F5, Inc.
Apache Tomcat Best Practises; 3-day on-site training
+
Linux Security and Isolation APIs Training; Michael Kerrisk; 3-day on-site training
Ultimate Go Programming; Bill Kennedy; O'Reilly Online
-
MySQL Deep Dive Workshop; 2-day on-site training
-
Algorithms Video Lectures; Robert Sedgewick; O'Reilly Online
-
The Well-Grounded Rubyist Video Edition; David. A. Black; O'Reilly Online
Red Hat Certified System Administrator; Course + certification (Although I had the option, I decided not to take the next course as it is more effective to self learn what I need)
-
Linux Security and Isolation APIs Training; Michael Kerrisk; 3-day on-site training
-
Scripting Vim; Damian Conway; O'Reilly Online
+
AWS Immersion Day; Amazon; 1-day interactive online training
+
F5 Loadbalancers Training; 2-day on-site training; F5, Inc.
Protocol buffers; O'Reilly Online
-
The Ultimate Kubernetes Bootcamp; School of Devops; O'Reilly Online
+
Functional programming lecture; Remote University of Hagen
+
Structure and Interpretation of Computer Programs; Harold Abelson and more...;
Developing IaC with Terraform (with Live Lessons); O'Reilly Online
+
The Ultimate Kubernetes Bootcamp; School of Devops; O'Reilly Online
+
Cloud Operations on AWS - Learn how to configure, deploy, maintain, and troubleshoot your AWS environments; 3-day online live training with labs; Amazon
+
Scripting Vim; Damian Conway; O'Reilly Online
+
Algorithms Video Lectures; Robert Sedgewick; O'Reilly Online
+
The Well-Grounded Rubyist Video Edition; David. A. Black; O'Reilly Online
+
MySQL Deep Dive Workshop; 2-day on-site training
Technical guides
These are not whole books, but guides (smaller or larger) which I found very useful. in random order:
-
Advanced Bash-Scripting Guide
Raku Guide at https://raku.guide
+
Advanced Bash-Scripting Guide
How CPUs work at https://cpu.land
Podcasts
@@ -192,60 +192,60 @@
In random order:
-
Pratical AI
+
BSD Now [BSD]
+
Modern Mentor
+
Hidden Brain
+
Backend Banter
The Pragmatic Engineer Podcast
-
The Changelog Podcast(s)
-
Fallthrough [Golang]
Fork Around And Find Out
-
Dev Interrupted
-
Hidden Brain
-
The ProdCast (Google SRE Podcast)
+
Fallthrough [Golang]
+
The Changelog Podcast(s)
Cup o' Go [Golang]
-
Deep Questions with Cal Newport
-
Modern Mentor
-
BSD Now [BSD]
+
The ProdCast (Google SRE Podcast)
Maintainable
-
Backend Banter
+
Deep Questions with Cal Newport
+
Pratical AI
+
Dev Interrupted
Podcasts I liked
I liked them but am not listening to them anymore. The podcasts have either "finished" (no more episodes) or I stopped listening to them due to time constraints or a shift in my interests.
-
FLOSS weekly
Java Pub House
-
CRE: Chaosradio Express [german]
Ship It (predecessor of Fork Around And Find Out)
-
Modern Mentor
Go Time (predecessor of fallthrough)
+
FLOSS weekly
+
CRE: Chaosradio Express [german]
+
Modern Mentor
Newsletters I like
This is a mix of tech and non-tech newsletters I am subscribed to. In random order:
-
Golang Weekly
-
Register Spill
The Pragmatic Engineer
-
Changelog News
+
Register Spill
Andreas Brandhorst Newsletter (Sci-Fi author)
The Imperfectionist
-
Applied Go Weekly Newsletter
The Valuable Dev
Monospace Mentor
-
byteSizeGo
-
Ruby Weekly
VK Newsletter
+
Changelog News
+
Golang Weekly
+
Ruby Weekly
+
byteSizeGo
+
Applied Go Weekly Newsletter
Magazines I like(d)
This is a mix of tech I like(d). I may not be a current subscriber, but now and then, I buy an issue. In random order:
-Generated on: 2025-07-09
+Generated on: 2025-07-12
This page showcases my side projects, providing an overview of what each project does, its technical implementation, and key metrics. Each project summary includes information about the programming languages used, development activity, and licensing. The projects are ordered by recent activity, with the most actively maintained projects listed first.
💻 Languages: Go (86.7%), Shell (11.4%), YAML (1.4%), JSON (0.5%)
+
💻 Languages: Go (89.5%), Shell (8.9%), YAML (1.1%), JSON (0.4%)
📚 Documentation: Markdown (100.0%)
-
📊 Commits: 60
-
📈 Lines of Code: 6548
-
📄 Lines of Documentation: 2338
-
📅 Development Period: 2025-06-23 to 2025-07-09
-
🔥 Recent Activity: 3.4 days (avg. age of last 42 commits)
+
📊 Commits: 76
+
📈 Lines of Code: 8340
+
📄 Lines of Documentation: 2363
+
📅 Development Period: 2025-06-23 to 2025-07-12
+
🔥 Recent Activity: 2.5 days (avg. age of last 42 commits)
⚖️ License: BSD-2-Clause
🏷️ Latest Release: v0.5.0 (2025-07-09)
-
🤖 AI-Assisted: This project was partially created with the help of generative AI
+
🎵 Vibe-Coded: This project has been vibe coded
GitSyncer is a cross-platform repository synchronization tool that automatically keeps Git repositories in sync across multiple hosting platforms like GitHub, Codeberg, and private SSH servers. It solves the common problem of maintaining consistent code across different Git hosting services by cloning repositories, adding all configured platforms as remotes, and continuously merging and pushing changes bidirectionally while handling branch creation and conflict detection.
@@ -115,19 +116,14 @@
View on Codeberg View on GitHub
-Go from internal/cli/handlers.go:
+Go from internal/showcase/images.go:
-Shell from frontends/scripts/sitestats.sh:
+Perl from frontends/scripts/foostats.pl:
-STATSFILE=/tmp/sitestats.csv
-BOTSFILE=/tmp/sitebots.txt
-TOP=20
+sub write ( $path, $content ) {
+ open my $fh, '>', "$path.tmp"
+ or die "\nCannot open file: $!";
+ print $fh $content;
+ close $fh;
+
+ rename
+ "$path.tmp",
+ $path;
+}
---
-
dtail
+
ior
-
💻 Languages: Go (93.9%), JSON (2.8%), C (2.0%), Make (0.5%), C/C++ (0.3%), Config (0.2%), Shell (0.2%), Docker (0.1%)
-
📚 Documentation: Text (79.4%), Markdown (20.6%)
-
📊 Commits: 1049
-
📈 Lines of Code: 20091
-
📄 Lines of Documentation: 5674
-
📅 Development Period: 2020-01-09 to 2025-06-20
-
🔥 Recent Activity: 52.4 days (avg. age of last 42 commits)
-
⚖️ License: Apache-2.0
-
🏷️ Latest Release: v4.2.0 (2023-06-21)
+
💻 Languages: Go (81.0%), Raku (11.5%), C (4.4%), Make (1.7%), C/C++ (1.5%)
+
📚 Documentation: Text (63.6%), Markdown (36.4%)
+
📊 Commits: 330
+
📈 Lines of Code: 7911
+
📄 Lines of Documentation: 742
+
📅 Development Period: 2024-01-18 to 2025-07-12
+
🔥 Recent Activity: 56.3 days (avg. age of last 42 commits)
+
⚖️ License: No license found
+
🧪 Status: Experimental (no releases yet)
🤖 AI-Assisted: This project was partially created with the help of generative AI
-
+
-DTail is a distributed log processing system written in Go that allows DevOps engineers to tail, cat, and grep log files across thousands of servers concurrently. It provides secure access through SSH authentication and respects UNIX file system permissions, making it ideal for enterprise environments where log analysis needs to scale horizontally across large server fleets. The tool supports advanced features like compressed file handling (gzip/zstd) and distributed MapReduce aggregations for complex log analytics.
+Based on my analysis of the codebase, here's a comprehensive summary of the I/O Riot NG (ior) project:
-
+
-The system uses a client-server architecture where dtail servers run on target machines (listening on port 2222) and clients connect to multiple servers simultaneously. It can also operate in serverless mode for local operations. The implementation leverages SSH for secure communication, includes sophisticated connection throttling and resource management, and provides specialized tools (dcat, dgrep, dmap) for different log processing tasks. The MapReduce functionality supports SQL-like queries with server-side local aggregation and client-side final aggregation, enabling powerful distributed analytics across log data.
+**I/O Riot NG** is a Linux-based performance monitoring tool that uses eBPF (extended Berkeley Packet Filter) to trace synchronous I/O system calls and analyze their execution times. This tool is particularly valuable for system performance analysis, allowing developers and system administrators to visualize I/O bottlenecks through detailed flamegraphs. It serves as a modern successor to the original I/O Riot project, migrating from SystemTap/C to a Go/C/BPF implementation for better performance and maintainability.
-View on Codeberg
-View on GitHub
+The architecture combines kernel-level tracing with user-space analysis: eBPF programs (internal/c/ior.bpf.c) attach to kernel tracepoints to capture syscall entry/exit events, which are then processed by a Go-based event loop (internal/eventloop.go) that correlates enter/exit pairs, tracks file descriptors, and measures timing. The tool can operate in real-time mode for live monitoring or post-processing mode to generate flamegraphs from previously collected data using the Inferno flamegraph library. Key features include filtering capabilities for specific processes or file patterns, comprehensive statistics collection, and support for various I/O syscalls like open, read, write, close, and dup operations.
+
+View on Codeberg
+View on GitHub
-Go from internal/io/signal/signal.go:
+Go from internal/file/file.go:
-func InterruptCh(ctx context.Context) <-chan string {
- sigIntCh := make(chan os.Signal, 10)
- gosignal.Notify(sigIntCh, os.Interrupt)
- sigOtherCh := make(chan os.Signal, 10)
- gosignal.Notify(sigOtherCh, syscall.SIGHUP, syscall.SIGTERM, syscall.SIGQUIT)
- statsCh := make(chan string)
-
- go func() {
- for {
- select {
- case <-sigIntCh:
- select {
- case statsCh <- "Hint: Hit Ctrl+C again to exit":
- select {
- case <-sigIntCh:
- os.Exit(0)
- case <-time.After(time.Second * time.Duration(config.InterruptTimeoutS)):
- }
- default:
- }
- case <-sigOtherCh:
- os.Exit(0)
- case <-ctx.Done():
- return
- }
- }
- }()
- return statsCh
+func NewFd(fd int32, name []byte, flags int32) FdFile {
+ f := FdFile{
+ fd: fd,
+ name: types.StringValue(name),
+ flags: Flags(flags),
+ }
+ if f.flags == -1 {
+ panic(fmt.Sprintf("DEBUG with -1 flags: %v", f))
+ }
+ return f
}
🔥 Recent Activity: 71.7 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 74.9 days (avg. age of last 42 commits)
⚖️ License: Custom License
🏷️ Latest Release: v1.0.0 (2025-05-11)
@@ -353,51 +315,6 @@ def initialize(myself)
---
-
ior
-
-
-
💻 Languages: C (54.7%), Go (37.4%), Raku (5.4%), Make (1.4%), C/C++ (1.1%)
-
📚 Documentation: Text (84.1%), Markdown (15.9%)
-
📊 Commits: 316
-
📈 Lines of Code: 9835
-
📄 Lines of Documentation: 559
-
📅 Development Period: 2024-01-18 to 2025-06-14
-
🔥 Recent Activity: 83.7 days (avg. age of last 42 commits)
-
⚖️ License: No license found
-
🧪 Status: Experimental (no releases yet)
-
-
-
-
-Based on my analysis of the codebase, here's a comprehensive summary of the I/O Riot NG (ior) project:
-
-
-
-**I/O Riot NG** is a Linux-based performance monitoring tool that uses eBPF (extended Berkeley Packet Filter) to trace synchronous I/O system calls and analyze their execution times. This tool is particularly valuable for system performance analysis, allowing developers and system administrators to visualize I/O bottlenecks through detailed flamegraphs. It serves as a modern successor to the original I/O Riot project, migrating from SystemTap/C to a Go/C/BPF implementation for better performance and maintainability.
-
-The architecture combines kernel-level tracing with user-space analysis: eBPF programs (internal/c/ior.bpf.c) attach to kernel tracepoints to capture syscall entry/exit events, which are then processed by a Go-based event loop (internal/eventloop.go) that correlates enter/exit pairs, tracks file descriptors, and measures timing. The tool can operate in real-time mode for live monitoring or post-processing mode to generate flamegraphs from previously collected data using the Inferno flamegraph library. Key features include filtering capabilities for specific processes or file patterns, comprehensive statistics collection, and support for various I/O syscalls like open, read, write, close, and dup operations.
-
-View on Codeberg
-View on GitHub
-
-C from tools/forktest.c:
-
-
🔥 Recent Activity: 128.9 days (avg. age of last 42 commits)
+
📅 Development Period: 2023-01-02 to 2025-07-12
+
🔥 Recent Activity: 121.8 days (avg. age of last 42 commits)
⚖️ License: Custom License
-
🧪 Status: Experimental (no releases yet)
+
🏷️ Latest Release: v0.1.0 (2025-07-12)
Based on the README and project structure, **foostats** is a privacy-respecting web analytics tool written in Perl specifically designed for OpenBSD systems. It processes both traditional HTTP/HTTPS logs and Gemini protocol logs to generate comprehensive traffic statistics while maintaining visitor privacy through SHA3-512 IP hashing. The tool is built for the foo.zone ecosystem and similar sites that need analytics without compromising user privacy.
@@ -568,7 +486,7 @@ sub write ( $path, $content ) {
📈 Lines of Code: 1373
📄 Lines of Documentation: 48
📅 Development Period: 2024-12-05 to 2025-02-28
-
🔥 Recent Activity: 138.3 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 141.6 days (avg. age of last 42 commits)
🔥 Recent Activity: 518.3 days (avg. age of last 42 commits)
+
⚖️ License: Custom License
+
🏷️ Latest Release: v1.1.0 (2024-05-03)
+
🤖 AI-Assisted: This project was partially created with the help of generative AI
+
+
+
+
+Gogios is a lightweight, minimalistic monitoring tool written in Go designed for small-scale server monitoring. It executes standard Nagios-compatible check plugins and sends email notifications only when service states change, making it ideal for personal infrastructure or small environments with limited resources. The tool emphasizes simplicity over complexity, avoiding the bloat of enterprise monitoring solutions like Nagios, Icinga, or Prometheus by eliminating features like web UIs, databases, contact groups, and clustering.
+
+The implementation follows a clean architecture with concurrent check execution, dependency management, and persistent state tracking. Key features include state-based notifications (only alerts on status changes), configurable retry logic, federation support for distributed monitoring, and stale detection for checks that haven't run recently. The tool is configured via JSON and requires only a local mail transfer agent for notifications. It's designed to run via cron jobs and supports high-availability setups through simple dual-server configurations, making it perfect for users who want effective monitoring without operational overhead.
+
+View on Codeberg
+View on GitHub
+
+Go from internal/check.go:
+
+
🔥 Recent Activity: 762.0 days (avg. age of last 42 commits)
-
⚖️ License: Custom License
-
🏷️ Latest Release: v1.1.0 (2024-05-03)
-
-⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
-
-
-
-Gogios is a lightweight, minimalistic monitoring tool written in Go designed for small-scale server monitoring. It executes standard Nagios-compatible check plugins and sends email notifications only when service states change, making it ideal for personal infrastructure or small environments with limited resources. The tool emphasizes simplicity over complexity, avoiding the bloat of enterprise monitoring solutions like Nagios, Icinga, or Prometheus by eliminating features like web UIs, databases, contact groups, and clustering.
-
-The implementation follows a clean architecture with concurrent check execution, dependency management, and persistent state tracking. Key features include state-based notifications (only alerts on status changes), configurable retry logic, federation support for distributed monitoring, and stale detection for checks that haven't run recently. The tool is configured via JSON and requires only a local mail transfer agent for notifications. It's designed to run via cron jobs and supports high-availability setups through simple dual-server configurations, making it perfect for users who want effective monitoring without operational overhead.
-
-View on Codeberg
-View on GitHub
-
-Go from internal/state.go:
-
-
-func readState(conf config) (state, error) {
- s := state{
- stateFile: fmt.Sprintf("%s/state.json", conf.StateDir),
- checks: make(map[string]checkState),
- }
-
- if _, err := os.Stat(s.stateFile); err != nil {
- return s, nil
- }
-
- file, err := os.Open(s.stateFile)
- if err != nil {
- return s, err
- }
- defer file.Close()
-
- bytes, err := io.ReadAll(file)
- if err != nil {
- return s, err
- }
-
- if err := json.Unmarshal(bytes, &s.checks); err != nil {
- return s, err
- }
-
- var obsolete []string
- for name := range s.checks {
- if _, ok := conf.Checks[name]; !ok {
- obsolete = append(obsolete, name)
- }
- }
-
- for _, name := range obsolete {
- delete(s.checks, name)
- log.Printf("State of %s is obsolete (removed)", name)
- }
-
- return s, nil
-}
-
🔥 Recent Activity: 765.8 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 769.1 days (avg. age of last 42 commits)
⚖️ License: No license found
🧪 Status: Experimental (no releases yet)
@@ -1037,6 +943,63 @@ declare -i NUM_PAGES_TO_EXTRACT=42 # This is the answear!
---
+
dtail
+
+
+
💻 Languages: Go (91.1%), JSON (4.1%), C (2.9%), Make (0.6%), C/C++ (0.5%), Config (0.3%), Shell (0.2%), Docker (0.2%)
+
📚 Documentation: Text (80.4%), Markdown (19.6%)
+
📊 Commits: 1049
+
📈 Lines of Code: 13525
+
📄 Lines of Documentation: 5375
+
📅 Development Period: 2020-01-09 to 2023-10-05
+
🔥 Recent Activity: 781.8 days (avg. age of last 42 commits)
+
⚖️ License: Apache-2.0
+
🏷️ Latest Release: v4.2.0 (2023-06-21)
+
+⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
+
+
+
+DTail is a distributed log processing system written in Go that allows DevOps engineers to tail, cat, and grep log files across thousands of servers concurrently. It provides secure access through SSH authentication and respects UNIX file system permissions, making it ideal for enterprise environments where log analysis needs to scale horizontally across large server fleets. The tool supports advanced features like compressed file handling (gzip/zstd) and distributed MapReduce aggregations for complex log analytics.
+
+
+
+The system uses a client-server architecture where dtail servers run on target machines (listening on port 2222) and clients connect to multiple servers simultaneously. It can also operate in serverless mode for local operations. The implementation leverages SSH for secure communication, includes sophisticated connection throttling and resource management, and provides specialized tools (dcat, dgrep, dmap) for different log processing tasks. The MapReduce functionality supports SQL-like queries with server-side local aggregation and client-side final aggregation, enabling powerful distributed analytics across log data.
+
+View on Codeberg
+View on GitHub
+
+Go from internal/io/fs/readfilelcontext.go:
+
+
-do { int'egrate'; sub trade; };
-do { exp'onentize' and abs'olutize' };
-study and study and study and study;
-
-foreach $topic ({of, math}) {
-you, m/ay /go, to, limits }
-
-do { not qw/erk / unless $success
-and m/ove /o;$n and study };
+no strict;
+no warnings;
+we: do { print 'love'
+or warn and die 'slow'
+unless not defined true #respect
+} for reverse'd', qw/mind of you/
+and map { 'me' } 'into', undef $mourning;
+__END__
+v2 Copyright (2005, 2006) by Paul C. Buetow, http://paul.buetow.org
---
@@ -1885,7 +1836,7 @@ and m/ove /o;$n and study };
📊 Commits: 7
📈 Lines of Code: 80
📅 Development Period: 2011-07-09 to 2015-01-13
-
🔥 Recent Activity: 4204.6 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 4207.9 days (avg. age of last 42 commits)
⚖️ License: Custom License
🧪 Status: Experimental (no releases yet)
@@ -1930,40 +1881,16 @@ if ($ENV{SERVER_NAME} eq 'ipv6.buetow.org') {
---
-
cpuinfo
-
-
-
💻 Languages: Shell (53.2%), Make (46.8%)
-
📚 Documentation: Text (100.0%)
-
📊 Commits: 28
-
📈 Lines of Code: 124
-
📄 Lines of Documentation: 75
-
📅 Development Period: 2010-11-05 to 2021-11-05
-
🔥 Recent Activity: 4245.3 days (avg. age of last 42 commits)
-
⚖️ License: No license found
-
🏷️ Latest Release: 1.0.2 (2014-06-22)
-
-⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
-
-**cpuinfo** is a small command-line utility that provides a human-readable summary of CPU information on Linux systems. It parses /proc/cpuinfo using AWK to extract and display key processor details including the CPU model, cache size, number of physical processors, cores, and whether hyper-threading is enabled. The tool calculates total CPU frequency and bogomips across all cores, making it easier to understand complex multi-core and multi-processor configurations at a glance.
-
-The implementation is remarkably simple - a single shell script that uses GNU AWK to parse the kernel's CPU information and format it into a clear, structured output. It's particularly useful for system administrators and developers who need to quickly understand CPU topology, especially on servers with multiple processors or complex threading configurations where the raw /proc/cpuinfo output can be overwhelming.
-
-View on Codeberg
-View on GitHub
-
----
-
loadbars
💻 Languages: Perl (97.4%), Make (2.6%)
-
📚 Documentation: Text (100.0%)
+
📚 Documentation: Text (93.5%), Markdown (6.5%)
📊 Commits: 527
📈 Lines of Code: 1828
-
📄 Lines of Documentation: 100
+
📄 Lines of Documentation: 107
📅 Development Period: 2010-11-05 to 2015-05-23
-
🔥 Recent Activity: 4275.4 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 4215.4 days (avg. age of last 42 commits)
-Perl from lib/Loadbars/HelpDispatch.pm:
+Perl from lib/Loadbars/Utils.pm:
-sub create () {
- my $hosts = '';
-
- my $textdesc = <<END;
-For more help please consult the manual page or press the 'h' hotkey during
- program execution and watch this terminal window.
-END
+sub trim (\$) {
+ my $str = shift;
+ $$str =~ s/^[\s\t]+//;
+ $$str =~ s/[\s\t]+$//;
+ return undef;
+}
---
+
cpuinfo
+
+
+
💻 Languages: Shell (53.2%), Make (46.8%)
+
📚 Documentation: Text (100.0%)
+
📊 Commits: 28
+
📈 Lines of Code: 124
+
📄 Lines of Documentation: 75
+
📅 Development Period: 2010-11-05 to 2021-11-05
+
🔥 Recent Activity: 4248.5 days (avg. age of last 42 commits)
+
⚖️ License: No license found
+
🏷️ Latest Release: 1.0.2 (2014-06-22)
+
+⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
+
+**cpuinfo** is a small command-line utility that provides a human-readable summary of CPU information on Linux systems. It parses /proc/cpuinfo using AWK to extract and display key processor details including the CPU model, cache size, number of physical processors, cores, and whether hyper-threading is enabled. The tool calculates total CPU frequency and bogomips across all cores, making it easier to understand complex multi-core and multi-processor configurations at a glance.
+
+The implementation is remarkably simple - a single shell script that uses GNU AWK to parse the kernel's CPU information and format it into a clear, structured output. It's particularly useful for system administrators and developers who need to quickly understand CPU topology, especially on servers with multiple processors or complex threading configurations where the raw /proc/cpuinfo output can be overwhelming.
+
+View on Codeberg
+View on GitHub
+
+---
+
perldaemon
@@ -1997,7 +1947,7 @@ END
📊 Commits: 110
📈 Lines of Code: 614
📅 Development Period: 2011-02-05 to 2022-04-21
-
🔥 Recent Activity: 4324.8 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 4328.1 days (avg. age of last 42 commits)
💻 Languages: Java (98.6%), Shell (0.8%), XML (0.4%)
-
📚 Documentation: LaTeX (98.4%), Text (1.4%), Markdown (0.2%)
-
📊 Commits: 411
-
📈 Lines of Code: 14582
-
📄 Lines of Documentation: 2903
-
📅 Development Period: 2008-05-15 to 2022-04-03
-
🔥 Recent Activity: 5385.5 days (avg. age of last 42 commits)
-
⚖️ License: Custom License
-
🏷️ Latest Release: v1.0 (2008-08-24)
-
-⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
-
-
-
-VS-Sim is an open-source distributed systems simulator written in Java, developed as a diploma thesis at Aachen University of Applied Sciences. It provides a visual environment for simulating and understanding distributed system algorithms including consensus protocols (one-phase/two-phase commit), time synchronization (Berkeley, Lamport, vector clocks), and communication patterns (multicast, broadcast, reliable messaging). The simulator is useful for educational purposes, allowing students and researchers to visualize complex distributed system concepts through interactive simulations.
-
-The implementation features a modular architecture with separate packages for core processes, events, protocols, and visualization. It includes pre-built protocol implementations, a GUI-based simulator with start/pause/reset controls, serialization support for saving simulations, and comprehensive time modeling systems. The codebase demonstrates clean separation of concerns with abstract base classes for extensibility and a plugin-like protocol system for easy addition of new distributed algorithms.
-
-View on Codeberg
-View on GitHub
-
-Java from sources/exceptions/VSNegativeNumberException.java:
-
-
-public class VSNegativeNumberException extends Exception {
- private static final long serialVersionUID = 1L;
-}
-
-
----
-
hsbot
@@ -2239,7 +2146,7 @@ public class VSNegativeNumberException extends Exception {
📊 Commits: 80
📈 Lines of Code: 601
📅 Development Period: 2009-11-22 to 2011-10-17
-
🔥 Recent Activity: 5444.8 days (avg. age of last 42 commits)
+
🔥 Recent Activity: 5448.1 days (avg. age of last 42 commits)
-typedef struct {
- int i_current_line_nr;
- int i_current_pos_nr;
- int i_num_tokenends;
- char *c_filename;
- char *c_codestring;
- FILE *fp;
- List *p_list_token;
- TokenType tt_last;
-
+
vs-sim
+
+
+
📚 Documentation: Markdown (100.0%)
+
📊 Commits: 411
+
📈 Lines of Code: 0
+
📄 Lines of Documentation: 7
+
📅 Development Period: 2008-05-15 to 2015-05-23
+
🔥 Recent Activity: 5809.1 days (avg. age of last 42 commits)
+
⚖️ License: No license found
+
🏷️ Latest Release: v1.0 (2008-08-24)
+
+⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.
+
+VS-Sim is an open-source distributed systems simulator written in Java, developed as a diploma thesis at Aachen University of Applied Sciences. It provides a visual environment for simulating and understanding distributed system algorithms including consensus protocols (one-phase/two-phase commit), time synchronization (Berkeley, Lamport, vector clocks), and communication patterns (multicast, broadcast, reliable messaging). The simulator is useful for educational purposes, allowing students and researchers to visualize complex distributed system concepts through interactive simulations.
+
+The implementation features a modular architecture with separate packages for core processes, events, protocols, and visualization. It includes pre-built protocol implementations, a GUI-based simulator with start/pause/reset controls, serialization support for saving simulations, and comprehensive time modeling systems. The codebase demonstrates clean separation of concerns with abstract base classes for extensibility and a plugin-like protocol system for easy addition of new distributed algorithms.
+
+View on Codeberg
+View on GitHub
Generated with Gemtexter 3.0.1-develop |
served by OpenBSD/relayd(8)+httpd(8) |
diff --git a/about/showcase/debroid/image-1.png b/about/showcase/debroid/image-1.png
index a10f334f..0c815b21 100644
--- a/about/showcase/debroid/image-1.png
+++ b/about/showcase/debroid/image-1.png
@@ -17,7 +17,6 @@
-