Big Idea
I am getting to the stage of my career now where I have started picking up guiding principles that guide my socio-technical endeavors. I am sure I will continue to learn more and add them here or come back revise these with more wisdom and insight but what I want to start here is a collection of tenets. These tenets are not implementation details or design patterns but are more like paradigms for how we relate to problems, the natural systems that emerge from people thrown into teams, and more.
Tenets
In systems we see hierarchy emerge naturally. In this hierarchy, be it teams or software, look down for functionality and up for vision. This is how an organization scales, this is how code modularizes. 1
When you encounter an unknown problem in a system don’t jump to trying to fix the problem. First get visibility of the data that shows the problem. Second, fix the data with your changes. Third, validate that the data is corrected. 2
The goal of a DevOps environment is the goal of creating an environment in which change is safe. 3
I first heard the astute summary “down for functionality and up for vision” from Charity Majors’ interview with the Kubernetes Podcast (~6 min mark) ↩︎
Learned this from a great mentor and Sr. developer while I was a working through school ↩︎
Many teams rarely realize how paralyzed their velocity is by the fear that change means instability. The problem is that instability is not a result of change but a result of insufficent controls around how change is managed. ↩︎