TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

Devs need system design tools, not diagramming tools

215 pointsby argoeris11 months ago

21 comments

bunsenhoneydew11 months ago
As others have said the C4 model is a great way to address a number of these issues.<p>I can’t find the right video at the moment but Simon Brown (creator of C4) gives a great talk about creating his DSL, Structurizr, for C4, which he developed during COVID lockdown (if memory serves). There are many videos on YouTube of Simon talking about “C4 Models as Code” so I’m sure any one of those will suffice.<p>The focus is on creating the model of your system architecture, from which the diagrams you extract are a specific projection of that model. Rather than a diagram be the main artifact. It’s a simple but very powerful concept that I’m always surprised isn’t more widely used.<p>Structurizr models can also be exported to display as ilograph diagrams, mermaid diagrams and more. Also very much worth a mention is icepanel, a lovely tool for architectural model that implements the C4 model heavily.<p>I saw Simon talk at a conference in Sydney about 10-15 years ago and heard about C4 for the first time in that talk, it’s been one of the most influential talks I’ve been to in my career as it made a lot of fuzzy things in my head all start to come together in a way that just made sense.<p><a href="https:&#x2F;&#x2F;c4model.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;c4model.com&#x2F;</a><p><a href="https:&#x2F;&#x2F;structurizr.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;structurizr.com&#x2F;</a><p><a href="https:&#x2F;&#x2F;www.ilograph.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.ilograph.com&#x2F;</a><p><a href="https:&#x2F;&#x2F;mermaid.js.org&#x2F;" rel="nofollow">https:&#x2F;&#x2F;mermaid.js.org&#x2F;</a><p><a href="https:&#x2F;&#x2F;icepanel.io&#x2F;">https:&#x2F;&#x2F;icepanel.io&#x2F;</a>
评论 #40981399 未加载
评论 #40980877 未加载
评论 #40984074 未加载
评论 #40984122 未加载
评论 #40987548 未加载
jawns11 months ago
This reminds me of the following:<p>* Devs: We need a better language than Javascript as the lingua franca of the web!<p>* Users: Sure, use whatever language you want -- just make sure it compiles to Javascript, which is already the lingua franca of the web.<p>Keep in mind that the consumers of technical diagrams are often non-technical folks. And they don&#x27;t care about how they get their diagrams. They just want to be able to understand, at a high level, what&#x27;s going on in the black box.<p>You can either convince every single one of them that devs need to focus on better system design tools ... or you can continue to give them the diagrams they want, just using a smarter process to generate them.<p>Or you can treat them as entirely separate problems, because fundamentally system design tools are building tools, and system diagrams are communication tools. In most cases you can improve them independently.
评论 #40979507 未加载
评论 #40981547 未加载
评论 #40980422 未加载
评论 #40979641 未加载
评论 #40983908 未加载
yuliyp11 months ago
It&#x27;s not so hard to do static and tracing-based analysis to capture all the calls that various systems make between themselves. Similarly, it&#x27;s not so hard to graph all of the metrics of a system.<p>That&#x27;s not really all that useful. Diagrams, like other forms of documentation, are a <i>format</i> for communicating something to the reader. It means that they should spend more space on the important flows rather than the exceptional ones. They&#x27;ll explain the meaningful parts of a sequence rather than just giving a series of function calls. The various tools we have for doing this (boxes showing what systems talk to what, sequence diagrams, database schema diagrams) provide a rich enough language for that communication.<p>Death star diagrams are bad because they spend a bunch of time and effort to convey one piece of information: &quot;there are a lot of systems here&quot; rather than anything actually useful for someone attempting to navigate a specific part of the system.
steve197711 months ago
I think at least part of the problem is that todays &quot;agile&quot; methodologies lure people into almost completely neglecting analysis and design, as if these steps are forbidden in agile. So for many dev teams I have seen, agile basically means &quot;we have no plan&quot;.
评论 #40982812 未加载
评论 #40983863 未加载
gtirloni11 months ago
I read the whole article and it has great points. Almost nodded the whole time. However, I couldn&#x27;t identify whether an alternative exists today.
评论 #40979848 未加载
评论 #40979071 未加载
评论 #40979800 未加载
评论 #40979083 未加载
评论 #40983927 未加载
RcouF1uZ4gsC11 months ago
&gt;Today, we have the technology and knowledge to create tools that prevent developers from wasting valuable development time deciphering static, outdated diagrams,<p>One issue is that diagrams in general are pretty universal. As long as your tool can makes shapes and connect them, you can use it for any kind of architecture. For example it will work flow charts for 50 year old Fortran to UML from the 90s to microservices diagrams from now and I bet to whatever is common 50 years from now.
评论 #40979328 未加载
评论 #40984026 未加载
tomjohnson311 months ago
Thank you everyone for reading my article! I’m the author, Thomas Johnson. This article stems from my frustration with the typical approach of asking, “What diagramming tool should we use?” instead of addressing the root problem: the need for up-to-date, easily accessible system architecture information. That’s why I co-founded Multiplayer. We focus on automating the creation and maintenance of system architecture diagrams and creating a single source of truth for system information. This includes your individual components, APIs, dependencies, and repositories.<p>We’re language and environment agnostic and you can start with a napkin sketch or a photo of your whiteboard. And this is just the start, we have many plans for how to evolve system design tooling including supporting popular integrations and models like C4.<p>It’s early days for us. I’d love to hear what you think: <a href="https:&#x2F;&#x2F;www.multiplayer.app&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.multiplayer.app&#x2F;</a> (It’s free!)
dennisy11 months ago
Great post but lacking an answer. I guess we are yet to find one!
评论 #40979456 未加载
评论 #40979376 未加载
评论 #40983950 未加载
评论 #40979810 未加载
airbreather11 months ago
There is a potentially interesting standard many may not know - IEC 61499 - Standard for Distributed Automation, first ed 2005!!! and related to PLC type controllers.<p>It was meant to be the next step forward from IEC 61131 that described the five PLC control languages, but far ahead of it&#x27;s time.<p>61499 introduced the concept of an executable specification, and went on develop tie ins with XML and OPC. The executable specification is a particularly interesting idea, effectively emerging as no code these days<p>But two decades on is still only starting to get traction, seemingly because it was so far ahead of it&#x27;s time, and the target audience was potentially mostly only just branching out into software because they were now programming ladder logic, instead of designing panel boards with hundred of relays and timers.<p>But, it is worth a look for some ideas in the space, particularly the executable specification concept (you know this can only lead to a DSL of some kind), but also including their diagramming that looks a lot like UML but maybe works better, along with 4Diac software package, consideration of how some of the more esoteric aspects of OPC fit into all this, and more slightly obliquely, TLA+.
bitwize11 months ago
In 1971, M. Bryce and Associates marketed PRIDE, the first commercial software methodology for general business use. It was originally an entirely manual process using paper forms, but it was already far more comprehensive than anything called a &quot;methodology&quot; we use today. For example, in PRIDE, every artifact of the systems design and implementation process -- each high-level requirement, each software module, each database table and column, and more -- is assigned a tracking number and extensively documented as to its purpose in a unified knowledge repository. This was decades before Git or JIRA, and at first it was all done by hand, but not for long.<p>In the 80s, they marketed PRIDE&#x2F;ASDM, which combines PRIDE with Automated Systems Design Methodology, a suite of system design tools written in COBOL for mainframes. Far from being mere diagramming tools, they assisted in all aspects of an information systems design from initial requirements down through coding and database management. A key component of ASDM was the Information Resource Manager (IRM), a searchable central database of all of the information artifacts described above along with their documentation. Another component was Automated Instructional Materials (AIM), the online documentation facility, which not only provided instructions on how to use the system, it also provided step-by-step directions (called &quot;playscripts&quot; in PRIDE-speak) for each member of the development team to follow, in order to see a business system through from abstract design down to software implementation and deployment. Provided the directions were followed, it was next to impossible to screw up a system or subsystem implemented through PRIDE&#x2F;ASDM.<p>This level of comprehensiveness and clarity is <i>the</i> gold standard for business IS development. And it seems to be nearly lost to time.
评论 #40981270 未加载
ranger_danger11 months ago
I feel like <a href="https:&#x2F;&#x2F;plantuml.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;plantuml.com&#x2F;</a> gets close to what I want by being able to make diagrams with code, but for system design what I <i>really</i> want is to be able to have diagrams generated directly from the code itself, maybe with some extra comments&#x2F;annotations that help it along.<p>Does anything like that exist already?
评论 #40981041 未加载
canterburry11 months ago
We have the tools and ways to express architecture. The problem is no one is bothering to actually learn it and do it well.<p>Everyone seems to look for answers involving not having to spend any time learning anything new.<p>UML, BPMN, 4+1 view, it can do it all. Just learn it and make sure everyone else in your team does too.
评论 #40979610 未加载
评论 #40979794 未加载
danjl11 months ago
Google Slides and Drawings (under + &gt; More...) are great tools. They support the diagramming objects, connectors, shared collaboration, and integration with the other Google Doc tools. They also have great history and diff tools as well as team comments, with actions.
评论 #40983958 未加载
agumonkey11 months ago
I wonder if modeling&#x2F;system design people didn&#x27;t have new insights since the last 20 years (when Model Driven * started to sink).<p>Languages changed a bit, more types, more concurrency, more functional idioms. Yet I feel we&#x27;re not going anywhere.
kmerroll11 months ago
To take this a different way, Devs need AI-driven system design tools, not diagramming tools. The work to automate the process to define, code, deploy, and document tech&#x2F;app solutions using GenAI is arguably well underway and the days of humans producing layers of boxes and arrows documentation is thankfully numbered.<p>More directly, the need for the special snowflakes and the ensuing complex system design processes will be reduced as we drive towards more automation N(A) frameworks.
SrslyJosh11 months ago
This would be more interesting if there was actually a proposed solution.
评论 #40984000 未加载
webprofusion11 months ago
If we had a complete and evolving set of requirements for any reasonably complex system, we wouldn&#x27;t really read them once they no longer match the system we have delivered.<p>Systems and requirements go hand in hand but the reality is requirements are eventually codified, and after a point only the system matters because <i>the system</i> is the reality and the requirements were just the formal inspiration.<p>I would love to see automated requirement analysis and verification from code.
digger49511 months ago
This is a useless and insipid editorial. I don&#x27;t want the problem redeclared. We know this. We want solutions.
评论 #40984014 未加载
Veuxdo11 months ago
You need to use diagramming tools that are meant for complex systems. Almost all of the complaints in this article are caused be using generic drag-and-drop diagramming tools.
评论 #40979989 未加载
port1911 months ago
No, I need a diagramming tool. Excalidraw lives on
评论 #40983976 未加载
qwerty45612711 months ago
Also GUI design tools like the WinForms designer but for more modern toolkits please. VB&#x2F;Delphi&#x2F;WinForms were such a joy to design and XAMl (let alone web frontent) is such a pain to write.