data:image/s3,"s3://crabby-images/fc188/fc188c41b64dac226bf9c25443ec96114c6f9d9a" alt="Distributed Systems Pattern: Lease"
Cluster nodes need exclusive access to certain resources. But nodes can crash; they can be temporarily disconnected or experiencing a process pause. Under these error scenarios, they should not keep the access to a resource indefinitely.
more… https://martinfowler.com/articles/patterns-of-distributed-systems/time-bound-lease.html
data:image/s3,"s3://crabby-images/c35d8/c35d8b0814c6cd7e402129ae854dc13f0973cc1b" alt="The Lies that can Undermine Democracy"
Like many Americans, I was transfixed and horrified by the recent assault on the Capitol. Much of this anger originates in lies perpetrated by irresponsible politicians and spread through media agencies. Lies like this can destroy democracies, and while we must have free speech we must not be free of the consequences of that speech more… https://martinfowler.com/articles/202101-lies-and-democracy.html
data:image/s3,"s3://crabby-images/d0123/d0123e093bce5eb80457ce4acf2083c270a3bb72" alt="Maximizing Developer Effectiveness: Feedback Loops"
Tim continues his comparison of high and low effectiveness organizations by comparing their key feedback loops. To improve these, organizations need to understand the importance of micro feedback loops, which are often neglected because they are so small.
more… https://martinfowler.com/articles/developer-effectiveness.html#HowToGetStarted
Tim continues his comparison of high and low effectiveness organizations by comparing their key feedback loops. To improve these, organizations need to understand the importance of micro feedback loops, which are often neglected because they are so small.
more… http://localhost:1963/articles/developer-effectiveness.html#HowToGetStarted
data:image/s3,"s3://crabby-images/ec40d/ec40de54d1007c023ce0873aa4198718486a5f0c" alt="Maximizing Developer Effectiveness"
My colleague Tim Cochran has helped many software engineering organizations transform to respond faster to changing market needs. Often companies struggle with these transformations and a primary reason for these problems is that engineering organization has neglected to provide developers with an effective working environment. The key to to developing an effective environment is to concentrate on feedback loops.
In this first installment, Tim contrasts a develo
data:image/s3,"s3://crabby-images/96aba/96aba9ecc6317151b770f55f4c22197b057ad804" alt="Distributed Systems Pattern: Consistent Core"
Unmesh has a few more of his Patterns of Distributed Systems ready to share with the world. In this one he looks at the problem of a large cluster, one that is too large to effectively maintain strong consistency, yet needs to maintain some data in a strongly consistent way. It can do this by using a smaller cluster, which he calls a Consistent Core.
more… https://martinfowler.com/articles/patterns-of-distributed-systems/consistent-core.html
data:image/s3,"s3://crabby-images/c6987/c698714e54f64c1c7e31726feb4835acad1854a6" alt="My favorite musical discoveries of 2020"
Like most people, I'm looking forward to seeing 2020 in the rear-view mirror, but even this ugly year has brought some good things. For the last three decades I've regularly bought a few albums every month, and I thought I'd pick out a half-dozen favorites in the hope that they lead some readers to share at least a bit of my musical tastes. I've been doing most of my musical buying on Bandcamp, so you can easily sample them.
data:image/s3,"s3://crabby-images/9af8f/9af8f8edbc80071e3b6d633d4151f61cf5347a27" alt="Data Mesh Principles and Logical Architecture"
Last year, my colleague Zhamak Dehghani introduced the notion of the Data Mesh, shifting from the notion of a centralized data lake to a distributed vision of data. Based on more thinking, and the lessons of a year's worth working with clients, she's now written an article outlining four foundational principles of a data mesh, and how they drive a logical architecture.
more… https://martinfowler.com/articles/data-mesh-principles.html
data:image/s3,"s3://crabby-images/6ae38/6ae38d44e92843d787f4c80fc56f1687e485f688" alt="Bliki: ComputationalNotebook"
A computational notebook is an environment for writing a prose document that allows the author to embed code which can be easily executed with the results also incorporated into the document. It's a platform particularly well-suited for data science work. Such environments include Jupyter Notebook, R Markdown, Mathematica, and Emacs's org-mode. When I'm exploring some data, it's useful to keep my notes close together with the code that performs the exploration. I like to try some cod
data:image/s3,"s3://crabby-images/79a93/79a93640aa0e522d4379ea271b5a225b62439d9d" alt="Don't put data science notebooks into production"
We've come across many clients who are interested in taking the computational notebooks developed by their data scientists, and putting them directly into the codebase of production applications. My colleague David Johnston points out that while data science ideas do need to move out of notebooks and into production, trying to deploy that notebooks as a code artifact breaks a multitude of good software practices. Predictably, that results in a number of obser