Let's explore why it is Not.
Yes, that is a provocative title :)
Note: The realm of software architecture offers multiple pathways, each with its associated trade-offs. In this exploration, we delve into how Salesforce, a leader in the SaaS domain, effectively implements Domain-Driven Design and Microservices Architecture. This analysis concentrates on software architecture and design. Salesforce manages the infrastructure aspect, guaranteeing that customers need not concern themselves with it, thus providing them with peace of mind and an advantage in this regard.
Monolith & Microservices
Monolith
In software engineering, "monolith" describes an application architecture with intertwined and tightly coupled components, typically consolidated into a single large codebase. Effective for smaller or simpler applications, this approach presents several challenges as the application expands:
Despite Microservices' rising popularity, monolithic architecture retains key benefits, particularly suited to certain development contexts:
However, for larger and more complex applications, alternative architectures like Microservices are often considered to better address these challenges.
Microservices
Let's dive straight in and formulate a comprehensive synthesis of a Microservice Architecture definition drawing insights from various authoritative sources.
Red Hat Developer, Opensource.com, Developer.com, Salesforce, TechTarget, Pluralsight, O'Reilly, DZone, Sam Newman, Chris Richardson, Robert C. Martin, Marko Luksa, Martin Fowler
Microservice Architecture Distillation
Microservices represent individual units of software functionality, each focusing on a singular concern or business aspect. Characterized by their independence, they can be deployed on their own, typically within containers, facilitating communication through standardized, language-independent interfaces like REST APIs.
Let's continue with the principles of Microservices architecture.
Key principles of Microservices architecture include:
Lets take a look how Martin Fowler, a leader in the field views it
In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies.-- James Lewis and Martin Fowler (2014)
My takeaway. Whatever you use, things such as domain driven design and decoupling "workloads and processes" is the key outcome. The net affect is the organisation can move faster.
Lets also look at Domain-Driven Design to round out our perspective
The most reputable author (in my view) of Domain-Driven Design (DDD) is Eric Evans. He is widely recognized for his contributions to the field and is best known for his book "Domain-Driven Design: Tackling Complexity in the Heart of Software," published in 2003. In this book, Evans laid out the fundamentals of DDD, a software design approach that emphasizes modeling software based on the business domain and involves close collaboration between technical experts and domain experts.
Eric Evans' principles of Domain-Driven Design (DDD) have a significant influence on the way Microservices are conceptualized and implemented, particularly as articulated by experts like Martin Fowler. Here's a detailed look at how these principles intersect and complement each other in the context of microservices:
Salesforce's Alignment to Microservice Architecture and Domain-Driven Design
If we agree in general with the above synthesis of Monolith, Microservices and Domain-Driven Design.
I'll begin by proposing that Salesforce's architecture aligns very well with it, primarily due to its modular and decoupled design, which enables a level of flexibility and scalability akin to Microservices architectures and Domain-Driven Design and aligns with the key principles of Microservices and DD, each in distinct ways:
Salesforce Domain-Driven Design Example
The accompanying illustration simplifies seven distinct domains within the framework of Domain-Driven Design (DDD). This approach aids in providing a clearer understanding. The illustration clearly shows defined domain boundaries, with each embodying a distinct bounded context. This visual representation effectively exemplifies the principles of DDD. It highlights the careful delineation of each domain, showcasing its unique area of focus and functionality.
So far it feels like we are on the right track of realising a Microservices approach within the Salesforce platform.
Undoubtedly, the ability to rapidly develop and deploy features is essential, requiring some level of independence from other teams. The following illustration captures this idea. It depicts a specialized team or 'squad' concentrated on the Sales Domain, diligently working on developing and deploying domain-specific features. Likewise, distinct squads are dedicated to the Marketing and Servicing Domains. These squads function independently, allowing for swift and efficient progress, free from the need for continuous collaboration with other teams.
So far it feels like we are on the right track of realising a Microservices approach within the Salesforce platform.
Wait a moment! You might notice that the squads appear to be broadly defined, and there's merit to that observation. The breadth and definition of these teams typically vary based on the company's size and organizational structure. To gain deeper insight, let's delve into the specifics. We'll examine the more detailed and nuanced aspects of these squads' structures and operations, customizing our approach to fit the distinctive requirements and characteristics of various organizational divisions.
Below we can see a squad for Lead Management and a squad for Selling (Opportunity Management)
Recommended by LinkedIn
So far it feels like we are on the right track of realising a Microservices approach within the Salesforce platform.
Salesforce's software architecture clearly aligns with the principles of Domain-Driven Design (DDD) and microservices. This alignment creates a system that is both modular and scalable – vital for a platform of Salesforce's scale. Now, let's explore how this architecture manages and invokes workloads or functions.
In Salesforce, the key to effective architecture is domain decoupling. There are several ways to achieve this. A primary method is through native service calls within the platform, enabling efficient and independent communication among Salesforce services.
Another effective approach is utilizing REST APIs. These APIs facilitate the consumption and execution of services and can be seamlessly integrated into various events or processes. Particularly advantageous in supporting a loosely coupled architecture, REST APIs allow Salesforce components to interact flexibly, without direct dependencies. This not only preserves the modular nature of Microservices but also boosts the system's overall flexibility and resilience.
Such strategies illustrate Salesforce's capability to manage domain interactions within its Microservices architecture, ensuring that each component maintains its autonomy while being able to integrate seamlessly when needed.
The illustration serves as a blueprint, showcasing how Salesforce has adeptly embraced Domain-Driven Design (DDD) within its ecosystem to address the intricate and multifaceted needs of the banking industry.
Salesforce Communication Option Examples
Salesforce BIAN Banking Example
In this example we will use Banking Industry Architecture Network (BIAN), a global industry standard for Banking.
Native Inter-Platform Communication OR via BIAN API's
Salesforce's design philosophy shines through in its segmentation of intricate banking processes into distinct, manageable domains. Covering aspects from the initial customer interaction to credit structuring and decision-making, each domain is designed to reflect the detailed operations of financial services. This approach ensures that the system's architecture aligns closely with actual business scenarios that it aims to automate. Moreover, there is room for further decoupling within each domain and subdomain, enhancing flexibility and adaptability.
The orchestration layer in Salesforce is depicted as a central channel for data and service flows, facilitating the coordination of interactions among Microservices. It also integrates seamlessly with Salesforce's powerful APIs. The provided diagram highlights how users can utilize Salesforce's inherent features or choose to employ standardized BIAN APIs, a functionality that Salesforce has integrated into its architecture.
Inter-Platform Communication via REST API's OR via BIAN API's
Here we can see Lead Management and Opportunity Management are communication with each other via Salesforce API's or BIAN API's.
It's illustrating how Domain-Driven Design and Microservice architecture is realised in the platform. We can see that this approach aligns well with modern approaches.
Global customer such as U.S Bank with 73,000 employee, 3,000 branches in 25 states, J.P Morgan and others leading the way with their innovation and DDD approaches.
Salesforce TM Forum Telecommunications Example
The telecommunications sector, with its specific needs and challenges, provides a unique opportunity to examine the effectiveness of Salesforce's Domain-Driven Design (DDD) and microservices architecture. Similar to other industries, the concepts of modular design and autonomous service management are vital in telecommunications. This is due to the need for systems to be exceptionally scalable, adaptable, and dependable, to competently manage the intricate and ever-changing landscape of communication networks and services.
With some of the largest Telco's in the world such as Telstra leading the way.
Native Inter-Platform Communication OR via TM Forum API's
Inter-Platform Communication via REST API's OR via TM Forum API's
Let's focus our attention on a more streamlined version for clarity, using the Banking Industry Architecture Network (BIAN) as our example
The diagram illustrates a simplified model of a banking system designed with Domain-Driven Design (DDD) concepts, integrating with the Banking Industry Architecture Network (BIAN) standards.
In reality you have the three options to call services (native inter-platform execution, API's or Industry API's like BIAN, TM Forum etc).
So you can see the diagram is a testament to Salesforce's strategic foresight in adopting Domain-Driven Design and a Microservices approach.
It deftly illustrates Salesforce's ability to provide a scalable, resilient, and interoperable framework that aligns with the Banking, Telco or other industry's demand for precision, efficiency, and adherence to global standards.
Summing it up
I suggest that the architectural framework of Salesforce's platform is a prime representation of Domain-Driven Design (DDD) and Microservices, especially within the scope of SaaS. This architecture demonstrates deep understanding and effective solutions for the intricate, domain-specific challenges that are common in the banking industry.
Through careful structuring around distinct business functionalities and processes, Salesforce ensures that each microservice is dedicated to a single concern. This dedication not only simplifies maintenance but also significantly enhances scalability.
Complementing this is the establishment of distinct service boundaries and the adoption of containerization, which collectively facilitate agile and easily transferable solutions adaptable to various environments.
Salesforce adeptly showcases its capability to separate design from deployment, accelerating the development and release of features. This is achieved through autonomous teams, each concentrating on specific business areas.
Incorporating APIs that adhere to BIAN standards, TM Forum APIs, and others, Salesforce reinforces its role as a trailblazer in crafting a unified, standardized, and forward-thinking ecosystem.
At its core, Salesforce’s architecture is a testament to its commitment to agility, robustness, and interoperability – key traits of a contemporary approach.
This article aims to offer insightful perspectives on constructing decoupled systems using the Salesforce SaaS platform. The success of such projects relies heavily on the expertise of your team and the strategic methodologies, norms, and architectural designs you implement.
Thank you for investing your time in reading this article. I hope it has deepened your understanding of how Salesforce aligns with Domain-Driven Design and Microservices Architecture.
Principal Architect
1yFantastic post Malcolm Fitzgerald. It leaves me in no doubt of the need for a broader, ongoing discussion. The power and flexibility of the platform can at times lead to some solution incompatibilities with DDD, think bloated aggregates in the data model, competing transactional patterns + processes, poorly designed API contracts etc. Building awareness of how the Salesforce platform can readily deliver solutions aligned to DDD principles is tremendously important. This post is a timely contribution to that enterprise. Thanks for sharing.
Solving your Sales and Service Pain with Salesforce Expertise | Your Go-To for Salesforce Excellence
1yFantastic Architectural write up on Monolith Architecture Design, Domain-Driven Design and Microservices Architecture. It's even deeper evidence that Salesforce rocks as a PaaS Platform and SaaS solution!
Crafting Audits, Process, Automations that Generate ⏳+💸| FULL REMOTE Only | Founder & Tech Creative | 30+ Companies Guided
1yGreat analysis of Salesforce's architecture and its implementation of DDD and Microservices! 👍🏼 The examples you provided from the banking and telco sectors are very insightful. #Salesforce #architecture #tech
Salesforce for Banks
1yFantastic review and analysis Malcolm Fitzgerald and Paul Rashleigh. I've long believed this to be the case but when challenged by customers that they were microservices "shops" and Salesforce didn't fit their world view I struggled to answer with the depth they expected. Well now I can point them to this or to you. Thanks for clarifying what increasing numbers of our customers are starting to realise - ie there are not enough engineers in their market or at a volume they can afford to keep building at a highly decomposed level. This provides the rationale to increase the scope of business capabilities a Salesforce implementation can bring, without compromise, especially when the software and integration layers are being built around industry standard. This brings speed to value and future-proofing to any size of customer, often with #clicksnotcode. Thank you.
Data + AI Solution Practice | PMP®| Technical Architect @Salesforce
1yIn another form, Salesforce's architecture is loose coupling, high cohesion, and single-purpose?