Architects, Anti-Patterns, and Organizational Fuckery

I recently wrote a twitter thread on the proper role of architects, or as I put it, tongue-in-cheek-ily, whether or not architect is a “bullshit role”.

It got a LOT of reactions (2.5 weeks later, the thread is still going!!), which I would sort into roughly three camps:

  1. “OMG this resonates; this matches my experiences working with architects SO MUCH”,
  2. “I’m an architect, and you’re not wrong”, and
  3. “I’m an architect and I hate you.”

Some of your responses (in all three categories!) were truly excellent and thought-provoking. THANK YOU — I learned a ton. I figured I should write up a longer, more readable, somewhat less bombastic version of my original thread, featuring some of my favorite responses.

Where I’m Coming From

Just to be clear, I don’t hate architects! Many of the most brilliant engineers I have ever met are architects.

Nor do I categorically believe that architects should not exist, especially after reading all of your replies. I received some interesting and compelling arguments for the architect role at larger enterprises, and I have no reason to believe they are not true.

Also, please note that I personally have never worked at a company with “architect” as a role. I have also never worked anywhere but Silicon Valley, or at any company larger than Facebook. My experiences are far from universal. I know this.

Let me get suuuuuper specific here about what I’m reacting to:

  • When I meet a new “architect”, they tend toward the extremes: either world class and amazing or useless and out of touch, with precious little middle ground.
  • When I am interviewing someone whose last job title was “architect”, they often come from long tenured positions, and their engineering skills are usually very, very rusty. They often have a lot of detailed expertise about how their last company worked, but not a lot of relevant, up-to-date experience.
  • Because of 👆, when I see “architect” on a job ladder, I tend to feel dubious about that org in a way I do not when I see “staff engineer” or “principal engineer” on the ladder.

What I have observed is that the architect role tends to be the locus of a whole mess of antipatterns and organizational fuckery. The role itself can also be one that does not set up the people who hold it for a successful career in the long run, if they are not careful. It can be a one-way street to being obsolete.

I think that a lot of companies are using some of their best, most brilliant senior engineers as glorified project manager/politicians to paper over a huge amount of organizational dysfunction, while bribing them with money and prestige, and that honestly makes me pretty angry. 😡

But title is not destiny. And if you are feeling mad because none of what I’ve written applies to you, then I’m not writing about you! Live long and prosper. 🖖

Architect Anti-patterns and fuckery

There is no one right way to structure your org and configure your titles, any more than there is any one right way to architect your systems and deploy your services. And there is an eternal tension between centralization and specialization, in roles as well as in systems.

Most of the pathologies associated with architects seem to flow from one of two originating causes:

  1. unbundling decision-making authority from responsibility for results, and
  2. design becoming too untethered from execution (the “Frank Gehry” syndrome)

But it’s only when being an architect brings more money and prestige than engineering that these problems really tend to solidify and become entrenched.

Skin In The Game

When that happens, you often run into the same fucking problem with architects and devs as we have traditionally seen with devs and ops. Only instead of “No, I can’t be on call or get woken up, my time is far too valuable, too busy writing important software”, the refrain is, “No, I can’t write software or review code, my time is far too valuable, I’m much too busy telling other people how to do their jobs.”

This is also why I think calling the role “architect” instead of “staff engineer” or “principal engineer” may itself be kind of an anti-pattern. A completely different title implies that it’s a completely different job, when what you really want, at least most of the time, is an engineer performing a slightly different (but substantially overlapping) set of functions as a senior engineer.

My core principle here is simple: only the people responsible for building software systems get to make decisions about how those systems get built. I can opine all I want on your architecture or ours, but if I’m not carrying a pager for you, you should probably just smile politely and move along.

Technical decisions should be ultimately be made by the people who have to live with the consequences. But good architects will listen to those people, and help co-create architectural decisions that take into account local, domain, and enterprise perspectives (a Katy Allred quote).

Architecture is a core engineering skill

When you make architecture “someone else’s problem” and scrap the expectation that it is a core skill, you get weaker engineers and worse systems.

Learning to see the forest as well as the trees, and factor in security, maintainability, data integrity and scale, performance, etc is a *critical* part of growing up as an engineer into senior roles.

The story of QA is relevant here. Once upon a time, every technical company had a QA department to test their code and ensure quality. Software engineers weren’t expected to write tests for their code — that was QA’s job. Eventually we realized that we wrote better software when engineers were held responsible for writing their own tests and testing their own code.

Developers howled and complained: they didn’t have time! they would never get anything built! But it gradually became clear that while it may take more time up front to write and test code, it saved immensely more time and pain in the longer run because the code got so much better and problems got found so much earlier.

It’s not like we got rid of QA  — QA departments still exist, especially in some industries, but they are more like consulting experts. They write test suites and test software, but more importantly they are a resource to make sure that everybody is writing good tests and shipping quality software.

This was long enough ago that most people writing code today probably don’t remember this. (It was mostly before my own time as well.) But you hear echoes of the same arguments today when engineers are complaining about having to be on call for their code, or write instrumentation and operate their code in production.

The point is not that every engineer has to do everything. It’s that there are elements of testing, operations, and architecture that every software engineer needs to know in order to write quality code — in order to not make mistakes that will cost you dearly down the line.

Specialists are not here to do the job for you, they’re to help you do the job better.

“Architect” Done Right

If you must have architects at all, I suggest:

  1. Grow your architects from within. The best high-level thinkers are the ones with a thorough grounding in the context and the particulars.
  2. Be clear about who gets to have opinions vs who gets to make decisions. Having architects who consult, educate, and support is terrific. Having “pigeon architects” who “swoop and poop” — er, make technical decisions for engineers to implement — is a recipe for resentment and weak architectures.
  3. Pay them the same as your staff or principal engineers, not dramatically more. Create an org structure that encourages pendulum swings between (eng, mgr, arch) roles, not one with major barriers in form of pay or level disparities.
  4. Consider adopting one of the following patterns, which do a decent job of evading the two main traps we described above.

If your architects don’t have the technical skills, street cred, or time to spend growing baby engineers into great engineers, or mentoring senior engineers in architecture, they are probably also crappy architects. (another Katy Allred quote)

The “Embedded Architect” (aka Staff+ Engineer)

The most reliable way I know to align architecture and engineering goals is for them to be done by the same team. When one team is responsible for designing, developing, maintaining, and operating a service, you tend to have short, tight, feedback loops that let you ship products and iterate swiftly.

Here is one useful measure of your system’s complexity and the overhead involved in making changes:

“How long does it take you to ship a one-character fix?”

There are many other measures, of course, but this is one of the most important. It gets to the heart of why so many engineers get fed up with working at big companies, where the overhead for change is SO high, and the threshold for having an impact is SO long and laborious.

The more teams have to be involved in designing, reviewing, and making changes, the slower you will grind. People seem to accept this as an inevitability of working in large and complex systems far more than I think they should.

Embedding architecture and operations expertise in every engineering team is a good way to show that these are skills and responsibilities we expect every engineer to develop.

This is the model that Facebook had. It is often paired with,

The “Architecture Group” of Practicing Engineers

Every company eventually needs a certain amount of standardization and coordination work. Sometimes this means building out a “Golden Path” of supported software for the organization. Sometimes this looks like a platform engineering team. Sometimes it looks like capacity planning years worth of hardware requirements across hundreds of teams.

I’ve seen this function fulfilled by super-senior engineers who come together informally to discuss upcoming projects at a very high level. I’ve seen it fulfilled by teams that are spun up by leadership to address a specific problem, then spun down again. I’ve seen it fulfilled by guilds and other formal meetings.

These conversations need to happen, absolutely no question about it. The question is whether it’s some people’s full time job, or one of many part-time roles played by your most senior engineers.

I’m more accustomed to the latter. Pro: it keeps the conversations grounded in reality. Con: engineers don’t have a lot of time to spend interfacing with other groups and doing “project management” or “stakeholder management”, which may be a sizable amount of work at some companies.

The “architect-engineer” pendulum

The architect-to-engineer pendulum seems like the only strategy short of embedded architects / shared ownership that seems likely to yield consistently good results, in my opinion.

The reasoning behind this is similar to the reasons for saying that engineering managers should probably spend some time doing hands-on work every few years. You need to be a pretty good engineer before you can be a good engineering manager or a good architect, and 5+ years after doing any hands-on work, you probably aren’t one anymore.

If you’re the type of architect that is part of an engineering team, partly responsible for a product, shipping code for that product, or on call for that product, this may not apply to you. But if you’re the type of architect that spends little if any time debugging/understanding or building the systems you architect, you should probably make a point of swinging back and forth every few years.

The “Time-Share Architect”

This one has aspects of both the “Architecture Working Group” and the “Architect-Engineer Pendulum”. It treats architecture is a job to be done, not a role to be occupied. Thinking of it like a “really extended pager rotation” is an interesting idea.

Somewhat relatedly — at Honeycomb, “lead engineer” is a title attached to a particular project, and refers to a set of actions and responsibilities for that project. It isn’t a title that’s attached to a particular person. Every engineer gets the opportunity to lead projects (if they want to), and everybody gets a break from doing the project management stuff from time to time. The beautiful thing about this is that everybody develops key leadership skills, instead of embodying them in a single person.

The important thing is that someone is performing the coordination activities, but the people building the system have final say on architecture decisions.

The “Advisor Architect”

I honestly have no problem with architects who are not seen as senior to, and do not have opinions overriding those of, the senior engineers who are building and maintaining the system.

Engineers who are making architectural decisions should consult lots of sources and get lots of opinions. If architects provide educated opinions and a high level view of the systems, and the engineers make use of their expertise, well  that’s fan fucking tastic.

If architects are handing them assignments, or overriding their technical decisions and walking off, leaving a mess behind … fuck that shit. That’s the opposite of empowerment and ownership.

The “skin in the game” rule of thumb still holds, though. The less an architect is exposed to the maintenance and operational consequences of decisions, the less sway their opinion should hold with the group. It doesn’t mean it doesn’t bring value. But the limitations of opinions at a distance should be made clear.

The Threat to Architects’ Careers

It’s super flattering to be told you are just too important, your time is too valuable for you to fritter it away on the mundane acts of debugging and reviewing PRs. (I know! It feels great!!!) But I don’t think it serves you well. Not you, or your team, your company, customers, or the tech itself.

And not *every* architect role falls into this trap. But there’s a definite correlation between orgs that stop calling you “engineers” and orgs that encourage (or outright expect) you to stop engineering at that level. In my experience.

But your credibility, your expertise, your moral authority to impose costs on the team are all grounded in your fluency and expertise with this codebase and this production system — and your willingness to shoulder those costs alongside them. (All the baby engineers want to grow up to be a principal engineer like this.)

But if you aren’t grounded in the tech, if you don’t share the burden, your direction is going to be received with some (or a LOT of) cynicism and resentment. Your technical work will also be lower quality.

Furthermore, you’re only hurting yourself in the long run. Some of the most useless people I’ve ever met were engineers who were “promoted” to architect many, many years ago, and have barely touched an editor or production shell since. They can’t get a job anywhere else, certainly not with comparable status or pay, and they know it. 🤒

They may know EVERYTHING about the company where they work, but those aren’t transferable skills. They have become a super highly paid project manager.

And as a result … they often become the single biggest obstacle to progress. They are just plain terrified of being automated out of a job. It is frustrating to work with, and heartbreaking to watch. 💔

Don’t become that sad architect. Be an engineer. Own your own code in production. This is the way.

Coda: On “Solutions Architects”

You might note that I didn’t include solutions architects in this thread. There is absolutely a real and vibrant use for architects who advise. The distinction in my mind is: who has the last word, the engineers or the architect? Good engineering teams will seek advice from all kinds of expert sources, be they managers or architects or vendors.

My complaint is only with “architects” who are perceived to be superior to, and are capable of overruling the judgments of, the engineering team.

Exceptions abound; the title is not the person. My observations do not obviate your existence as a skilled technologist.  You obviously know your own role better than I do. 🙃


Architects, Anti-Patterns, and Organizational Fuckery

6 thoughts on “Architects, Anti-Patterns, and Organizational Fuckery

  1. I think I saw a bunch of:
    4. you’re misrepresenting architects and
    5. you’re doing #4 for “social media points (did I get any from posting? no? damn!).”

    Personally I almost entirely agree with you, but I think you’re misrepresenting the only meaningful criticism.

    Actually, I would go beyond that and claim that most of what I’ve seen over a couple of decades at a proto-FAANG and a bunch of startups . . . is that . . . architects tend to be political actors and not the people who tend to the architecture.

    Perhaps that’s because businesses are groups of people vying with one another for dominance, so they care about that a lot. But, frankly, nobody cares about how the sausage is made. A pristine sausage mill that always pumps out perfect ones is not a business goal. But I bet there’s a sales initiative for sausage that will change the company . . .

    So anyway, when you “stick it to the architects,” (my paraphrase) are you really doing that? If not, don’t take the feedback too seriously. Any press (even HN!) is good press, right?

    1. What *is* the only meaningful criticism? Don’t leave me hanging like that! 🙃 I also can’t quite tell what you’re asking … am I really doint what? (“Stick it to the architects” was really not my goal.. I was just sharing my observation that architects tend to be either AMAZING or useless, with very little in between, and it kind of took off from there.)

  2. Hoi,

    Van een collega kreeg ik dit artikel onder ogen.

    Goed artikel !!
    Ben ik ook mee eens.

    Met 2 opmerkingen:

    1 De wijze woorden van een oud collega:
    “Niets is absoluut,
    Ook niet wat je leest of denkt te begrijpen.”
    (Ik heb van die man veel geleerd van zijn uitspraken soort uitspraken.)

    2 De leerervaring tijdens mijn afstuderen in richting methodisch ontwerpen tov de aanpak in andere vakgebieden.
    (En een seminar en werkgroep hierover waar ik deel aan nam. Long time ago. Maar ook aan de gesprekken Siemens industrail solutions enkele jaren geleden. En tijdens de Strategic Platform of the European Machine Builders in Berlijn 2012 waar ik gastspreker mocht zijn tav mass customisation and CTO in the SME industry)

    Punt 2 in meer detail:

    Toen ik de titel van het artikel las, dacht ik dat het over een bouwkundig architect zou gaan. En in 1e gedeelte misschien wel een Mechansch- of Mechatronica architect, maar later in het artikel werd het duidelijk dat het over de Achitect van sofware systemen ging.

    Tijdens mijn studie naar de ontwerp aanpakken (methodieken) in andere gebieden, gaf ik aan bouwkundige architect bedrijven niet te kunnen vertouwen als ze geen bouwontwerp en oplevering (resultaat) verantwoordelijk zouden dragen.

    De hoogleraar moest daarop hard lachen over mijn stellige overtuiging ( enigzins gechargeerd, maar gebaseerd om mijn toen geringe ervaring waar ik het al aan den lijve had ondervonden).
    Maar hij bevestigde dat met schrijnende bouwkundige missers met falende constructies en gebouwen met dodelijke gevolgen. ( waar de architect (high level ontwerpers) en de uitvoerende partij (technische constructeurs en bouwbedrijven) naar elkaar wezen. (Om niet verantwoordelijk te zijn en de claims te ontduiken)).

    Dit komt overeen volgens de tekst in artikel (vooral met puntje 2):
    De meeste pathologieën die verband houden met architecten lijken voort te vloeien uit een van de volgende twee oorzaken:
    1 het loskoppelen van beslissingsbevoegdheid en resultaatverantwoordelijkheid,
    2 en ontwerp wordt te los van de uitvoering (het “Frank Gehry” -syndroom)

    En de rol of functie  architect, of systeem architect is inderdaad niet alleen van toepasing in het domein van het software gebied.
    Het komt oorspronkelijk voor uit System Engineering.

    1 Met een goed voorbeeld de technische uitvoering van militaire operaties en oplossingen als D-day.
    Met onderandere de haven van Amaranche in Normandie,  de Liberty schepen, zelfde de Willis jeep.

    2 En later System Engineering bedoeld als ontwerp van complexere producten met steun van meedere (multidiciplinaire) vakgebieden.
    (Wat tijdens mijn studie en tijdens afstuderen bij Shell mijn interesse en liefde had)

    3 Precies waar we tijdens en na de 3D en PLM implementatie onze werkgever met Dassault vanaf 2004 inhoudelijk over spraken voor ons vakgebied in de SME gebied (Small and Medium Enterprises).
    Maar ook in de gesprekken met Siemens Industial Solutions in 2008 om ons bedrijf naar een hoger niveau te brengen… (..nog  steeds een hoop te doen dus 🤣)

    4 En tegenwoordig heeft het geresulteerd in MBSE.
    Oftewel Model Based System Engineering, als centrale tool ondesteuning voor alle vakgebieden.

    In deze ontwikkeling in de periode van 2009 tot 2019 heb ik (met nog een collega) midden in gestaan en bijdrage geleverd met Dassault en afgevaardigden uit de luchtvaart en automobiel  industrie
    Dassault spreekt terecht over de RFLP structuur. (Requirement-Function-Ligical-Pysical strucure).
    Indien nodig kan ik daar over uitwijden.
    En dit implementeren in het product onwikkel proces in waves.
    En dan geld nog steeds het volgende:
    ” a fool with tool is still a fool 🤣)

    Maar nu terug naar het artikel.
    Die bevestigd dat kundige ervaren Architecten (als overlappende rol/functie) essentieel zijn.
    Waar ik het eens mee ben, zoals in het artikel omschreven.
    Dit is ook de reden waarom ik denk dat het noemen van de rol “architect” in plaats van “stafingenieur” of “hoofdingenieur” op zichzelf misschien een soort antipatroon is. Een compleet andere titel impliceert dat het een compleet andere baan is, terwijl je eigenlijk, in ieder geval meestal, een ingenieur wilt die een iets andere (maar substantieel overlappende) reeks functies uitvoert als senior engineer.
    En nog beter:
    Engineers who are making architectural decisions should consult lots of sources and get lots of opinions. If architects provide educated opinions and a high level view of the systems, and the engineers make use of their expertise, well  that’s fan fucking tastic.

    Dus ja dat heeft te maken met organisatie als bedrijf, en ook ondersteuning van de juiste tools die de (ontwikkel) methodiek in de executie ondersteund,
    MAAR allerbelangrijkste de mens, dus kundige en er varen vakmensen in het ontwikkel proces.
    En dat mag best een Architect zijn.
    Mits zoal omschreven in het artikel:

    Good architects will listen to those people, and help co-create architectural decisions that take into account local, domain, and enterprise perspectives.

    Dat is de essentie.
    Maar ook wat we leuk vinden.

    Tijdens het lezen van het artikel kwamen veer veel flash backs, ervaringen, spannende en mooie  momenten/ herinneringen boven.

    Met vriendelijke groet.

  3. I don’t think there is a single job title in our industry I couldn’t find good, bad, and dysfunctional examples of. Many of the criticisms I see tend to poo poo the ‘architectural astronaut’, the ‘Architectural Review committee’ located in SomewhereElse, and/or the non-coding standards/tool ivory towers, with which I wholeheartedly agree. Instead of focusing on an ill-defined job title, let me ask… What *activities* in a book like “Enterprise Software Architecture” or “Software Architecture: The Hard Parts” do you disagree with?

Leave a Reply