Im Management existiert manchmal die Vorstellung, man dürfe sich nicht von einem Lieferanten abhängig machen. Aus diesem Grund werden dann Vorgaben gemacht, dass für alle größeren Plattformen mindestens zwei Lieferanten / Integratoren / Dienstleister ins Boot zu holen seien. Solche Multi-Vendor-Strategien funktionieren grundsätzlich nicht! Software ist kein Büromaterial. Mehr als ein Lieferant ist organisierte Verantwortungslosigkeit. […]
Der Product Owner entscheidet. Dieser scheinbar triviale Satz aus jedem Scrum Lehrbuch birgt erhebliche Fallstricke. Ohne Entscheidungskompetenz beim PO funktioniert Scrum erfahrungsgemäß nicht. Kann oder darf der PO nicht entscheiden, ist er nicht in der Lage dem Team die richtigen Anforderungen in der notwendigen Geschwindigkeit zu geben. Er kann nicht Rede und Antwort stehen und […]
Kein Team ohne einen Senior aufstellen. Jedes Entwicklungs-Team braucht mindestens einen Senior, der eine solche Aufgabenstellung schon einmal konkret gemacht hat. Fehlt dieser Senior im Team, wird das Team sehr wahrscheinlich in Komplexitätsfallen laufen. Aus diesen kommt man dann nur noch mit viel Zeit und Aufwand heraus.
Administrivialitäten entscheiden kein Projekt. In einem Projekt sind immer Menschen entscheidend und niemals Pläne. Aus diesem Grund muss ein Projektleiter immer das Team und die Stakeholder im Focus haben. Pläne sind grob zu halten und auf ein Minimum zu beschränken. Pläne kann man anpassen, Menschen nicht.
Der Teufel steckt im Detail. In allen Lösungen und Projekten versteckt sich Komplexität. Und damit ist nicht diejenige gemeint, die offensichtlich ist. Software basiert immer auf hunderten von Skills und Technologien, die vielfach nicht bis in letzte Detail verstanden werden können und vom team einfach nur angewendet werden. Trotzdem fallen einem in jedem Projekt solche […]
Nach allen Seiten offen ist nicht ganz dicht! Generalisierung kann schnell übertrieben werden. Ansätze mit generischen Key-Value Daten-Strukturen und konfigurierbaren Funktionen führen sehr schnell in die „Konfigurations-Hölle“. Das System wird dann zweimal programmiert. Das erste mal vom Entwickler und die zweite Programmierung erfolgt in Form komplexer Konfigurationen. Ein passendes Anti-Pattern auf der Programmierebene ist das […]