Dirk Ollmetzer | Saturday, 22 September 2012 | Unterwegs
Diese Woche war ich mit den Kollegen und Kolleginnen auf Mallorca zu einem zweitägigen Strategie- und Kommunkationsseminar. Der Ort war mit Bedacht gewählt. Einerseits sollten wir für die Zeit des Workshops im wortwörtlichen Sinne genug Abstand zum Tagesgeschäft aufbauen und zum Teil war es auch ein Dankeschön an das Team für zwei Jahre harte und erfolgreiche Aufbauarbeit.
Wir waren im Hotel Palacio Avenida am Plaça d’Espanya am inneren Stadtring untergebracht. Dort fand auch das Seminar statt. Die Fotos vom offiziellen Teil der Veranstaltung werde ich natürlich nicht zeigen – aber ein paar Impressionen vom Freizeit-Teil sind erlaubt, denke ich.
Seminar im Hotel Palacio Avenida
Placa d'Espanya
Nach der Ankunft am Mittwoch Abend wollten wir noch gemeinsam einen Absacker nahmen, was sich aber als erstaunlich schwierig herausstellte, weil gerade überall geschlossen wurde. Aber Schwierigkeiten sind da, um gemeistert zu werden.
Palma am Abend - gerade geschlossen
Zwischen den Seminarteilen blieb uns freundlicherweise etwas Zeit um Palma geniessen zu können. Für den Rest der Insel leider nicht – aber will ich mich beschweren? Immerhin musste man nur die Straße überqueren um in die Altstadt zu kommen und zum Strand waren es auch nur gemütliche 15 Minuten zu Fuss, was wir in der Mittagspause am Donnerstag auch ausgenutzt haben.
Barfuss über den Strand, kurz die Füsse ins warme Wasser gehalten und dann einen leckerer Snack: frisches, knuspriges Brot mit Aioli und ein Glas Rosé. “La dulce vida” (wenn ich Google Translate da trauen darf…)
Mittagspause im Nassau Beach Club
Als Einstimmung auf das gemeinsame Abendmahl war das schon mal ganz gut. Das fand im Puro Beach Club statt.
Da zeigt sich mal wieder, welche Bildungslücken enstehen, wenn man keine Glotze hat. Hier verkehren wohl irgendwelche Pseudo Promis, deren Namen mir sowieso nichts sagen. Ich hatte auch den Spruch “Grüss mir die Katze” bei unserer Abfahrt nicht verstanden.
Egal. Umso unvoreingenommener konnte ich das Etablissement beurteilen. Mein Eindruck: Sieht ganz schick aus – wie in einem 70er Jahre James Bond Film. Es hätte mich auch nicht gewundert, wenn das Dessert per Wasserflugzeug gebracht worden wäre. Getränke und Essen waren recht gut, allerdings auch nichts weltbewegendes. Da haben mich schon kleine, unscheinbare Restaurants in Seitenstrassen von Artà oder Gozo wesentlich mehr beeindruckt.
Abendessen im Puro Beach Club
“DER JÜRGEN” als running Gag
Á Propos “Promis”: Nach dem Check-in auf dem Flughafen Hannover dauerte es natürlich nicht lange, bis die ersten Ballermann- und Jürgen Drews-Sprüche in der Truppe gerissen wurden. Als ein Kollege meinte, er würde jetzt mal rübergehen um sich ein Autogramm zu holen habe ich erst verstanden, dass der langhaarige Typ in der Glitzerjacke am Gate tatsächlich Jürgen Drews war – der sozusagen mit uns zur Arbeit flog. Und es sollte nicht das letzte Mal sein, dass wir ihn sahen…
Nach dem Abend im Puro Beach Club wollten wir eigentlich nach Palma zurück, aber – hallo Gruppendynamik – führen wir dann plötzlich doch Richtung S’Arenal in den Mega Park. Quasi als Gegenthese zu zuviel Gediegenheit.
Holldrio, was für ‘ne Rummelmucke!
Selbstverständlich war das total unter unserem Niveau – und nach ungefähr 60 Sekunden war die ganze Truppe auf der Tanzfläche… :-)
Das eCommerce Team im Entertainment-Einsatz
Natürlich trat DER JÜRGEN dann auch tatsächlich noch auf. “Ein Bett im Kornfeld” singend als “König von Mallorca” verkleidet. Dass ich DAS noch erlaben musste durfte…
Wir nahmen den Auftritt dann auch als Anlass, ins Hotel zurückzufahren, weil ja immerhin noch der zweite Seminartag vor uns lag, den wir dann auch mit Bravour hinter uns brachten.
Alles in allem hatten wir eine sehr gelungene Veranstaltung, die sicherlich dem Gruppenprozess sehr zuträglich war. Ich schätze die Kollegen und Kolleginnen sehr und habe sie auch persönlich gerne um mich. So gesehen, waren es zwei bittersüsse Tage für mich. Sehr schön, aber auch etwas traurig, weil ich die Firma zum Jahresende nach über zwei Jahren sehr intensiver und erfolgreicher Arbeit verlassen werde.
Gestern Abend war ich in der c-base zur Veranstaltung “Idea >> Realtime – Demoscene Realtime Graphics”. Es war ein schöner Abend, der mit lockerem Grillen am Spreeufer begann. Zwei typische Mitte Hipster verliefen sich am Spreeufer auf der Suche nach einem typischen Mitte-Hipster-Laden und standen plötzlich vor der Crowd. Ein irritierter, leicht angewiederter Blick und die beiden drehten sich um und gingen, so schnell, wie sie erschienen waren. Das war auch besser so – in der c-base sehen Nerds eben noch wie Nerds aus. Aber immerhin waren überraschenderweise auch einige durchaus nicht unattraktive Damen anwesend.
c-base Eingang
c-base - noch leer
Im Laufe des Abends hielt Pixtur einen netten Vortrag über die Demoszene und führte das Tool vor, mit dem seine Gruppe STILL arbeitet. Den Vorläufer mitgerechnet stecken 7 Jahre Entwicklungsarbeit in TOOLL2 – und das merkt man. Es ist nicht nur die Leistungsfähigkeit toll, sondern – und das hätte ich von einem Werkzeug, das von Freaks für Freaks entwickelt wurde nicht erwartet – es hat auch eine sehr brauchbare Benutzeroberfläche.
Pixtur führt TOOLL2 vor
Danach gab es ein Pottpurri sehr unterschiedlicher Demos aus Kategorien wie 4K, 64K, Commodore Plus 4, Amiga und sogar Web, die in den letzten zwei Jahren auf den Veranstaltungen für aufsehen gesorgt hatten. Mir gefiel die Demo “Beta” von Still noch mit am besten. Technisch kitzelt sie aus den Rechnern zwar nicht das Letzte heraus, aber ich finde die Ästhetik einfach klasse.
Am Freitag schrieb ich mir mein Missvergnügen an Magento von der Seele (“Mein Leben als Softwaredissident“). Dann las ich einen Artikel auf Kassenzone.de den Alexander Graf bewusst provokativ mit dem Satz “Das beste Shopsystem ist zur Zeit Shopware” begann und in dem er Magento disste. Interessant daran sind aber vor allem, die ausufernden Kommentare.
Als Replik auf den Artikel erschien auf ecomPunk der Artikel “Roman’s Rants: Shop System Wars“. Der zentrale Satz darin lautet:
“You know what? It doesn’t bloody matter which software you use, it’s just a fucking tool!”
Genau. Bloss kein Glaubenskrieg. In den letzten 15 Jahren war ich an so einigen Online Shop Projekten beteiligt und stiess dabei stets auf die Frage:
Was ist die ideale Shopsoftware?
HA! Ideal unter welchen Voraussetzungen? ecomPunk meint, daß die zentralen Fragen sind: Unterstützt das Tool effizient Dein Geschäftsmodell und war kostet der ganze Kram?
Das würde ich glatt unterschreiben. Ich spielte in Gedanken die Onlineshops durch, die ich in den letzten 15 Jahren gebaut hatte. Die Spannbreite war recht beachtlich. Sowohl bezüglich des Artikelsortiments, der kaufmännischen Anforderungen, der Systemumgebungen, der verwendeten Techniken und des Traffics. Die Shops waren unter anderem für:
Computer und Zubehör
Mobilfunkzubehör
Handyverträge eines der grossen deutschen Netzbetreibers
Merchandisingartikel
Finanzdienstleistungen
Bekleidung
Jedes Projekt hatte dabei spezielle Herausforderungen. Mal war es ein sehr heterogenes Artikelsortiment, mal extrem marketinggetriebenes Vorgehen, das tägliche Umbauten erforderte, mal die Kombination verschiedener Layouts, Sprachen und Währungen, mal ein sehr komplexes Systemumfeld und mal der schiere zu bewältigende Traffic.
Die verwendete Technik reicht von ein paar Zeilen PERL mit CSV Dateien, über PHP/MySQL-basierte System bis hin zu Enterprise Lösungen auf der Basis von Java/Oracle. In keinen zwei Projekten kam die gleiche Basistechnologie zum Einsatz. So unterschiedlich die Anforderungen und die zur Lösung eingesetzte Technik auch war – einige zentrale Erkenntnisse bestätigen sich immer wieder:
Man möchte zunächst Software, die so flexibel wie möglich ist. Das Marketing träumt davon, alles ohne Programmierer machen zu können, sobald das System einmal steht. Das führt zu einer Shortlist mit den üblichen Standardsystemen.
Standardsysteme versuchen alle denkbaren Szenarien abzudecken und sind daher prinzipiell schwergewichtig bzw. aufgeblasen.
Egal was das System kann – das Marketing will es immer etwas Anderes haben. Vorzugsweise etwas, das mit den vorhandenen Datenstrukturen nicht geht. “Und die Aktion startet übrigens morgen Mittag…”
Der “wiederverwendbare Code” ist häufig so allgemein gehalten und verschachtelt, daß das Anpassen länger dauert, als schlanken “Wegwerfcode” zu bauen.
Shops sind nach durchschnittlich zwei Jahren so verbastelt, dass die Codebasis komplett erneuert werden muss.
Große Shops (also nicht der kleine Spezialversender, der seine Pakete noch selber zu DHL bringt) brauchen meist kein Shop-Backend. Sie sind direkt an Warenwirtschaft, Finanzbuchhaltung und PIM angeschlossen.
Aussagen wie “Mit PHP schafft man den Traffic nicht” sind Blödsinn. Es kommt letztlich auf die Systemarchitektur an. Was Flickr und Facebook antreibt, sollte auch für Deinen Laden reichen. Ich habe vor 20 Jahren mal die weisen Worte gelesen “Ein schlechter Algorithmus ist in jeder Programmiersprache langsam”.
Dirk Ollmetzer | Friday, 31 August 2012 | Development
Heute hatte ich ein Gespräch über Softwareentwicklung im eCommerce Bereich. Anschliessend stellte sich bei mir erst ein Gefühl der Unzufriedenheit und schliesslich so etwas wie Frustration ein. Ich war in nahezu allen Dingen die zur Sprache kamen (Basissysteme, Frameworks, Entwicklermethoden) fundamental anderer Meinung, als mein Gegenüber. Schlimm daran fand ich, dass die andere Meinung absoluter Mainstream unter den Entwicklern ist. Ich bin also quasi ein Software-Dissident.
Worum ging es?
Es fing schon mit den verwendeten Basissystemen an: Typo3 und Magento. Finde ich beide zum in-die-Tonne-treten. Warum?
Typo3 ist in der Bedienung unglaublich umständlich und einfach nicht state-of-the-art. Man hat eine Million Stellen, wo man irgendweche Settings machen muss und kann sich eigentlich nie sicher sein, dass man nicht doch noch irgendwas übersehen hat. Der Sinn von Typoscript hat sich mir auch noch nie erschlossen. Mit einem sauberen MVC Ansatz würde man keine zusätzliche Templatesprache benötigen. Zudem ist das System out-of the-box langsam und verbraucht viel Ressourcen auf dem Server.
Magento benötigt ebenfalls sehr viel Ressourcen und es ist im Grundzustand wahnsinnig lahm. Man kann es schneller machen – aber das ist recht aufwändig. Zudem ist der Code überkomplex. Wenn ich höre, dass man Fehlersuche bei Magento ohne Debugger eigentlich vergessen kann (und das glaube ich uneingeschränkt), verdrehe ich die Augen. Eine Shopping-Cart ist eigentlich eine der einfachsten Webanwendungen überhaupt. Wenn ich da einen Debugger brauche – was zum Geier soll das für eine Softwarearchitektur sein?
Jira als Standard Ticketsystem bringt mich ebenfalls zur Verzweifelung. Das ist so komplex in der Bedienung wie Typo3 – allerdings in zehnfacher Potenz.
Anschliessend ging es um die Frage, welche Frameworks sinnvoll sind. Das betraf sowohl PHP Frameworks wie Zend, Cake oder Symphony, als auch Javascript und CSS Frameworks. Dabei ist meines Erachtens die Frage:
Sinnvoll in welcher Hinsicht?
Mit Cake kann man ohne Frage extrem schnell Webapplikationen bauen. Ob ich dieses Konstrukt aber in Hochlastszenarien einsetzen würde, möchte ich doch schwer in Frage stellen. Analog gilt für CSS Frameworks, dass man damit schnell ein gutes Standard-Ergebnis erzielen kann. Wenn es aber darum geht, die Frontend Performance zu optimieren, geht nichts über eigenen Code.
Womit wir bei der Softwareentwicklung angekommen sind. Objektorientiert wird bevorzugt – klar. Designpatterns? Ohne Frage absolut sinnvoll, wenn man komplexe Software baut. Bei Webanwendungen allerdings schwerstens überbewertet. Hier gibt es keine laufende Applikation, die parallele Threads, Events, Multiuser, was weiss ich noch was berücksichtigen muss. Der grundlegende Ablauf ist hier ja stets gleich:
Request kommt rein, wird verarbeitet, Antwort geht raus, Ende.
Okay, Application- und Sessionobjekt als Singleton zu programmieren macht durchaus Sinn. Ein Factory-Objekt ist hier und da ebenfalls angebracht. Aber sonst? Wenn man diese Techniken inklusive massenweise Vererbung übertreibt, kommt man zu sehr schwer wartbarem Code (“Hallo Debugger!”), der viel Ressourcen braucht (“Rechenzentrum: Bitte nochmal zwei Blades reinschieben…”) und langsam ist.
Langsam? Macht nix – kann man ja cachen…
Hmm, die Lösung ist also, auf eine vermurkste, zu komplexe Architektur noch eine Softwareschicht draufzulegen und das System damit noch fehleranfälliger zu machen? Ist ja ‘ne super Idee…
Conclusio
Und hier fiel mir auf, warum ich mit meiner Meinung häufig so alleine stehe. Ich bin stets auf des Suche, nach möglichst schlanken, eleganten und performanten Architekturen. Der Mainstream ist aber, eine dicke Schicht auf die andere zu setzen und damit Bloatware zu erzeugen.
Das läuft mir einfach zu 100% gegen den Strich.
Vielleicht liegt das daran, dass ich sowieso gerne mal dagegen bin (wie der Comic-Pinguin von Uli Stein).
Vielleicht liegt es daran, dass ich das Programmieren im letzten Jahrtausend auf ultralangsamen 8 Bit Rechnern mit weniger als 64KB(!) Speicher gelernt habe.
Vielleicht weil ich generell ein Faible für Schlichtheit und Reduktion habe.
Vielleicht liegt es auch daran, dass es wesentlich schwieriger ist, eine elegante, einfache Lösung zu entwickeln, als ein komplexes Monstrum zu erschaffen. Meine Meinung ist: Wenn ein System sehr komplex ist, ist es einfach noch nicht genügend durchdacht.
Wahrscheinlich sind alle der oben aufgezählten Gründe die Ursache für mein heutiges Missvergnügen.
Gerade bin ich bei Tech Crunch über einen interessanten kurzen Artikel gestolpert. In “All Your Metadata Shall Be In Water Writ” wirft Devin Coldewey das Problem auf, dass man sich nicht wirklich auf die Korrektheit von Daten aus dem Internet verlassen kann. Er bezieht sich auf die Unbeständigkeit von Daten, zum Beispiel Artikel in Blogs, Homepages, Wikipedia und sonstwas.
Man findet leicht Unmengen von Informationen zu fast jedem denkbaren Thema, aber man kann sich nicht auf deren Beständigkeit und Integrität verlassen.
Die Information kann zwischem den letzten Abruf und dem aktuellen verändert worden sein.
Das ist zum Beispiel bei Publikationen (“Internetzeitungen”) oder auch Blogs durchaus üblich.
Die Information kann vollständig verschwunden sein.
Der Betreiber existiert nicht mehr, hat das Interesse verloren, verfolgt jetzt andere Ziele oder wurde verklagt.
Die Information kann beim Transport vom Server zum Client verändert worden sein.
Stichwort Zwangsproxy zum Beispiel bei UMTS Verbindungen. Hier wird bereits heute von den Providern der auszuliefernde Inhalt verändert.
Die Angaben zum Ort, an dem die Information vermutet wird, können manipuliert sein.
Das passiert bei nahezu allen DSL Anbietern in Deutschland, wenn im Browser fehlerhafte URL eingegeben werden.
Die Information kann personalisiert sein, d.h. in Abhängigkeit meinem Browser, Betriebssystem, Standort, Netzwerkanschluss, Login oder sonstigen Parameter kann mir abweichender Inhalt angezeigt werden.
Das ist unter Umständen sogar sinnvoll, wenn Websites an Smartphones angepasst werden. Hingegen zumindest fragwürdig, wenn Google in Abhängigkeit vom Land aus dem eine Suchanfrage kommt, bestimmte Ergebnisse unterdrückt.
An den Beispielen wird jedenfalls deutlich, dass keine Verlässlichkeit gegeben ist. Coldewey schreibt:
There is no simple and reliable way to tell whether the information you are looking at has been altered in any way. Every word, every image, every byte has to some significant degree an unknown provenance.
Die o.g. Methoden können in bestimmten Szenarien durchaus nützlich und sinnvoll sein. In anderen Szenarien können es gezielte Manipulationen sein, um z.B. bestimmte Reaktionen auszulösen, Daten abzugreifen, Falschinformationen weiterzugeben, Reputation zu zerstören, rechtliche Massnahmen zu beeinflussen oder sonstige dunkle Machenschaften durchzuführen.
Auf jeden Fall sollte man sich stets bewusst sein, dass es bei Daten aus dem Internet keine Verlässlichkeit gibt, wenn man auf der Basis dieser Daten wichtige Entscheidungen treffen will.
Dirk Ollmetzer | Wednesday, 22 August 2012 | Fundstücke
Ich habe früher so lustige Sachen gespielt, wie “Ich will schneller an der nächsten Strassenecke sein, als das Auto, dass da hinten gerade losgefahren ist”. Totales Kopfkino. Habe das natürlich keinem gesagt, weil mir dann doch irgendwie blöde vorkam.
Offensichtlich haben andere aber auch solche Art Spinnereien Spielereien gemacht. Musste jedenfalls gerade über dieses Video schmunzeln und fühlte mich etwas ertappt…
Dirk Ollmetzer | Monday, 20 August 2012 | Development
NERDWARNUNG:
Wer nicht programmiert, wird das Folgende leider nicht verstehen. Sorry.
Für den Rest: Ich habe gerade den Artikel “New programming jargon” auf Jeff Atwoods Blog Coding Horror gelesen und musste über die Begriffsdefinitionen schon schmunzeln.
Er schreibt zum Beispiel über Yoda Conditions:
Using if(constant == variable) instead of if(variable == constant), like if(4 == foo). Because it’s like saying “if blue is the sky” or “if tall is the man”.
Darüber habe ich noch nie wirklich nachgedacht, aber so ein Ausdruck wie if(5 == count)
kam mir schon immer instinktiv unelegant vor.
Schön sind auch verschiedene Fehlertypen, die bestimmt jedem schon mal begegnet sind, wie zum Beispiel diese beiden:
Heisenbug – Der Fehler, der nicht mehr auftritt, sobald er untersucht wird.
Loch Ness Monster Bug – Fehler, die immer nur eine bestimmte Person meldet, die aber niemals bei irgend jemand anderem auftauchen.
Beim Debuggen ist auch bestimmt so mancher bereits über Hydra Code gestolpert (jedes Mal, wenn einen Fehler entfernt, tauchen an anderer Stelle zwei neue Fehler auf).
Ich will nicht alles vorweg nehmen – wen es interessiert, dem sei der Original Artikel empfohlen. Da ich schon mal beim Empfehlen bin – Atwoods Rant gegen PHP (“The PHP Singularity“) ist auch lesenswert. Zwar ist PHP meine bevorzugte Programmiersprache – aber an deren Eleganz oder Konsequenz liegt es sicher nicht…
So, nun ist es schon spät und es wird so langsam Zeit für ein bischen Noping.
Dirk Ollmetzer | Tuesday, 14 August 2012 | Fundstücke
Vor etwas längerer Zeit hatte ich bereits das Vergnügen, Iggy Pop live zu erleben. Damals war der Mann schon über 60 und ich war perplex und faziniert, was für eine irre Rampensau über die Bühne in der Zitadelle Spandau jagte.
Wesentlich besser, als ich es je könnte beschreibt Henry Rollins (der ja selber auch nicht so ganz ohne ist) dieses Gefühl, das ich damals hatte – natürlich aus seiner Sicht als Musiker.
Vorhang auf…
Vielen Dank an Spreeblick, für den Hinweis auf dieses Video. Ich habe Tränen gelacht…
Dirk Ollmetzer | Saturday, 11 August 2012 | Unterwegs
Ein kurzes Wochenende im hohen Norden – bei schönstem Wetter. 22 Grad, leichter Wind, Sonne, Wasser.
Heute ein kurzer Abstecher zum Yachhafen Sonwik in Flensburg, ein längerer Abstecher an den Strand nach Holnis und gleich geht es zum Rummel nach Glücksburg. Sehr nett!