diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-01 15:12:41 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-01 15:12:41 +0200 |
| commit | 1db8546d34bbefa89e4c64a0d76401a9d35377c9 (patch) | |
| tree | e1bd59f97db52e5614e80ce97608696e5857ea22 | |
| parent | da4affd2b41019f36697fcd8463f8d8a833b3d7a (diff) | |
fixes
37 files changed, 68 insertions, 68 deletions
diff --git a/gemfeed/2010-05-09-the-fype-programming-language.gmi.tpl b/gemfeed/2010-05-09-the-fype-programming-language.gmi.tpl index d4dac222..683e2357 100644 --- a/gemfeed/2010-05-09-the-fype-programming-language.gmi.tpl +++ b/gemfeed/2010-05-09-the-fype-programming-language.gmi.tpl @@ -275,7 +275,7 @@ until <expression> { <statements> } ## Scopes -A new scope starts with an { and ends with an }. An exception is a procedure, which does not use its own scope (see later in this manual). Control statements and functions support scopes. The "scope" function prints out all available symbols at the current scope. Here is a small example: +A new scope starts with an { and ends with an }. An exception is a procedure, which does not use its own scope (see later in this manual). Control statements and functions support scopes. The "scope" function prints out all available symbols at the current scope. Here is a small example: ``` my foo = 1; diff --git a/gemfeed/2015-12-05-run-debian-on-your-phone-with-debroid.gmi.tpl b/gemfeed/2015-12-05-run-debian-on-your-phone-with-debroid.gmi.tpl index 40539e7f..8b153366 100644 --- a/gemfeed/2015-12-05-run-debian-on-your-phone-with-debroid.gmi.tpl +++ b/gemfeed/2015-12-05-run-debian-on-your-phone-with-debroid.gmi.tpl @@ -173,7 +173,7 @@ chmod +x /data/local/userinit.sh exit ``` -Reboot & test! Enjoy! +Reboot & test! Enjoy! E-Mail your comments to `paul@nospam.buetow.org` :-) diff --git a/gemfeed/2016-04-03-offsite-backup-with-zfs.gmi b/gemfeed/2016-04-03-offsite-backup-with-zfs.gmi index 7eaaa917..0833a3eb 100644 --- a/gemfeed/2016-04-03-offsite-backup-with-zfs.gmi +++ b/gemfeed/2016-04-03-offsite-backup-with-zfs.gmi @@ -32,7 +32,7 @@ Once weekly, all the local server data is copied to two external USB drives as a ## Storing it at my apartment is not enough -Now I am thinking about an offsite backup of all this local data. The problem is that all the data remains on a single physical location: My local MicroServer. What happens when the house burns or my server, including the internal disks and the attached USB drives, gets stolen? My first thought was to back up everything to the "cloud". However, the significant issue here is the limited amount of available upload bandwidth (only 1MBit/s). +Now I am thinking about an offsite backup of all this local data. The problem is that all the data remains on a single physical location: My local MicroServer. What happens when the house burns or my server, including the internal disks and the attached USB drives, gets stolen? My first thought was to back up everything to the "cloud". However, the significant issue here is the limited amount of available upload bandwidth (only 1MBit/s). The solution is adding another USB drive (2TB) with an encryption container (GELI) and a ZFS pool. The GELI encryption requires a secret key and a secret passphrase. I am updating the data to that drive once every three months (my calendar is reminding me about it), and afterwards, I keep that drive at a secret location outside of my apartment. All the information needed to decrypt (mounting the GELI container) is stored at another (secure) place. Key and passphrase are kept at different sites, though. Even if someone knew of it, he would not be able to decrypt it as some additional insider knowledge would be required as well. diff --git a/gemfeed/2021-05-16-personal-bash-coding-style-guide.gmi.tpl b/gemfeed/2021-05-16-personal-bash-coding-style-guide.gmi.tpl index d7903de2..9c67046c 100644 --- a/gemfeed/2021-05-16-personal-bash-coding-style-guide.gmi.tpl +++ b/gemfeed/2021-05-16-personal-bash-coding-style-guide.gmi.tpl @@ -384,7 +384,7 @@ The following two paragraphs are thoroughly quoted from the Google guidelines. B I also highly recommend having a read through the "Advanced Bash-Scripting Guide" (not from Google). I use it as the universal Bash reference and learn something new every time I look at it. -=> https://tldp.org/LDP/abs/html/ Advanced Bash-Scripting Guide +=> https://tldp.org/LDP/abs/html/ Advanced Bash-Scripting Guide E-Mail your comments to `paul@nospam.buetow.org` :-) diff --git a/gemfeed/2021-06-05-gemtexter-one-bash-script-to-rule-it-all.gmi.tpl b/gemfeed/2021-06-05-gemtexter-one-bash-script-to-rule-it-all.gmi.tpl index b8cd1588..883e130a 100644 --- a/gemfeed/2021-06-05-gemtexter-one-bash-script-to-rule-it-all.gmi.tpl +++ b/gemfeed/2021-06-05-gemtexter-one-bash-script-to-rule-it-all.gmi.tpl @@ -108,7 +108,7 @@ I followed all these best practices, and in my opinion, the result is a pretty m ShellCheck, a shell script analysis tool written in Haskell, is run on Gemtexter ensuring that all code is acceptable. I am pretty impressed with what ShellCheck found. -It, for example, detected "some_command | while read var; do ...; done" loops and hinted that these create a new subprocess for the while part. The result is that all variable modifications taking place in the while-subprocess won't reflect the primary Bash process. ShellSheck then recommended rewriting the loop so that no subprocess is spawned as "while read -r var; do ...; done < <(some_command)". ShellCheck also pointed out to add a "-r" to "read"; otherwise, there could be an issue with backspaces in the loop data. +It, for example, detected "some_command | while read var; do ...; done" loops and hinted that these create a new subprocess for the while part. The result is that all variable modifications taking place in the while-subprocess won't reflect the primary Bash process. ShellSheck then recommended rewriting the loop so that no subprocess is spawned as "while read -r var; do ...; done < <(some_command)". ShellCheck also pointed out to add a "-r" to "read"; otherwise, there could be an issue with backspaces in the loop data. Furthermore, ShellCheck recommended many more improvements. Declaration of unused variables and missing variable and string quotations were the most common ones. ShellSheck immensely helped to improve the robustness of the script. diff --git a/gemfeed/2021-08-01-on-being-pedantic-about-open-source.gmi.tpl b/gemfeed/2021-08-01-on-being-pedantic-about-open-source.gmi.tpl index 08dff942..a678c997 100644 --- a/gemfeed/2021-08-01-on-being-pedantic-about-open-source.gmi.tpl +++ b/gemfeed/2021-08-01-on-being-pedantic-about-open-source.gmi.tpl @@ -22,7 +22,7 @@ I believe that it is essential to always have free and open-source alternatives One benefit of using open-source software is that it doesn't cost anything, right? That's correct in many cases. However, in some cases you still need to spend a significant amount of time configuring the software to work for you. It will be more expensive to use open-source software than proprietary commercial one if you aren't careful. -Not to say that I haven't seen the same effect with commercial software where people had to, after buying it, put a bunch of effort to make it work due to the lack of quality or due to high complexity. But that's either bad luck or bad decision-making. Most commercial providers I have worked with try to make it work for you, so you also will buy other products and services from them later on and don't lose you as a happy customer. +Not to say that I haven't seen the same effect with commercial software where people had to, after buying it, put a bunch of effort to make it work due to the lack of quality or due to high complexity. But that's either bad luck or bad decision-making. Most commercial providers I have worked with try to make it work for you, so you also will buy other products and services from them later on and don't lose you as a happy customer. ## Commercial providers diff --git a/gemfeed/2021-09-12-keep-it-simple-and-stupid.gmi.tpl b/gemfeed/2021-09-12-keep-it-simple-and-stupid.gmi.tpl index dcec5dd7..ebe48abc 100644 --- a/gemfeed/2021-09-12-keep-it-simple-and-stupid.gmi.tpl +++ b/gemfeed/2021-09-12-keep-it-simple-and-stupid.gmi.tpl @@ -35,7 +35,7 @@ Have a look at COBOL, a prevalent programming language of the past. No one is le ### On Kubernetes -Now have a look at Kubernetes (k8s), the current trendy infrastructure thing to use nowadays. Of course, there are many benefits of using k8s (auto-scaling, reproducible deployments, dynamic resource allocation and resource sharing, saving of hardware costs, good commercial for potential employees as it is the current hot sauce of infrastructure). But all of this also comes with costs: You need experts operating the k8s cluster (or you need to pay extra for a managed cluster in the cloud), increased complexity of the system (k8s comes with a steep learning curve). The latter not only applies to the engineers managing the k8s cluster - it also applies to the software engineers, who now have to develop 'cloud native' applications and, therefore, have to change how they developed software how they used to. They all need to be re-educated on what cloud-native means, and they also need to understand the key concepts of k8s for writing optimal software for it. +Now have a look at Kubernetes (k8s), the current trendy infrastructure thing to use nowadays. Of course, there are many benefits of using k8s (auto-scaling, reproducible deployments, dynamic resource allocation and resource sharing, saving of hardware costs, good commercial for potential employees as it is the current hot sauce of infrastructure). But all of this also comes with costs: You need experts operating the k8s cluster (or you need to pay extra for a managed cluster in the cloud), increased complexity of the system (k8s comes with a steep learning curve). The latter not only applies to the engineers managing the k8s cluster - it also applies to the software engineers, who now have to develop 'cloud native' applications and, therefore, have to change how they developed software how they used to. They all need to be re-educated on what cloud-native means, and they also need to understand the key concepts of k8s for writing optimal software for it. ### The younger generation of IT professionals @@ -77,7 +77,7 @@ Another perfect example is the Adobe PDF reader. How can it be that the inventor ### The power of plain text files -Speaking of file formats, never underestimate the power of plain text files. Plain text files don't require any special software to be opened, and they outlive the software which created them in the first place. You will still be able to read a plain text file on a modern computer system ten (or twenty) years from now, but you probably won't be able to read such an old version of an Adobe Photoshop image file if the software required for reading that format isn't supported anymore and doesn't run anymore on modern computers. +Speaking of file formats, never underestimate the power of plain text files. Plain text files don't require any special software to be opened, and they outlive the software which created them in the first place. You will still be able to read a plain text file on a modern computer system ten (or twenty) years from now, but you probably won't be able to read such an old version of an Adobe Photoshop image file if the software required for reading that format isn't supported anymore and doesn't run anymore on modern computers. ### KISS for programmers diff --git a/gemfeed/2021-10-22-defensive-devops.gmi.tpl b/gemfeed/2021-10-22-defensive-devops.gmi.tpl index 96237193..37b2ee32 100644 --- a/gemfeed/2021-10-22-defensive-devops.gmi.tpl +++ b/gemfeed/2021-10-22-defensive-devops.gmi.tpl @@ -69,7 +69,7 @@ Furthermore, when you write Bash script, always run the tool ShellSheck (https:/ You probably won't have time for writing unit tests. But what you can do is to pedantically test your code manually. But you have to do the testing on a production machine. So how can you test your code in production without causing more damage? -Your script should be idempotent. This means you can run it infinite times in a row, and you will always get the same result. For example, in the first run of the script, a file A get's renamed to A.backup. The second time you run the script, it attempts to do the same, but it recognises that A has already been renamed to A.backup and then it is skipping that step. This is very helpful for manually testing, as it means that you can re-run the script every time you extended it. You should dry-run the script at least once before running it for real. You can apply the same principle for almost all features you add to the code. +Your script should be idempotent. This means you can run it infinite times in a row, and you will always get the same result. For example, in the first run of the script, a file A get's renamed to A.backup. The second time you run the script, it attempts to do the same, but it recognises that A has already been renamed to A.backup and then it is skipping that step. This is very helpful for manually testing, as it means that you can re-run the script every time you extended it. You should dry-run the script at least once before running it for real. You can apply the same principle for almost all features you add to the code. You may also want to inject manual negative testing into your script. For example, you want to run a particular function F in your script but only if a certain pre-condition is met, and you want to ensure that the code branching works as expected. The pre-condition check could be pretty complex (e.g. N log messages containing a specific warning string are found in the applications logs, but only on the cluster leader server). You can flip the switch directly in the code manually (e.g. run F only, when the pre-condition isn't met) and then perform a dry run of the script and study the output. Once done, flip the switch back to its correct configuration. For double insurance, test the same on a different server type (e.g. on a follower and not on a leader system). diff --git a/gemfeed/2021-12-26-how-to-stay-sane-as-a-devops-person.gmi.tpl b/gemfeed/2021-12-26-how-to-stay-sane-as-a-devops-person.gmi.tpl index 106d882f..46fcb886 100644 --- a/gemfeed/2021-12-26-how-to-stay-sane-as-a-devops-person.gmi.tpl +++ b/gemfeed/2021-12-26-how-to-stay-sane-as-a-devops-person.gmi.tpl @@ -48,7 +48,7 @@ There are many temptations to get side-tracked by other projects and/or issues. If the request is urgent, and you have the capacity to help, probably you should help. If it's not urgent, maybe ask to pospone the request (e.g. ask to create a ticket, so that someone from your team can work on it later). -If the request is urgent, but you don't have the knowledge or the capacity to help, try to defer to a colleague who might be able to help. You could also provide some quick tips and hints, so that the requester can resolve the issue by himself. Make it transparent why you might not have the time right now, as this can help the person to review his own priorities or to escalate. +If the request is urgent, but you don't have the knowledge or the capacity to help, try to defer to a colleague who might be able to help. You could also provide some quick tips and hints, so that the requester can resolve the issue by himself. Make it transparent why you might not have the time right now, as this can help the person to review his own priorities or to escalate. ### Escalation is only a tool diff --git a/gemfeed/2022-01-01-bash-golf-part-2.gmi.tpl b/gemfeed/2022-01-01-bash-golf-part-2.gmi.tpl index 1938de51..3898fb5a 100644 --- a/gemfeed/2022-01-01-bash-golf-part-2.gmi.tpl +++ b/gemfeed/2022-01-01-bash-golf-part-2.gmi.tpl @@ -335,7 +335,7 @@ Ok, let's dig deeper: -e Exit immediately if a command exits with a non-zero status. ``` -As you can see in the following example, the Bash terminates after the execution of "grep" as "foo" is not matching "bar". Therefore, grep exits with 1 (unsuccessfully) and the shell aborts. And therefore, "bar" will not be printed out anymore: +As you can see in the following example, the Bash terminates after the execution of "grep" as "foo" is not matching "bar". Therefore, grep exits with 1 (unsuccessfully) and the shell aborts. And therefore, "bar" will not be printed out anymore: ``` ❯ bash -c 'set -e; echo hello; grep -q bar <<< foo; echo bar' diff --git a/gemfeed/2022-05-27-perl-is-still-a-great-choice.gmi.tpl b/gemfeed/2022-05-27-perl-is-still-a-great-choice.gmi.tpl index 548192ee..0a16ff4c 100644 --- a/gemfeed/2022-05-27-perl-is-still-a-great-choice.gmi.tpl +++ b/gemfeed/2022-05-27-perl-is-still-a-great-choice.gmi.tpl @@ -72,7 +72,7 @@ So it means that Perl and Raku now exist in parallel. They influence each other, => https://www.OpenBSD.org The OpenBSD Operating System => https://news.ycombinator.com/item?id=23360338 Why does OpenBSD still include Perl in its base installation? -The renaming of Perl 6 to Raku has now opened the door for a future Perl 7. As far as I understand, Perl 7 will be Perl 5 but with modern features enabled by default (e.g. pragmas `use strict;`, `use warnings;`, `use signatures;` and so on. Also, the hope is that a Perl 7 with modern standards will attract more beginners. There aren't many Perl jobs out there nowadays. That's mostly due to Perl's bad (bad for no real reasons) reputation. +The renaming of Perl 6 to Raku has now opened the door for a future Perl 7. As far as I understand, Perl 7 will be Perl 5 but with modern features enabled by default (e.g. pragmas `use strict;`, `use warnings;`, `use signatures;` and so on. Also, the hope is that a Perl 7 with modern standards will attract more beginners. There aren't many Perl jobs out there nowadays. That's mostly due to Perl's bad (bad for no real reasons) reputation. > Update 2022-12-10: A reader pointed out, that `use v5.36;` already turns strict, warnings and signatures pragmas automatically on! diff --git a/gemfeed/2022-06-15-sweating-the-small-stuff.gmi.tpl b/gemfeed/2022-06-15-sweating-the-small-stuff.gmi.tpl index d95880a2..bfced2a8 100644 --- a/gemfeed/2022-06-15-sweating-the-small-stuff.gmi.tpl +++ b/gemfeed/2022-06-15-sweating-the-small-stuff.gmi.tpl @@ -129,7 +129,7 @@ Pos | System | Kernel | Uptime | 20 | mars | Linux 3.2.0-4-amd64 | 190d 05:44:21 | ``` -=> https://codeberg.org/snonux/guprecords +=> https://codeberg.org/snonux/guprecords This all is of no real practical use but fun! diff --git a/gemfeed/2022-12-24-ultrarelearning-java-my-takeaways.gmi.tpl b/gemfeed/2022-12-24-ultrarelearning-java-my-takeaways.gmi.tpl index 8c23cfb5..36ca9bd7 100644 --- a/gemfeed/2022-12-24-ultrarelearning-java-my-takeaways.gmi.tpl +++ b/gemfeed/2022-12-24-ultrarelearning-java-my-takeaways.gmi.tpl @@ -55,7 +55,7 @@ Another great way to get the hang of Java again was to sneak into the code revie ### Took ownership of a roadmap-Java project -Besides my Pet Project, I also took ownership of a regular roadmap Java project at work, making an internal Java service capable of running in Kubernetes. This was a bunch of minor changes and adding a bunch of classes and unit tests dealing with the statelessness and a persistent job queue in Redis. The job also involved reading and understanding a lot of already existing Java code. It wasn't part of my job description, but it was fun, and I learned a lot. The service runs smoothly in production now. Of course, all of my code got reviewed by my Software Engineering colleagues. +Besides my Pet Project, I also took ownership of a regular roadmap Java project at work, making an internal Java service capable of running in Kubernetes. This was a bunch of minor changes and adding a bunch of classes and unit tests dealing with the statelessness and a persistent job queue in Redis. The job also involved reading and understanding a lot of already existing Java code. It wasn't part of my job description, but it was fun, and I learned a lot. The service runs smoothly in production now. Of course, all of my code got reviewed by my Software Engineering colleagues. ## The good diff --git a/gemfeed/2023-01-23-why-grapheneos-rox.gmi.tpl b/gemfeed/2023-01-23-why-grapheneos-rox.gmi.tpl index e266d22e..c28a124b 100644 --- a/gemfeed/2023-01-23-why-grapheneos-rox.gmi.tpl +++ b/gemfeed/2023-01-23-why-grapheneos-rox.gmi.tpl @@ -124,7 +124,7 @@ A pure Linux phone, e.g. with Ubuntu Touch installed, e.g. on a PinePhone, Fairp => https://ubuntu-touch.io/ Ubuntu Touch => https://en.wikipedia.org/wiki/Linux_for_mobile_devices More Linux distributions for mobile devices -But here, Google Play would not be sandboxed; you could not configure individual network permissions and storage scopes like in GrapheneOS. Pure Linux-compatible phones usually come with a crappy camera, and the battery life is generally pretty bad (only a few hours). Also, no big tech company pushes the development of Linux phones. Everything relies on hobbyists, whereas multiple big tech companies put a lot of effort into the Android project, and a lot of code also goes into the Android Open-Source project. +But here, Google Play would not be sandboxed; you could not configure individual network permissions and storage scopes like in GrapheneOS. Pure Linux-compatible phones usually come with a crappy camera, and the battery life is generally pretty bad (only a few hours). Also, no big tech company pushes the development of Linux phones. Everything relies on hobbyists, whereas multiple big tech companies put a lot of effort into the Android project, and a lot of code also goes into the Android Open-Source project. Currently, pure Linux phones are only a nice toy to tinker with but are still not ready (will they ever?) to be the daily driver. SailfishOS may be an exception; I played around with it in the past. It is pretty usable, but it's not an option for me as it is partial a proprietary operating system. diff --git a/gemfeed/2023-02-26-how-to-shut-down-after-work.gmi.tpl b/gemfeed/2023-02-26-how-to-shut-down-after-work.gmi.tpl index dbbb82f5..2e1e2aff 100644 --- a/gemfeed/2023-02-26-how-to-shut-down-after-work.gmi.tpl +++ b/gemfeed/2023-02-26-how-to-shut-down-after-work.gmi.tpl @@ -51,7 +51,7 @@ Often, your mind goes back to work-related stuff even after work. That's normal * Think of or work on that fun passion project. I currently, for example, like to learn and code a bit in Rakulang. * Read. Nothing beats reading a good Science Fiction Novel (or whatever you prefer) before falling asleep. -Some of these can be habit-stacked: Exercise could be combined with watching videos about your passion project (e.g. watching lectures about that new programming language you are currently learning for fun). With walking, for example, you could combine listening to an Audiobook or music, or you could also think about your passion project during that walk. +Some of these can be habit-stacked: Exercise could be combined with watching videos about your passion project (e.g. watching lectures about that new programming language you are currently learning for fun). With walking, for example, you could combine listening to an Audiobook or music, or you could also think about your passion project during that walk. ## Get a pet diff --git a/gemfeed/2023-03-16-the-pragmatic-programmer-book-notes.gmi.tpl b/gemfeed/2023-03-16-the-pragmatic-programmer-book-notes.gmi.tpl index c9dcf7bb..1a2f2f94 100644 --- a/gemfeed/2023-03-16-the-pragmatic-programmer-book-notes.gmi.tpl +++ b/gemfeed/2023-03-16-the-pragmatic-programmer-book-notes.gmi.tpl @@ -72,7 +72,7 @@ It's your life. Share it, celebrate it, be proud and have fun. How to motivate others to contribute something (e.g. ideas to a startup): -> A kindly, old stranger was walking through the land when he came upon a village. As he entered, the villagers moved towards their homes, locking doors and windows. The stranger smiled and asked, why are you all so frightened. I am a simple traveler, looking for a soft place to stay for the night and a warm place for a meal. "There's not a bite to eat in the whole province," he was told. "We are weak and our children are starving. Better keep moving on." "Oh, I have everything I need," he said. "In fact, I was thinking of making some stone soup to share with all of you." He pulled an iron cauldron from his cloak, filled it with water, and began to build a fire under it. Then, with great ceremony, he drew an ordinary-looking stone from a silken bag and dropped it into the water. By now, hearing the rumor of food, most of the villagers had come out of their homes or watched from their windows. As the stranger sniffed the "broth" and licked his lips in anticipation, hunger began to overcome their fear. "Ahh," the stranger said to himself rather loudly, "I do like a tasty stone soup. Of course, stone soup with cabbage -- that's hard to beat." Soon a villager approached hesitantly, holding a small cabbage he'd retrieved from its hiding place, and added it to the pot. "Wonderful!!" cried the stranger. "You know, I once had stone soup with cabbage and a bit of salt beef as well, and it was fit for a king." The village butcher managed to find some salt beef . . . And so it went, through potatoes, onions, carrots, mushrooms, and so on, until there was indeed a delicious meal for everyone in the village to share. The village elder offered the stranger a great deal of money for the magic stone, but he refused to sell it and traveled on the next day. As he left, the stranger came upon a group of village children standing near the road. He gave the silken bag containing the stone to the youngest child, whispering to a group, "It was not the stone, but the villagers that had performed the magic." +> A kindly, old stranger was walking through the land when he came upon a village. As he entered, the villagers moved towards their homes, locking doors and windows. The stranger smiled and asked, why are you all so frightened. I am a simple traveler, looking for a soft place to stay for the night and a warm place for a meal. "There's not a bite to eat in the whole province," he was told. "We are weak and our children are starving. Better keep moving on." "Oh, I have everything I need," he said. "In fact, I was thinking of making some stone soup to share with all of you." He pulled an iron cauldron from his cloak, filled it with water, and began to build a fire under it. Then, with great ceremony, he drew an ordinary-looking stone from a silken bag and dropped it into the water. By now, hearing the rumor of food, most of the villagers had come out of their homes or watched from their windows. As the stranger sniffed the "broth" and licked his lips in anticipation, hunger began to overcome their fear. "Ahh," the stranger said to himself rather loudly, "I do like a tasty stone soup. Of course, stone soup with cabbage -- that's hard to beat." Soon a villager approached hesitantly, holding a small cabbage he'd retrieved from its hiding place, and added it to the pot. "Wonderful!!" cried the stranger. "You know, I once had stone soup with cabbage and a bit of salt beef as well, and it was fit for a king." The village butcher managed to find some salt beef . . . And so it went, through potatoes, onions, carrots, mushrooms, and so on, until there was indeed a delicious meal for everyone in the village to share. The village elder offered the stranger a great deal of money for the magic stone, but he refused to sell it and traveled on the next day. As he left, the stranger came upon a group of village children standing near the road. He gave the silken bag containing the stone to the youngest child, whispering to a group, "It was not the stone, but the villagers that had performed the magic." By working together, everyone contributes what they can, achieving a greater good together. diff --git a/gemfeed/2023-03-25-gemtexter-2.0.0-lets-gemtext-again-2.gmi.tpl b/gemfeed/2023-03-25-gemtexter-2.0.0-lets-gemtext-again-2.gmi.tpl index 00639a96..396ea9d9 100644 --- a/gemfeed/2023-03-25-gemtexter-2.0.0-lets-gemtext-again-2.gmi.tpl +++ b/gemfeed/2023-03-25-gemtexter-2.0.0-lets-gemtext-again-2.gmi.tpl @@ -119,7 +119,7 @@ An example blog post without any publishing date looks like this: The remaining content of the Gemtext file... ``` -Gemtexter will add a line starting with `> Published at ...` now. Any subsequent Atom feed generation will then use that date. +Gemtexter will add a line starting with `> Published at ...` now. Any subsequent Atom feed generation will then use that date. ```sh % cat gemfeed/2023-02-26-title-here.gmi diff --git a/gemfeed/2023-07-17-career-guide-and-soft-skills-book-notes.gmi.tpl b/gemfeed/2023-07-17-career-guide-and-soft-skills-book-notes.gmi.tpl index dc4b22c9..0319e80c 100644 --- a/gemfeed/2023-07-17-career-guide-and-soft-skills-book-notes.gmi.tpl +++ b/gemfeed/2023-07-17-career-guide-and-soft-skills-book-notes.gmi.tpl @@ -133,7 +133,7 @@ Use your most productive hours to work on you. Make that your priority. Take car * Friendships and positive thinking help to have and maintain better health, longer Life, better productivity and increased happiness. * Positive thinking can be trained and be a habit. Read the book "The Power of Positive Thinking". -* Stoicism helps. Meditation helps. Playing for fun helps too. +* Stoicism helps. Meditation helps. Playing for fun helps too. Become the person you want to become (your self image). Program your brain unconsciously. Don't become the person other people want you to be. Embrace yourself, you are you. diff --git a/gemfeed/2024-01-13-one-reason-why-i-love-openbsd.gmi.tpl b/gemfeed/2024-01-13-one-reason-why-i-love-openbsd.gmi.tpl index 6908d132..970da21f 100644 --- a/gemfeed/2024-01-13-one-reason-why-i-love-openbsd.gmi.tpl +++ b/gemfeed/2024-01-13-one-reason-why-i-love-openbsd.gmi.tpl @@ -43,7 +43,7 @@ I followed the same procedure the previous times and never encountered any diffi I have seen upgrades of other Operating Systems either take a long time or break the system (which takes manual steps to repair). That's just one of many reasons why I love OpenBSD! There appear never to be any problems. It just gets its job done! -=> https://www.openbsd.org The OpenBSD Project +=> https://www.openbsd.org The OpenBSD Project BTW: are you looking for an opinionated OpenBSD VM hoster? OpenBSD Amsterdam may be for you. They rock (I am having a VM there, too)! diff --git a/gemfeed/2024-06-23-terminal-multiplexing-with-tmux.gmi.tpl b/gemfeed/2024-06-23-terminal-multiplexing-with-tmux.gmi.tpl index bd109308..a50f5d8b 100644 --- a/gemfeed/2024-06-23-terminal-multiplexing-with-tmux.gmi.tpl +++ b/gemfeed/2024-06-23-terminal-multiplexing-with-tmux.gmi.tpl @@ -39,7 +39,7 @@ I can also recommend this book (this is the book I got started with with Tmux): => https://pragprog.com/titles/bhtmux2/tmux-2/ -Over the years, I have built a couple of shell helper functions to optimize my workflows. Tmux is extensively integrated into my daily workflows (personal and work). I had colleagues asking me about my Tmux config and helper scripts for Tmux several times. It would be neat to blog about it so that everyone interested in it can make a copy of my configuration and scripts. +Over the years, I have built a couple of shell helper functions to optimize my workflows. Tmux is extensively integrated into my daily workflows (personal and work). I had colleagues asking me about my Tmux config and helper scripts for Tmux several times. It would be neat to blog about it so that everyone interested in it can make a copy of my configuration and scripts. The configuration and scripts in this blog post are only the non-work-specific parts. There are more helper scripts, which I only use for work (and aren't really useful outside of work due to the way servers and clusters are structured there). @@ -191,7 +191,7 @@ Before I used Tmux, I was a heavy user of ClusterSSH, which allowed me to log in However, since I started using Tmux, I retired ClusterSSH, as it came with the benefit that Tmux only needs to be run in the terminal, whereas ClusterSSH spawned terminal windows, which aren't easily portable (e.g., from a Linux desktop to macOS). The `tmux::cluster_ssh` function can have N arguments, where: * ...the first argument will be the session name (see `tmux::tssh_from_argument` helper function), and all remaining arguments will be server hostnames/FQDNs to connect to simultaneously. -* ...or, the first argument is a file name, and the file contains a list of hostnames/FQDNs (see `tmux::ssh_from_file` helper function) +* ...or, the first argument is a file name, and the file contains a list of hostnames/FQDNs (see `tmux::ssh_from_file` helper function) This is the function definition behind the `tssh` alias: @@ -288,7 +288,7 @@ I often search the history backwards with `prefix-key [` followed by a `?`, whic Once I have identified the terminal text to be copied, I enter visual select mode with `v`, highlight all the text to be copied (using arrow keys or Vi motions), and press `y` to yank it (sorry if this all sounds a bit complicated, but Vim/NeoVim users will know this, as it is pretty much how you do it there as well). -For `v` and `y` to work, the following has to be added to the Tmux configuration file: +For `v` and `y` to work, the following has to be added to the Tmux configuration file: ``` bind-key -T copy-mode-vi 'v' send -X begin-selection diff --git a/gemfeed/2024-07-05-random-weird-things.gmi.tpl b/gemfeed/2024-07-05-random-weird-things.gmi.tpl index 24022f62..e216b46d 100644 --- a/gemfeed/2024-07-05-random-weird-things.gmi.tpl +++ b/gemfeed/2024-07-05-random-weird-things.gmi.tpl @@ -82,7 +82,7 @@ Fancy watching Star Wars Episode IV in ASCII? Head to the ASCII cinema: Netflix has got the Hello World application run in production 😱 -* https://www.Netflix.com/helloworld +* https://www.Netflix.com/helloworld > By the time this is posted, it seems that Netflix has taken it offline... I should have created a screenshot! diff --git a/gemfeed/2024-07-07-the-stoic-challenge-book-notes.gmi.tpl b/gemfeed/2024-07-07-the-stoic-challenge-book-notes.gmi.tpl index 9b178f5e..45b69261 100644 --- a/gemfeed/2024-07-07-the-stoic-challenge-book-notes.gmi.tpl +++ b/gemfeed/2024-07-07-the-stoic-challenge-book-notes.gmi.tpl @@ -2,7 +2,7 @@ > Published at 2024-07-07T12:46:55+03:00 -These are my personal takeaways after reading "The Stoic Challenge: A Philosopher's Guide to Becoming Tougher, Calmer, and More Resilient" by William B. Irvine. +These are my personal takeaways after reading "The Stoic Challenge: A Philosopher's Guide to Becoming Tougher, Calmer, and More Resilient" by William B. Irvine. ``` ,.......... .........., diff --git a/gemfeed/2024-08-05-typing-127.1-words-per-minute.gmi.tpl b/gemfeed/2024-08-05-typing-127.1-words-per-minute.gmi.tpl index 0c60565c..d1f7b3bb 100644 --- a/gemfeed/2024-08-05-typing-127.1-words-per-minute.gmi.tpl +++ b/gemfeed/2024-08-05-typing-127.1-words-per-minute.gmi.tpl @@ -166,7 +166,7 @@ You can't reach your average typing speed first ting the morning. It would help As mentioned, the Kinesis is a great keyboard, but it is not meant for travel. -I guess keyboards will always be my expensive hobby, so I also purchased another ergonomic, ortho-linear, concave split keyboard, the Glove80 (with the Red Pro low-profile switches). This keyboard is much lighter and, in my opinion, much better suited for travel than the Kinesis. It also comes with a great travel case. +I guess keyboards will always be my expensive hobby, so I also purchased another ergonomic, ortho-linear, concave split keyboard, the Glove80 (with the Red Pro low-profile switches). This keyboard is much lighter and, in my opinion, much better suited for travel than the Kinesis. It also comes with a great travel case. Here is a photo of me using it with my Surface Go 2 (it runs Linux, by the way) while waiting for the baggage drop at the airport: diff --git a/gemfeed/2024-09-07-site-reliability-engineering-part-4.gmi.tpl b/gemfeed/2024-09-07-site-reliability-engineering-part-4.gmi.tpl index b0a5a28b..6bcf5913 100644 --- a/gemfeed/2024-09-07-site-reliability-engineering-part-4.gmi.tpl +++ b/gemfeed/2024-09-07-site-reliability-engineering-part-4.gmi.tpl @@ -38,7 +38,7 @@ Shadowing Sessions: Each new engineer undergoes two on-call week shadowing sessi Comprehensive Runbooks: We created 64 runbooks (by the time writing this probably more than 100) that are composable like Lego bricks. Each runbook covers a specific scenario and guides the engineer step-by-step to resolution. Pairing these with monitoring alerts linked directly to Confluence docs, and from there to the respective runbooks, ensures every alert can be navigated with ease (well, there are always exceptions to the rule...). -Self-Sufficiency & Confidence Building: With all these resources at their fingertips, our on-call engineers become self-sufficient for most of the common issues they'll face (new starters can now handle around 80% of the most common issue after 6 weeks they had joined the company). This boosts their confidence and ensures they can handle Tier-1 incidents independently. +Self-Sufficiency & Confidence Building: With all these resources at their fingertips, our on-call engineers become self-sufficient for most of the common issues they'll face (new starters can now handle around 80% of the most common issue after 6 weeks they had joined the company). This boosts their confidence and ensures they can handle Tier-1 incidents independently. Documentation and Feedback Loop: Continuous improvement is key. We regularly update our documentation based on feedback from the engineers. This makes our process even more robust and user-friendly. diff --git a/gemfeed/2024-12-03-f3s-kubernetes-with-freebsd-part-2.gmi.tpl b/gemfeed/2024-12-03-f3s-kubernetes-with-freebsd-part-2.gmi.tpl index ac865bf3..19557ad7 100644 --- a/gemfeed/2024-12-03-f3s-kubernetes-with-freebsd-part-2.gmi.tpl +++ b/gemfeed/2024-12-03-f3s-kubernetes-with-freebsd-part-2.gmi.tpl @@ -46,7 +46,7 @@ The Beelink comes with the following specs: * 500 GB M.2 SSD, with the option to install a 2nd 2.5 SSD drive (which I want to make use of later in this blog series). * GBit ethernet * Four USB 3.2 Gen2 ports (maybe I want to mount something externally at some point) -* Dimensions and weight: 115*102*39mm, 280g +* Dimensions and weight: 115*102*39mm, 280g * Silent cooling system. * HDMI output (needed only for the initial installation and maybe for troubleshooting later) * Auto power on via WoL (may make use of it) diff --git a/gemfeed/2025-01-15-working-with-an-sre-interview.gmi.tpl b/gemfeed/2025-01-15-working-with-an-sre-interview.gmi.tpl index ac27ab94..ee903a45 100644 --- a/gemfeed/2025-01-15-working-with-an-sre-interview.gmi.tpl +++ b/gemfeed/2025-01-15-working-with-an-sre-interview.gmi.tpl @@ -2,7 +2,7 @@ > Published at 2025-01-15T00:16:04+02:00 -I have been interviewed by Florian Buetow on `cracking-ai-engineering.com` about what it's like working with a Site Reliability Engineer from the point of view of a Software Engineer, Data Scientist, and AI Engineer. +I have been interviewed by Florian Buetow on `cracking-ai-engineering.com` about what it's like working with a Site Reliability Engineer from the point of view of a Software Engineer, Data Scientist, and AI Engineer. => https://www.cracking-ai-engineering.com/writing/2025/01/12/working-with-an-sre-interview/ See original interview here => https://www.cracking-ai-engineering.com Cracking AI Engineering @@ -50,7 +50,7 @@ Tell us about how you joined Mimecast. When did you fully embrace the SRE role? What are the differences between SRE, DevOps, SysAdmin, and Architects? -> SREs are like the next step after SysAdmins. A SysAdmin might manually install servers, replace disks, or use simple scripts for automation, while SREs use infrastructure as code and focus on reliability through SLIs, SLOs, and automation. DevOps isn’t really a job-it’s more of a way of working, where developers are involved in operations tasks like setting up CI/CD pipelines or on-call shifts. Architects focus on designing systems and infrastructures, such as load balancers or distributed systems, working alongside SREs to ensure the systems meet the reliability and scalability requirements. The specific responsibilities of each role depend on the company, and there is often overlap. +> SREs are like the next step after SysAdmins. A SysAdmin might manually install servers, replace disks, or use simple scripts for automation, while SREs use infrastructure as code and focus on reliability through SLIs, SLOs, and automation. DevOps isn’t really a job-it’s more of a way of working, where developers are involved in operations tasks like setting up CI/CD pipelines or on-call shifts. Architects focus on designing systems and infrastructures, such as load balancers or distributed systems, working alongside SREs to ensure the systems meet the reliability and scalability requirements. The specific responsibilities of each role depend on the company, and there is often overlap. What are the most important reliability lessons you’ve learned so far? @@ -67,11 +67,11 @@ Runbooks sound very practical. Can you explain how they’re used day-to-day? When should you decide to put something into a runbook, and when is it unnecessary? -> If an issue happens frequently, it should be documented in a runbook so that anyone, even someone new, can follow the steps to fix it. The idea is that 90% of the common incidents should be covered. For example, if a service is down, the runbook would specify where to find logs, which commands to check, and what actions to take. On the other hand, rare or complex issues, where the resolution depends heavily on context or varies each time, don’t make sense to include in detail. For those, it’s better to focus on general troubleshooting steps. +> If an issue happens frequently, it should be documented in a runbook so that anyone, even someone new, can follow the steps to fix it. The idea is that 90% of the common incidents should be covered. For example, if a service is down, the runbook would specify where to find logs, which commands to check, and what actions to take. On the other hand, rare or complex issues, where the resolution depends heavily on context or varies each time, don’t make sense to include in detail. For those, it’s better to focus on general troubleshooting steps. How do you search for and find the correct runbooks? -> Runbooks should be linked directly in the alert you receive. For example, if you get an alert about a service not running, the alert will have a link to the runbook that tells you what to check, like logs or commands to run. Runbooks are best stored in an internal wiki, so if you don’t find the link in the alert, you know where to search. The important thing is that runbooks are easy to find and up to date because that’s what makes them useful during incidents. +> Runbooks should be linked directly in the alert you receive. For example, if you get an alert about a service not running, the alert will have a link to the runbook that tells you what to check, like logs or commands to run. Runbooks are best stored in an internal wiki, so if you don’t find the link in the alert, you know where to search. The important thing is that runbooks are easy to find and up to date because that’s what makes them useful during incidents. Do you have an interesting war story you can share with us? diff --git a/gemfeed/2025-04-05-f3s-kubernetes-with-freebsd-part-4.gmi.tpl b/gemfeed/2025-04-05-f3s-kubernetes-with-freebsd-part-4.gmi.tpl index c807b51c..00ac2292 100644 --- a/gemfeed/2025-04-05-f3s-kubernetes-with-freebsd-part-4.gmi.tpl +++ b/gemfeed/2025-04-05-f3s-kubernetes-with-freebsd-part-4.gmi.tpl @@ -245,7 +245,7 @@ Whereas: ### Permitting root login -As these VMs aren't directly reachable via SSH from the internet, we enable `root` login by adding a line with `PermitRootLogin yes` to `/etc/sshd/sshd_config`. +As these VMs aren't directly reachable via SSH from the internet, we enable `root` login by adding a line with `PermitRootLogin yes` to `/etc/sshd/sshd_config`. Once done, we reboot the VM by running `reboot` inside the VM to test whether everything was configured and persisted correctly. diff --git a/gemfeed/2025-04-19-when-book-notes.gmi.tpl b/gemfeed/2025-04-19-when-book-notes.gmi.tpl index bfb199ec..6c7f73de 100644 --- a/gemfeed/2025-04-19-when-book-notes.gmi.tpl +++ b/gemfeed/2025-04-19-when-book-notes.gmi.tpl @@ -67,9 +67,9 @@ Short naps (10-20 minutes) significantly enhance mood, alertness, and cognitive ## Final Impressions -- The concluding experience of a vacation significantly influences overall memories. -- Restaurant reviews often hinge on the end of the visit, highlighting extras like wrong bills or additional desserts. -- Considering one's older future self can motivate improvements in the present. +* The concluding experience of a vacation significantly influences overall memories. +* Restaurant reviews often hinge on the end of the visit, highlighting extras like wrong bills or additional desserts. +* Considering one's older future self can motivate improvements in the present. ## The Midlife U Curve diff --git a/gemfeed/2025-05-02-terminal-multiplexing-with-tmux-fish-edition.gmi.tpl b/gemfeed/2025-05-02-terminal-multiplexing-with-tmux-fish-edition.gmi.tpl index 270f096a..41e19c57 100644 --- a/gemfeed/2025-05-02-terminal-multiplexing-with-tmux-fish-edition.gmi.tpl +++ b/gemfeed/2025-05-02-terminal-multiplexing-with-tmux-fish-edition.gmi.tpl @@ -39,7 +39,7 @@ I can also recommend this book (this is the book I got started with with Tmux): => https://pragprog.com/titles/bhtmux2/tmux-2/ -Over the years, I have built a couple of shell helper functions to optimize my workflows. Tmux is extensively integrated into my daily workflows (personal and work). I had colleagues asking me about my Tmux config and helper scripts for Tmux several times. It would be neat to blog about it so that everyone interested in it can make a copy of my configuration and scripts. +Over the years, I have built a couple of shell helper functions to optimize my workflows. Tmux is extensively integrated into my daily workflows (personal and work). I had colleagues asking me about my Tmux config and helper scripts for Tmux several times. It would be neat to blog about it so that everyone interested in it can make a copy of my configuration and scripts. The configuration and scripts in this blog post are only the non-work-specific parts. There are more helper scripts, which I only use for work (and aren't really useful outside of work due to the way servers and clusters are structured there). @@ -181,7 +181,7 @@ Before I used Tmux, I was a heavy user of ClusterSSH, which allowed me to log in However, since I started using Tmux, I retired ClusterSSH, as it came with the benefit that Tmux only needs to be run in the terminal, whereas ClusterSSH spawned terminal windows, which aren't easily portable (e.g., from a Linux desktop to macOS). The `tmux::cluster_ssh` function can have N arguments, where: * ...the first argument will be the session name (see `tmux::tssh_from_argument` helper function), and all remaining arguments will be server hostnames/FQDNs to connect to simultaneously. -* ...or, the first argument is a file name, and the file contains a list of hostnames/FQDNs (see `tmux::ssh_from_file` helper function) +* ...or, the first argument is a file name, and the file contains a list of hostnames/FQDNs (see `tmux::ssh_from_file` helper function) This is the function definition behind the `tssh` alias: @@ -277,7 +277,7 @@ I often search the history backwards with `prefix-key [` followed by a `?`, whic Once I have identified the terminal text to be copied, I enter visual select mode with `v`, highlight all the text to be copied (using arrow keys or Vi motions), and press `y` to yank it (sorry if this all sounds a bit complicated, but Vim/NeoVim users will know this, as it is pretty much how you do it there as well). -For `v` and `y` to work, the following has to be added to the Tmux configuration file: +For `v` and `y` to work, the following has to be added to the Tmux configuration file: ``` bind-key -T copy-mode-vi 'v' send -X begin-selection diff --git a/gemfeed/2025-06-07-a-monks-guide-to-happiness-book-notes.gmi.tpl b/gemfeed/2025-06-07-a-monks-guide-to-happiness-book-notes.gmi.tpl index 22095051..1d7f13ee 100644 --- a/gemfeed/2025-06-07-a-monks-guide-to-happiness-book-notes.gmi.tpl +++ b/gemfeed/2025-06-07-a-monks-guide-to-happiness-book-notes.gmi.tpl @@ -49,20 +49,20 @@ These are my personal book notes from Gelong Thubten's "A Monk's Guide to Happin ## Reflective Questions -* Why do I do all the things I do? What do I try to achieve? -* What am I doing about that? -* Is it working? -* What are the real causes of happiness and suffering? -* What about meditation? How does that address the situation? +* Why do I do all the things I do? What do I try to achieve? +* What am I doing about that? +* Is it working? +* What are the real causes of happiness and suffering? +* What about meditation? How does that address the situation? ## Miscellaneous Guidelines -* Posture is important as the mind and body are connected. -* Don't use music, so you don't rely on music to change your state of mind. Similar regular guided meditation. Guided meditation is good for learning a technique, but you should not rely on another voice. -* You are not trying to relax. Relaxing and trying are two different things. -* When you love everything, even the bad things happening to you, then you are invincible. -* Happiness is all in your mind. As if you flip a switch there. -* Digging for answers will never end. It will always cause more material to dig. +* Posture is important as the mind and body are connected. +* Don't use music, so you don't rely on music to change your state of mind. Similar regular guided meditation. Guided meditation is good for learning a technique, but you should not rely on another voice. +* You are not trying to relax. Relaxing and trying are two different things. +* When you love everything, even the bad things happening to you, then you are invincible. +* Happiness is all in your mind. As if you flip a switch there. +* Digging for answers will never end. It will always cause more material to dig. If happiness is a mental issue. Clearly, the best time is spent training your mind in your free time and don't always be busy with other things. E.g. meditation, or think about the benefits of meditation. All that we do in our free time is search for happiness. Are the things we do actually working? There is always something around the corner... diff --git a/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.gmi.tpl b/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.gmi.tpl index 6e20e5b8..96ba9ac6 100644 --- a/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.gmi.tpl +++ b/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.gmi.tpl @@ -801,7 +801,7 @@ Key benefits for our storage system: First, we add the CARP configuration to `/etc/rc.conf` on both `f0` and `f1`: -> Update: Sun 4 Jan 00:17:00 EET 2026 - Added `advskew 100` to f1 so f0 always wins CARP elections when it comes back online after a reboot. +> Update: Sun 4 Jan 00:17:00 EET 2026 - Added `advskew 100` to f1 so f0 always wins CARP elections when it comes back online after a reboot. ```sh # On f0 - The virtual IP 192.168.1.138 will float between f0 and f1 @@ -848,7 +848,7 @@ paul@f0:~ % doas service devd restart Next, we create the CARP control script that will restart stunnel when the CARP state changes: -> Update: Fixed the script at Sat 3 Jan 23:55:11 EET 2026 - changed `$1` to `$2` because devd passes `$subsystem $type`, so the state is in the second argument. +> Update: Fixed the script at Sat 3 Jan 23:55:11 EET 2026 - changed `$1` to `$2` because devd passes `$subsystem $type`, so the state is in the second argument. ```sh paul@f0:~ % doas tee /usr/local/bin/carpcontrol.sh <<'EOF' @@ -1143,7 +1143,7 @@ This ensures that clients always connect to the active NFS server through the CA This approach ensures clients can only connect to the active server, eliminating stale handles from the inactive server: -> Update: Fixed the script at Sat 3 Jan 23:55:11 EET 2026 - changed `$1` to `$2` because devd passes `$subsystem $type`, so the state is in the second argument. +> Update: Fixed the script at Sat 3 Jan 23:55:11 EET 2026 - changed `$1` to `$2` because devd passes `$subsystem $type`, so the state is in the second argument. ```sh # Create CARP control script on both f0 and f1 @@ -1340,7 +1340,7 @@ Auto-failback ENABLED (removed /data/nfs/nfs.NO_AUTO_FAILBACK) When `f0` reboots (planned or unplanned), `f1` takes over as CARP MASTER. To ensure `f0` automatically reclaims its primary role once it's fully operational, we'll implement an automatic failback mechanism. With: -> Update: Fixed the script at Sun 4 Jan 00:04:28 EET 2026 - removed the NFS service check because when f0 is BACKUP, NFS services are intentionally stopped by carpcontrol.sh, which would prevent auto-failback from ever triggering. +> Update: Fixed the script at Sun 4 Jan 00:04:28 EET 2026 - removed the NFS service check because when f0 is BACKUP, NFS services are intentionally stopped by carpcontrol.sh, which would prevent auto-failback from ever triggering. ```sh paul@f0:~ % doas tee /usr/local/bin/carp-auto-failback.sh <<'EOF' diff --git a/gemfeed/2025-10-02-f3s-kubernetes-with-freebsd-part-7.gmi.tpl b/gemfeed/2025-10-02-f3s-kubernetes-with-freebsd-part-7.gmi.tpl index 1df85de3..d216ce0c 100644 --- a/gemfeed/2025-10-02-f3s-kubernetes-with-freebsd-part-7.gmi.tpl +++ b/gemfeed/2025-10-02-f3s-kubernetes-with-freebsd-part-7.gmi.tpl @@ -30,9 +30,9 @@ $ cd f3s/ ``` **Current master branch** contains the ArgoCD-managed versions with: -- Application manifests organized under `argocd-apps/{monitoring,services,infra,test}/` -- Additional resources under `*/manifests/` directories (e.g., `prometheus/manifests/`) -- Justfiles updated to trigger ArgoCD syncs instead of direct Helm commands +* Application manifests organized under `argocd-apps/{monitoring,services,infra,test}/` +* Additional resources under `*/manifests/` directories (e.g., `prometheus/manifests/`) +* Justfiles updated to trigger ArgoCD syncs instead of direct Helm commands The deployment concepts and architecture remain the same—only the deployment method changed from imperative (`helm install/upgrade`) to declarative (GitOps with ArgoCD). @@ -999,7 +999,7 @@ The same pattern can be applied to any service. To add LAN access: 1. Copy the `f3s-lan-tls` secret to the service's namespace (if not already there) 2. Add a LAN Ingress resource using the pattern above -3. Configure DNS: `192.168.1.138 service.f3s.lan.foo.zone` +3. Configure DNS: `192.168.1.138 service.f3s.lan.foo.zone` No changes needed to: diff --git a/gemfeed/2025-12-07-f3s-kubernetes-with-freebsd-part-8.gmi.tpl b/gemfeed/2025-12-07-f3s-kubernetes-with-freebsd-part-8.gmi.tpl index 008c512e..da66ed0a 100644 --- a/gemfeed/2025-12-07-f3s-kubernetes-with-freebsd-part-8.gmi.tpl +++ b/gemfeed/2025-12-07-f3s-kubernetes-with-freebsd-part-8.gmi.tpl @@ -39,9 +39,9 @@ $ cd f3s/prometheus/ ``` **Current master branch** contains the ArgoCD-managed versions with: -- Application manifests organized under `argocd-apps/{monitoring,services,infra,test}/` -- Resources organized under `prometheus/manifests/`, `loki/`, etc. -- Justfiles updated to trigger ArgoCD syncs instead of direct Helm commands +* Application manifests organized under `argocd-apps/{monitoring,services,infra,test}/` +* Resources organized under `prometheus/manifests/`, `loki/`, etc. +* Justfiles updated to trigger ArgoCD syncs instead of direct Helm commands The deployment concepts and architecture remain the same—only the deployment method changed from imperative (`helm install/upgrade`) to declarative (GitOps with ArgoCD). diff --git a/gemfeed/2026-01-01-posts-from-july-to-december-2025.gmi.tpl b/gemfeed/2026-01-01-posts-from-july-to-december-2025.gmi.tpl index 53588bfb..08c5c805 100644 --- a/gemfeed/2026-01-01-posts-from-july-to-december-2025.gmi.tpl +++ b/gemfeed/2026-01-01-posts-from-july-to-december-2025.gmi.tpl @@ -226,7 +226,7 @@ I learned a lot from this `#OpenBSD` `#relayd` talk, and I already put the infor => https://www.youtube.com/watch?v=yW8QSZyEs6E www.youtube.com/watch?v=yW8QSZyEs6E -### Six weeks of claude code +### Six weeks of claude code => https://blog.puzzmo.com/posts/2025/07/30/six-weeks-of-claude-code/ blog.puzzmo.com/posts/2025/07/30/six-weeks-of-claude-code/ diff --git a/gemfeed/2026-01-01-using-supernote-nomad-offline.gmi.tpl b/gemfeed/2026-01-01-using-supernote-nomad-offline.gmi.tpl index a3d2c224..193eba01 100644 --- a/gemfeed/2026-01-01-using-supernote-nomad-offline.gmi.tpl +++ b/gemfeed/2026-01-01-using-supernote-nomad-offline.gmi.tpl @@ -32,7 +32,7 @@ I initially bought it because Retta (the manufacturer of the Supernote) stated o In a world of constant connectivity, the Supernote Nomad offers a sanctuary. By keeping it offline, I can focus on my thoughts and notes without compromise of my privacy. -One of the most significant advantages of keeping Wi-Fi off is the battery life. The Supernote Nomad can last a week, on a single charge when it's not constantly searching for a network. This makes it a good companion for long trips or intense note-taking sessions. +One of the most significant advantages of keeping Wi-Fi off is the battery life. The Supernote Nomad can last a week, on a single charge when it's not constantly searching for a network. This makes it a good companion for long trips or intense note-taking sessions. Privacy was my main concern. By not syncing my notes to Retta's cloud service, I retain full ownership and control over my data. There's no risk of my personal thoughts and ideas being accessed or mined by third parties. It's a simple and effective way to ensure my privacy. diff --git a/gemfeed/DRAFT-distributed-systems-simulator.gmi.tpl b/gemfeed/DRAFT-distributed-systems-simulator.gmi.tpl index 0464f3ab..701dfee3 100644 --- a/gemfeed/DRAFT-distributed-systems-simulator.gmi.tpl +++ b/gemfeed/DRAFT-distributed-systems-simulator.gmi.tpl @@ -123,7 +123,7 @@ The toolbar offers four different functions: ![Figure 2.4: The menu line including toolbar] * Reset simulation: can only be activated when the simulation has been paused or has finished -* Repeat simulation: cannot be activated if the simulation has not yet been started +* Repeat simulation: cannot be activated if the simulation has not yet been started * Pause simulation: can only be activated when the simulation is currently running * Start simulation: can only be activated when the simulation is not currently running and has not yet finished @@ -232,7 +232,7 @@ Two main types of events are distinguished: programmable events and non-programm * Local Eventsi: Triggered when a specific local time of the associated process is reached * Global Eventsi: (Expert Mode only): Triggered when a specific global simulation time is reached -* Event Programmingi: Users can add events by: Right-clicking on a process bar and selecting "Insert local event", using the event editor in the sidebar or by sssssssssssthe event time and type +* Event Programmingi: Users can add events by: Right-clicking on a process bar and selecting "Insert local event", using the event editor in the sidebar or by sssssssssssthe event time and type ### Event Types Available: diff --git a/gemfeed/DRAFT-f3s-kubernetes-with-freebsd-part-8b.gmi.tpl b/gemfeed/DRAFT-f3s-kubernetes-with-freebsd-part-8b.gmi.tpl index 51de7d0c..01d851e5 100644 --- a/gemfeed/DRAFT-f3s-kubernetes-with-freebsd-part-8b.gmi.tpl +++ b/gemfeed/DRAFT-f3s-kubernetes-with-freebsd-part-8b.gmi.tpl @@ -20,9 +20,9 @@ $ cd f3s/prometheus/ ``` **Current master branch** uses ArgoCD with: -- Application manifest: `argocd-apps/monitoring/prometheus.yaml` -- Multi-source Application combining upstream chart + custom manifests -- Justfile commands updated to trigger ArgoCD syncs instead of direct Helm commands +* Application manifest: `argocd-apps/monitoring/prometheus.yaml` +* Multi-source Application combining upstream chart + custom manifests +* Justfile commands updated to trigger ArgoCD syncs instead of direct Helm commands The etcd configuration concepts remain the same—only the deployment method changed. Instead of running `just upgrade`, you would: 1. Update the configuration in Git |
