Breaking free from monolithic thinking

Monolithic thinking and centralization hinders agility, inovation and responsiveness

Picture by: Todd Trapani

In recent years, companies have increasingly adopted an agile approach to working and innovation, as this method has been proven to be an effective way to develop products and services quickly and effectively. However, the success of an agile approach can be hindered by a monolithic thinking and centralization.

Monolithic thinking is the idea that all aspects of a company should be managed in the same manner. This centralization of control stifles creativity and innovation, as it limits the ability of individual team members to experiment and come up with new ideas. It also slows down decision-making, as each decision must be approved by the top-level management or centralized team.

Centralization of control also hinders agility and responsiveness. With a centralized structure, teams are unable to react quickly to changes in the market or customer demands. This can lead to missed opportunities and a slower rate of product or service delivery.

Finally, monolithic thinking and centralization can also lead to increased bureaucracy and costs. Teams are often forced to adhere to rigid processes that are not tailored to the individual needs of the organization, which can lead to wastage of time and resources.

To ensure that an agile approach is successful, companies must strive for more flexible and distributed decision-making and architecture. This means that teams should be empowered to make decisions independently, so that they can react quickly to changes in the market or customer demands. Additionally, companies should strive for greater transparency and open communication between teams, so that they can collaborate effectively and speed up decision-making.

By moving away from monolithic thinking and centralization, companies can ensure that their agile approach to working and innovation is successful. This will help them to develop products and services quickly and effectively, and ensure that they remain competitive in the ever-changing business landscape.

Hidden Monoliths and Coupling: How to Identify and Mitigate Complexity in the Workplace

In today's ever-changing world of technology, understanding the concept of monoliths and coupling is vital for businesses to remain competitive. Monoliths are large, interconnected systems that are difficult to change without breaking its entire structure. Coupling is when two or more components of a system are linked, making it difficult to modify one without changing the other. Monoliths are often hidden from view, but they play a powerful role in both the digital and physical worlds. They can be found in software applications, databases, solutions, and even in the way we think about our workplaces. Monolithic structures are characterized by strong coupling, which can increase the resilience and efficiency of a system, but can also limit its ability to adapt to changing conditions. In this blog, we will explore the different types of monoliths and coupling, how they can be identified and mitigated in the workplace.

Application Monoliths: An application monolith is a single, large application that contains all the code and data needed to operate the system. It is difficult to make changes to this type of monolith without affecting its entire structure, making it hard to modify or maintain.

Joined-at-the-Database Monoliths: A joined-at-the-database monolith is a single database that contains data from multiple applications. This type of monolith is difficult to change or modify without affecting the entire system.

Monolithic Builds: A monolithic build is when all components of the system are built at the same time. This type of monolith is difficult to modify or maintain without affecting the entire system.

Monolithic Coupled Releases: A monolithic coupled release is when two or more components of the system must be released at the same time and in the right order. This type of monolith can be difficult to modify or maintain without affecting the entire system.

Another aspect of monolithic thinking is the single view of the world, standardization and one size fits all is a solutions. When it comes to problem solving, using the same tool or approach for every problem is not always the best option. Rather, the best approach is to assess the problem and determine which tool or approach will be the most effective. There are multiple tools and approaches that can be used to solve a particular problem and it's important to understand which one is the most suitable.

Monolithic Model (Single View of the World): A monolithic model is when all components of the system are viewed as a single entity. This type of monolith is difficult to modify or maintain without affecting the entire system.

Monolithic Thinking (Standardization): Monolithic thinking is when all components of the system are standardized and seen as a single entity. This type of monolith can be difficult to modify or maintain without affecting the entire system.

Monolithic Workplace: A monolithic workplace is when the entire organization is seen as a single entity. This type of monolith can be difficult to modify or maintain without affecting the entire system.

Understanding the different types of monoliths and coupling can help businesses identify and mitigate complexity in the workplace. By breaking down large, interconnected systems into smaller, more manageable components, businesses can make changes or modifications more easily and quickly. This can help businesses remain competitive and reduce their costs in the long run.

One way of doing this is the domain driven approach. Domain Driven Development and bounded context are two of the most powerful tools in software development. Both concepts help to create efficient and effective software solutions by making sure that the solution is organized around meaningful business domains.

Domain driven design (DDD) is an approach to software development that focuses on the underlying structure of a software system and the domain it operates in. It emphasizes the importance of exploring and understanding the domain before attempting to develop a software solution. By understanding the underlying business requirements and mapping them to software elements, the development process becomes much more focused and efficient.

Bounded context is an important concept in DDD. It is the process of separating out different areas or aspects of the system and defining the boundaries between them. By doing this, the system can be divided into smaller, more manageable parts, which can be better understood and more easily maintained.

For example, consider a banking application. The application can be divided into separate bounded contexts such as customer information, accounts, payments and loan processing. Each of these bounded contexts could be further divided into smaller bounded contexts, such as customer accounts, customer payments, loan products and loan processing. By dividing the system into smaller pieces, developers can focus on what is important for each area and create more focused solutions.

Domain driven design and bounded context are extremely useful for software development. By understanding the domain and dividing the system into more manageable pieces, architects and developers can create more efficient and effective software solutions. Additionally, by reducing complexity and increasing focus, the development process becomes much faster and more efficient.

You can advantageously apply Bounded Context with a Best of breed strategy. This focuses on leveraging the best-of-breed components within a given bounded context to create the most optimized solution. By using the best-of-breed components within a given bounded context, businesses are able to create a system that is tailored to the specific needs of their users while also reducing costs and complexity. Additionally, this strategy allows businesses to quickly deploy new features and capabilities as the needs of their users evolve. Ultimately, Best of Breed with Bounded Context Focus is an effective and efficient way to create highly optimized solutions.

Monolithic structures can be beneficial, but they can also limit the ability of a system to adapt to changing conditions and hinder agile ways of working. As with any type of structure, it is important to assess the benefits and drawbacks of monolithic thinking and centralization in order to determine the best approach for your particular needs and goals.

> A book tip for this subject is Matthew Skelton and Manuel Pais book: Team Topologies - Organizing business and technology teams for fast flow

Comments