From 7bdf2109a5f94d6ae9ada46787672108b1520fad Mon Sep 17 00:00:00 2001 From: amanita Date: Fri, 27 Oct 2023 18:04:23 +0200 Subject: [PATCH 01/10] add pagecontent to how-to to allow some pretext --- templates/how-to.html | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/templates/how-to.html b/templates/how-to.html index 3544210..744a929 100755 --- a/templates/how-to.html +++ b/templates/how-to.html @@ -1,10 +1,7 @@ -{% extends "index.html" %} - -{% block title %} - {{ page.title }} - {{ config.title }} -{% endblock title %} +{% extends "page.html" %} {% block content %} +{{ page.content | safe }} {% set anleitungen = get_section(path="how-to/_index.md") %} {% for page in anleitungen.pages %}
  • From c3fe78040b110ad8dd429975af15aa42386f14ec Mon Sep 17 00:00:00 2001 From: amanita Date: Fri, 27 Oct 2023 18:07:41 +0200 Subject: [PATCH 02/10] add a little blog. css still missing :D --- content/blog.md | 6 ++++++ content/blogposts/_index.md | 3 +++ content/blogposts/buchhaltung.md | 16 ++++++++++++++++ content/blogposts/hello_world.md | 9 +++++++++ templates/blog.html | 18 ++++++++++++++++++ 5 files changed, 52 insertions(+) create mode 100644 content/blog.md create mode 100644 content/blogposts/_index.md create mode 100644 content/blogposts/buchhaltung.md create mode 100644 content/blogposts/hello_world.md create mode 100755 templates/blog.html diff --git a/content/blog.md b/content/blog.md new file mode 100644 index 0000000..c9b9c50 --- /dev/null +++ b/content/blog.md @@ -0,0 +1,6 @@ ++++ +title = "Was geht?" +weight = 9 +template = "blog.html" ++++ +# Die neusten Neuigkeiten diff --git a/content/blogposts/_index.md b/content/blogposts/_index.md new file mode 100644 index 0000000..bd38c11 --- /dev/null +++ b/content/blogposts/_index.md @@ -0,0 +1,3 @@ ++++ +title = "Neuigkeiten" ++++ diff --git a/content/blogposts/buchhaltung.md b/content/blogposts/buchhaltung.md new file mode 100644 index 0000000..cc069d0 --- /dev/null +++ b/content/blogposts/buchhaltung.md @@ -0,0 +1,16 @@ ++++ +title = "Überarbeitung unserer Buchhaltung" +date = "2023-03-01" ++++ +Wir sind gerade dabei eine neue Buchhaltungsperson einzuarbeiten. +In diesem Zuge ändern und verbessern wir unsere bisherige Buchhaltung. + +**Wundert euch also nicht, wenn ihr:** +* Rechnungen bekommt +* Rechnungen mehrfach bekommt + +Sollten Zahlungen ausstehen, werden wir euch nochmal explizit daran erinnern. + +Liebe Grüße + +Euer Reudnetz. diff --git a/content/blogposts/hello_world.md b/content/blogposts/hello_world.md new file mode 100644 index 0000000..72c002b --- /dev/null +++ b/content/blogposts/hello_world.md @@ -0,0 +1,9 @@ ++++ +title = "Einen Blog für die Webseite" +date = "2023-10-27" ++++ +Immer mehr machen sich Wunsch und Notwendigkeit breit, auch mal etwas aktuelles über die Webseite zu verbreiten. +Nun soll hier Platz sein, für Geschichten und Einblicke in unsere Arbeit, Störungsmeldungen und Ausfalls-Forensik +oder auch einfach ein Paar nette Worte über Dinge die uns beschäftigen. + +Viel Vergnügen damit. diff --git a/templates/blog.html b/templates/blog.html new file mode 100755 index 0000000..648673c --- /dev/null +++ b/templates/blog.html @@ -0,0 +1,18 @@ +{% extends "page.html" %} + +{% block content %} +{{ page.content | safe }} +{% set posts = get_section(path="blogposts/_index.md") %} + +{% for post in posts.pages %} +

    {{ post.title }}

    +

    {{ post.date }}

    +
    +{% if post.summary %} +{{ post.summary | safe }} +{% else %} +{{ post.content | safe }} +{% endif %} +
    +{% endfor %} +{% endblock content %} From f049281f734ac175bb339b4a5befce34af925f3b Mon Sep 17 00:00:00 2001 From: Carl Suckfuell Date: Sat, 28 Oct 2023 13:27:11 +0200 Subject: [PATCH 03/10] add some css elements to the blog template --- templates/blog.html | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/templates/blog.html b/templates/blog.html index 648673c..ff01e15 100755 --- a/templates/blog.html +++ b/templates/blog.html @@ -1,18 +1,20 @@ {% extends "page.html" %} {% block content %} -{{ page.content | safe }} -{% set posts = get_section(path="blogposts/_index.md") %} - -{% for post in posts.pages %} -

    {{ post.title }}

    -

    {{ post.date }}

    -
    -{% if post.summary %} -{{ post.summary | safe }} -{% else %} -{{ post.content | safe }} -{% endif %} -
    -{% endfor %} + {{ page.content | safe }} + {% set posts = get_section(path="blogposts/_index.md") %} + + {% for post in posts.pages %} +

    {{ post.title }}

    +

    {{ post.date }}

    +
    + {% if post.summary %} + {{ post.summary | safe }} + {% else %} + {{ post.content | safe }} + {% endif %} +
    +
    + {% endfor %} {% endblock content %} From 113a1be0cc9d68726daffcbe76dbbfb0e06dc762 Mon Sep 17 00:00:00 2001 From: Carl Suckfuell Date: Sat, 28 Oct 2023 13:36:08 +0200 Subject: [PATCH 04/10] stretch background; maybe looks better? --- static/style/styles.css | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/static/style/styles.css b/static/style/styles.css index 7341d25..c5c2210 100755 --- a/static/style/styles.css +++ b/static/style/styles.css @@ -61,7 +61,7 @@ body { background-image:url(linien1.svg); background-repeat:no-repeat; - background-size:contain; + background-size:100% auto; background-position:center; background-attachment:fixed; background-color:#3F3836; From c41c8b7e7fcca49be57fec5ee572a96fd287c3b6 Mon Sep 17 00:00:00 2001 From: Carl Suckfuell Date: Sun, 29 Oct 2023 15:27:24 +0100 Subject: [PATCH 05/10] remove jobs tab, since it does not start with w --- content/jobs.md | 10 ---------- 1 file changed, 10 deletions(-) delete mode 100644 content/jobs.md diff --git a/content/jobs.md b/content/jobs.md deleted file mode 100644 index 47dc15d..0000000 --- a/content/jobs.md +++ /dev/null @@ -1,10 +0,0 @@ -+++ -title = "Jobs" -weight = 9 -+++ - -# Jobausschreibungen des Reudnetzes -Aktuell haben wir keine konkreten Stellen anzubieten. - -Falls du trotzdem eine Initiale Bewerbung schreiben möchstest: -Schick Deine Bewerbung mit den üblichen Unterlagen an mail reudnetz org From 75a0a5440aff66dff462806868912a606c81555e Mon Sep 17 00:00:00 2001 From: amanita Date: Sat, 18 Nov 2023 15:59:32 +0100 Subject: [PATCH 06/10] add sorting by date for blog --- content/blogposts/_index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/content/blogposts/_index.md b/content/blogposts/_index.md index bd38c11..2bceea2 100644 --- a/content/blogposts/_index.md +++ b/content/blogposts/_index.md @@ -1,3 +1,4 @@ +++ title = "Neuigkeiten" +sort_by = "date" +++ From e1ed95e4a1433c5f628e6e3a62863a655c9fe889 Mon Sep 17 00:00:00 2001 From: amanita Date: Sat, 18 Nov 2023 20:28:58 +0100 Subject: [PATCH 07/10] add a blogpost about transparency and protocols --- content/blogposts/2023-11-18-protokolle.md | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 content/blogposts/2023-11-18-protokolle.md diff --git a/content/blogposts/2023-11-18-protokolle.md b/content/blogposts/2023-11-18-protokolle.md new file mode 100644 index 0000000..830cb87 --- /dev/null +++ b/content/blogposts/2023-11-18-protokolle.md @@ -0,0 +1,21 @@ ++++ +title = "Geheime Interna #1" +date = "2023-11-18" ++++ +Die meisten Entscheidungen trifft das Reudnetz in einem mehr oder weniger unorgansierten Plenum. +Seit je her, beziehungsweise seit dem wir angefangen haben mitzuschreiben, was wir beschließen, veröffentlichen wir +die Protokolle, welche dabei entstehen. +Aus Bequemlichkeit landete bisher alles in einem [Ordner im Git.](https://git.reudnetz.org/reudnetz/public-wiki/src/branch/master/menschenzeugs/protokolle). Dort kann es öffentlich eingesehen werden und wird sogar manchmal gelesen. + +Nun beschäftigt uns allerdings die Frage, ob wir diese Praxis beibehalten wollen. +Denn es gilt: "the internet never forgets" – was einmal veröffentlicht ist, emazipiert sich von uns wird in caches und backups weiterleben, selbst wenn wir einmal entscheiden sollten die Quelle bei uns zu löschen oder zu verändern. +Da wir auch Details zu neuen und alten Anschlüssen besprechen, müssen wir aufpassen, wie wir die Dinge aufschreiben, +um nicht datenschutzrelevante Informationen zu veröffentlichen. +Besonders dieses Risiko nährt die Frage nach den Sinnhaftigkeit dieser kompletten Offenheit. + +Gleichzeitig ist uns klar, was für ein starkes Bekenntnis an Transparenz es darstellt, die Ergebnisse unserer Treffen öffenlich zu halten. +Aus dem Unstand, das wir öffentliche Infrastruktur betreiben, lässt sich unter Umständen sogar ein Anspruch für diese Offenheit ableiten: Öffentliche Infrastruktur muss auch öffentlich verwaltet werden. + +Aber auch die Frage nach dem Nutzen der Protokolle ist nicht abschließend beantwortet. Die Argumentation, das die Protokolle für Auszenstehende wenig informativ sind, da sie oft wenig ausführlich sind, trifft durchaus zu. Zu unserer Überraschung scheinen diese Protokolle aber doch gelegentlich von Menschen gelesen zu werden, die sich für das Reudnetz Interessieren. +Besser könnten Blogposts wie dieser sein, die ausführlicher über Themen berichten, die uns gerade Beschäftigen. +Sie zu schreiben ist aber aufwendig und deckt stets nur einen Teil unserer Arbeit ab. From 38300978c6da7355a2c30e5dc672a76d97df231c Mon Sep 17 00:00:00 2001 From: carl Date: Thu, 30 Nov 2023 12:44:14 +0100 Subject: [PATCH 08/10] add new knowledge about kaese-hack-lauchsuppe --- .../how-to/vegane-kaese-hack-lauch-suppe.md | 48 +++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 content/how-to/vegane-kaese-hack-lauch-suppe.md diff --git a/content/how-to/vegane-kaese-hack-lauch-suppe.md b/content/how-to/vegane-kaese-hack-lauch-suppe.md new file mode 100644 index 0000000..3501ddf --- /dev/null +++ b/content/how-to/vegane-kaese-hack-lauch-suppe.md @@ -0,0 +1,48 @@ ++++ +title = "Vegane Käse-Hack-Lauchsuppe" ++++ +# Vegane Käse-Hack-Lauchsuppe +Falls das mit dem Internet mal wieder alles nervt, ist es eine gute Idee etwas zu kochen. + +## Das Rezept +Genau wie bei der [Anleitung zum Einrichten von Openwrt](@/how-to/openwrt-router.md) ist ein Rezept ein Modell der +Realität und entspricht normalerweise nicht dem was wirklich ist. +Es sollte stets als Wegweiser durch den Möglichkeitsraum verstanden werden. + +### Zutaten +||| +| ---: | --- +| 3 Stangen | Lauch +| 300g | Sojagranulat +| 1L | Soja/Hafersahne +| 3 | Zwiebeln +| 6 Zehen | Knoblauch +| 6EL | Hefeflocken +|1 Bund | Petersilie +| | Genüsebrühe +| | Sojasauce +| | Öl +| | Salz +| | Pfeffer +| | Kümmel +| | Edelsüßes Paprika + +### Umsetzung +Lauch und Zwiebeln kleinschneiden. +Zwiebeln in **reichlich Öl** anbraten, denn wie häufig bei veganem Essen, enthält hier nichts Fett außer dem Öl. Sojagranulat dazugeben auch kurz anbraten. +Hefeflocken dazu und ebenfalls kurz mitbraten. Lauch dazu und nach kurzer Zeit mit Soja/Hafergetränk ablöschen. + +Mindestens 10min köcheln lassen. + +Währenddessen Knoblauch und Petersilie zerkleinern. +Die Petersilie dient später als Garnitur, der Knoblauch kann sofort in die Suppe. +Abschmecken mit Sojasauce, Hefeflocken, Gemüsebrühe und den Gewürzen. +Servieren mit der Petersilie. + +Have fun. + +### Anmerkungen + +- Soja/Hafersahne ist teuer und kann auch durch entsprechende Pflanzenmilch und Stärke ersetzt werden. #kuefastyle + +- Soja enthält Sojalecithin, Sonneblumenöl enthält auch Sonnenblumenlecithine. Beides kann dabei helfen, das sich Öl und Wasser besser vermischen lassen. Um mehr Fett schön in der Suppe unterzubringen, kann es sich lohnen, beides zu verwenden. From 615b9a40f899d00e223b277bc1eab373d6e86b59 Mon Sep 17 00:00:00 2001 From: carl Date: Thu, 30 Nov 2023 12:54:03 +0100 Subject: [PATCH 09/10] remove windows crlf from style.css and add root em to fix footsize in nested environments --- static/style/styles.css | 441 ++++++++++++++++++++-------------------- 1 file changed, 221 insertions(+), 220 deletions(-) diff --git a/static/style/styles.css b/static/style/styles.css index c5c2210..2fd1d1c 100755 --- a/static/style/styles.css +++ b/static/style/styles.css @@ -1,220 +1,221 @@ -/* - * Web Fonts from fontspring.com - * - * All OpenType features and all extended glyphs have been removed. - * Fully installable fonts can be purchased at http://www.fontspring.com - * - * The fonts included in this stylesheet are subject to the End User License you purchased - * from Fontspring. The fonts are protected under domestic and international trademark and - * copyright law. You are prohibited from modifying, reverse engineering, duplicating, or - * distributing this font software. - * - * (c) 2010-2015 Fontspring - * - * - * - * - * The fonts included are copyrighted by the vendor listed below. - * - * Vendor: Fontfabric - * License URL: http://www.fontspring.com/licenses/fontfabric/webfont - * - * - */ - -@font-face { - font-family: 'intro_rust_gbase_2_line'; - src: url('introrustg-base2line-webfont.eot'); - src: url('introrustg-base2line-webfont.eot?#iefix') format('embedded-opentype'), - url('introrustg-base2line-webfont.woff2') format('woff2'), - url('introrustg-base2line-webfont.woff') format('woff'), - url('introrustg-base2line-webfont.ttf') format('truetype'), - url('introrustg-base2line-webfont.svg#intro_rust_gbase_2_line') format('svg'); - font-weight: normal; - font-style: normal; -} - -@font-face { - font-family: 'intro_script_rh2_base'; - src: url('introscriptr-h2base-webfont.eot'); - src: url('introscriptr-h2base-webfont.eot?#iefix') format('embedded-opentype'), - url('introscriptr-h2base-webfont.woff2') format('woff2'), - url('introscriptr-h2base-webfont.woff') format('woff'), - url('introscriptr-h2base-webfont.ttf') format('truetype'), - url('introscriptr-h2base-webfont.svg#intro_script_rh2_base') format('svg'); - font-weight: normal; - font-style: normal; -} - -@font-face { - font-family: 'intro_head_rbase'; - src: url('introheadr-base-webfont.eot'); - src: url('introheadr-base-webfont.eot?#iefix') format('embedded-opentype'), - url('introheadr-base-webfont.woff2') format('woff2'), - url('introheadr-base-webfont.woff') format('woff'), - url('introheadr-base-webfont.ttf') format('truetype'), - url('introheadr-base-webfont.svg#intro_head_rbase') format('svg'); - font-weight: normal; - font-style: normal; -} - -body { - background-image:url(linien1.svg); - background-repeat:no-repeat; - background-size:100% auto; - background-position:center; - background-attachment:fixed; - background-color:#3F3836; - color:#fff; -} - -a:link, a:visited { - color:#fff; -} - -a:hover, a:active, -a:visited:hover, a:visited:active { - background-color:#000; -} - -.legal { - text-align:right; - font-size:0.8em; - text-transform:uppercase; - font-family:'intro_head_rbase',sans-serif; - letter-spacing:1px; -} - -.legal a:link, .legal a:visited, -.nav a:link, .nav a:visited { - text-decoration:none; -} - -.head h1 { - font-family:'intro_rust_gbase_2_line',sans-serif; - font-weight:normal; - font-size:5em; - margin:0; -} - -.head h2 { - font-family:'intro_script_rh2_base',sans-serif; - font-weight:normal; - font-size:2.5em; - padding-top:1.1em; - text-align:right; - margin:0; -} - -.nav ul, .nav ul li { - margin:0; - padding:0; - list-style-type:none; - display:inline; -} - -.nav ul li a:link, .nav ul li a:visited { - display:block; - float:left; - background-color:#fff; - color:#3F3836; - width:10%; - margin-right:2%; - font-size:1.3em; - text-transform:uppercase; - font-family:'intro_head_rbase',sans-serif; -} - -.nav ul li.last a:link, .nav ul li.last a:visited { - margin-right:0; -} - -.nav ul li a:hover, .nav ul li a:visited:hover, -.nav ul li.current a:link, .nav ul li.current a:visited { - background-color:#000; - color:#fff; -} - -.content { - font-family:'intro_head_rbase',sans-serif; - margin-top:2em; -} - -.content h1 { - text-transform:uppercase; - margin-top:0; - font-weight:normal; - font-size:2em; -} - -.content p, .content li, .content td { - font-size:1.3em; -} - -.margin { - font-size:85%; -} - -.margin h3{ - background-color:#000; - padding:0.5em; - margin-top:0; -} - -.ifl { - float:left; - margin:0.5em 0.5em 0.5em 0; -} - -.ifr { - float:right; - margin:0.5em 0 0.5em 0.5em; -} - -.adress ul { - list-style-type:none; -} - -pre { - padding: 1em; - background-color: #008b8b70; - border-radius: 4px; - white-space: pre-wrap; -} - -p code { - vertical-align: baseline; - background-color: #008b8b70; - border-radius: 4px; - padding: 1px 4px; -} - -@media screen and (max-width:48em) { - -.legal { - text-align:center; - margin-top:1em; -} - -.head h1 { - font-size:2.5em; - text-align:center; - padding:0; -} - -.head h2 { - font-size:1.5em; - text-align:center; - padding:0; -} - -.nav ul li a:link, .nav ul li a:visited { - width:100%; - margin:0.2em 0; - text-align:center; -} - - - -} - +/* + * Web Fonts from fontspring.com + * + * All OpenType features and all extended glyphs have been removed. + * Fully installable fonts can be purchased at http://www.fontspring.com + * + * The fonts included in this stylesheet are subject to the End User License you purchased + * from Fontspring. The fonts are protected under domestic and international trademark and + * copyright law. You are prohibited from modifying, reverse engineering, duplicating, or + * distributing this font software. + * + * (c) 2010-2015 Fontspring + * + * + * + * + * The fonts included are copyrighted by the vendor listed below. + * + * Vendor: Fontfabric + * License URL: http://www.fontspring.com/licenses/fontfabric/webfont + * + * + */ + +@font-face { + font-family: 'intro_rust_gbase_2_line'; + src: url('introrustg-base2line-webfont.eot'); + src: url('introrustg-base2line-webfont.eot?#iefix') format('embedded-opentype'), + url('introrustg-base2line-webfont.woff2') format('woff2'), + url('introrustg-base2line-webfont.woff') format('woff'), + url('introrustg-base2line-webfont.ttf') format('truetype'), + url('introrustg-base2line-webfont.svg#intro_rust_gbase_2_line') format('svg'); + font-weight: normal; + font-style: normal; +} + +@font-face { + font-family: 'intro_script_rh2_base'; + src: url('introscriptr-h2base-webfont.eot'); + src: url('introscriptr-h2base-webfont.eot?#iefix') format('embedded-opentype'), + url('introscriptr-h2base-webfont.woff2') format('woff2'), + url('introscriptr-h2base-webfont.woff') format('woff'), + url('introscriptr-h2base-webfont.ttf') format('truetype'), + url('introscriptr-h2base-webfont.svg#intro_script_rh2_base') format('svg'); + font-weight: normal; + font-style: normal; +} + +@font-face { + font-family: 'intro_head_rbase'; + src: url('introheadr-base-webfont.eot'); + src: url('introheadr-base-webfont.eot?#iefix') format('embedded-opentype'), + url('introheadr-base-webfont.woff2') format('woff2'), + url('introheadr-base-webfont.woff') format('woff'), + url('introheadr-base-webfont.ttf') format('truetype'), + url('introheadr-base-webfont.svg#intro_head_rbase') format('svg'); + font-weight: normal; + font-style: normal; +} + +body { + background-image:url(linien1.svg); + background-repeat:no-repeat; + background-size:100% auto; + background-position:center; + background-attachment:fixed; + background-color:#3F3836; + color:#fff; +} + +a:link, a:visited { + color:#fff; +} + +a:hover, a:active, +a:visited:hover, a:visited:active { + background-color:#000; +} + +.legal { + text-align:right; + font-size:0.8em; + text-transform:uppercase; + font-family:'intro_head_rbase',sans-serif; + letter-spacing:1px; +} + +.legal a:link, .legal a:visited, +.nav a:link, .nav a:visited { + text-decoration:none; +} + +.head h1 { + font-family:'intro_rust_gbase_2_line',sans-serif; + font-weight:normal; + font-size:5em; + margin:0; +} + +.head h2 { + font-family:'intro_script_rh2_base',sans-serif; + font-weight:normal; + font-size:2.5em; + padding-top:1.1em; + text-align:right; + margin:0; +} + +.nav ul, .nav ul li { + margin:0; + padding:0; + list-style-type:none; + display:inline; +} + +.nav ul li a:link, .nav ul li a:visited { + display:block; + float:left; + background-color:#fff; + color:#3F3836; + width:10%; + margin-right:2%; + font-size:1.3em; + text-transform:uppercase; + font-family:'intro_head_rbase',sans-serif; +} + +.nav ul li.last a:link, .nav ul li.last a:visited { + margin-right:0; +} + +.nav ul li a:hover, .nav ul li a:visited:hover, +.nav ul li.current a:link, .nav ul li.current a:visited { + background-color:#000; + color:#fff; +} + +.content { + font-family:'intro_head_rbase',sans-serif; + margin-top:2em; +} + +.content h1 { + text-transform:uppercase; + margin-top:0; + font-weight:normal; + font-size:2em; +} + +.content p, .content li, .content td { + font-size:1.3rem; +} + + + +.margin { + font-size:85%; +} + +.margin h3{ + background-color:#000; + padding:0.5em; + margin-top:0; +} + +.ifl { + float:left; + margin:0.5em 0.5em 0.5em 0; +} + +.ifr { + float:right; + margin:0.5em 0 0.5em 0.5em; +} + +.adress ul { + list-style-type:none; +} + +pre { + padding: 1em; + background-color: #008b8b70; + border-radius: 4px; + white-space: pre-wrap; +} + +p code { + vertical-align: baseline; + background-color: #008b8b70; + border-radius: 4px; + padding: 1px 4px; +} + +@media screen and (max-width:48em) { + +.legal { + text-align:center; + margin-top:1em; +} + +.head h1 { + font-size:2.5em; + text-align:center; + padding:0; +} + +.head h2 { + font-size:1.5em; + text-align:center; + padding:0; +} + +.nav ul li a:link, .nav ul li a:visited { + width:100%; + margin:0.2em 0; + text-align:center; +} + + + +} From 5b10ecde65424eba81ec2fdc1c11c131a300a8e7 Mon Sep 17 00:00:00 2001 From: Gregor Michels Date: Wed, 7 Feb 2024 18:41:35 +0100 Subject: [PATCH 10/10] blog: add post for 2024.02.07 incident --- content/blogposts/2024-02-07-outage.md | 63 ++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 content/blogposts/2024-02-07-outage.md diff --git a/content/blogposts/2024-02-07-outage.md b/content/blogposts/2024-02-07-outage.md new file mode 100644 index 0000000..071ef41 --- /dev/null +++ b/content/blogposts/2024-02-07-outage.md @@ -0,0 +1,63 @@ ++++ +title = "Incident 07.02.2024" +date = "2024-02-07" ++++ + +In der Nacht von Dienstag auf Mittwoch (06.02.24 - 07.02.24) ist in der Wurzner Straße der Strom ausgefallen und hat uns eine ungeplante Downtime geschenkt. + +Unser Kernnetz, sowie die Kundenanschlusse, sind nach dem Stromausfall von selbst wieder hochgefahren. + +Allerdings mussten wir bei beiden Hosting-Servern manuell eingreifen und bis in die Mittagsstunden des Folgetages Entstörungen durchführen. + +--- + +## Verlauf + +* 2024.02.06 23:30 CET: Stromausfall + * gesamter Ausfall unserer Infrastruktur +* 2024.02.07 00:20 CET: Stromausfall beendet + * Kundenanschlüsse stehen wieder zur Verfügung +* 2024.02.07 11:00 CET: _hyper01_ und _sol_ unlocked + * _hyper01_: Kunden VMs wieder online + * _sol_: bootet ohne Netzwerkkonnektivität - Reverse-Proxies und interne VMs weiterhin offline +* 2024.02.07 14:30 CET: _sol_ entstört + * Reverse-Proxies und interne VMs wieder Verfügbar + +Seit 2024.02.07 14:30 CET ist das Reudnetz wieder uneingeschränkt online. + +--- + +## Entstörung _sol_ + +_sol_ ist nach dem Freischalten der `full-disk-encryption` ohne Netzwerkkonnektivität gebootet. +Eine fehlkonfigurierte Boot-Partiton hat einen veralteten Linux-Kernel gebootet für den das OS keine Kernel-Module mehr bereitgestellt hat. + +Durch die fehlenden Module konnte _sol_ seinen Netzwerk-Stack nicht konfigurieren da hierfür (unteranderem) das `bonding` Modul für 802.3ad (LACP) benötigt wird. + +_sol_ konnte über das IPMI entstört werden. + +Der Grund für die defekte Boot-Partiton war eine Wartung im Juni 2023. +Beim Austausch der HDDs in _sol_ gegen SSDs wurde die Bootpartition per `dd` kopiert. +Durch die gleichen FS/UU-IDs hat der Kernel das /boot auf der SSD gemountet, welches nicht in der Firmware als Boot-Device hinterlegt war. +Somit haben sich das Boot-Device und die eigentliche /boot-Partition immer weiter voneinander entfernt. + +## Full-Disk-Encryption + +Die Festplattenverschlüsselung von _hyper01_ und _sol_ musste manuell durch einen admin freigeschaltet werden. + +Das ist 11 Stunden nach Ende des Stromausfalls passiert. + +## PDU issues _hyper01_ + +Aufgrund von Netzteilproblemen ist _hyper01_ nicht automatisch gestartet. +Weder die Betätigung des `power-buttons`, noch das IPMI konnten den Server starten. + + +Aus Energieeffiziengründen wird _hyper01_ nur mit einem Netzteil betrieben. +Der Wechsel auf das Ersatznetzteil hat dem Server dann zum Starten verholfen. + +--- + +## Reflektion + +In den folgenden Pläna werden wir erarbeiten an welchen Stellen wir Verbessrungen erzielen können um diese Form von Ausfall zu verhindern.