Let's explore why it is Not.
DALL-E

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:

  1. Scalability Issues: Monolithic applications are difficult to scale selectively. When only part of the application faces high demand, the entire system often requires scaling, necessitating a complete redeployment.
  2. Complexity and Modularity Deficit: Growth in monolithic applications heightens complexity and hinders updates. The entangled codebase makes it hard to isolate and reuse components or address issues without impacting the entire system.
  3. Deployment and Rollback Delays: New version deployments are cumbersome, as the whole application must be re-deployed for any update, large or small. This also complicates rollbacks in the event of failures, often requiring a full reversion to prior versions.
  4. Troubleshooting Challenges: The complexity of monolithic applications can obscure the source of issues, leading to extended downtimes and slower resolutions.
  5. Heavy Dependency Structure: Monolithic applications often have a large number of third-party dependencies along with interconnectivity, increasing the risk of bugs and security vulnerabilities. The tightly coupled nature of these dependencies means that updating or patching even a minor component may require a full application redeployment.
  6. Technological Rigidity: The singular structure of monolithic architectures restricts technological integration and evolution. Significant changes can necessitate substantial investment and overhaul.
  7. Reliability Issues: Faults in any segment of a monolith could jeopardize overall application availability, unlike in Microservices architecture, where services function independently.

Despite Microservices' rising popularity, monolithic architecture retains key benefits, particularly suited to certain development contexts:

  1. Simplicity: Monolithic architectures offer simplicity in development, testing, and deployment, thanks to a unified codebase that streamlines processes. In contrast to Microservices, which involve managing multiple services, monolithic applications consolidate functions into a single entity, facilitating development and deployment.
  2. Performance: In a monolithic applications share memory space and infrastructure, promoting faster interactions than the inter-service communication found in Microservices.
  3. Consistency: Monoliths provide a uniform look and feel throughout, benefiting smaller applications or teams desiring a cohesive user experience. (Encore).
  4. Ease of Testing and Debugging: Testing monolithic architectures is generally more straightforward due to the centralized codebase, which also simplifies debugging by centralizing the code
  5. Defined Boundaries and Direct Communication: Monolithic applications' clear boundaries aid in understanding and managing the system. Internal communications occur directly within the application, without the need for the complex inter-service designs required by Microservices.
  6. Operational Overhead: Monoliths often incur less operational overhead compared to Microservices, avoiding the complexity of deployment orchestration and inter-service communication.
  7. Security: While both architectures have their security challenges, monolithic applications might be secured more readily due to their less complex nature, potentially reducing the risk of breaches.

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:

  1. Single Concern: Each microservice should concentrate on one function or business capability. This focus simplifies maintenance and scalability.
  2. Discrete and Transportable: Microservices have clear boundaries and are often containerized for easy transport across different environments.
  3. Data Ownership: Each microservice manages its own data, leading to easier schema updates and data isolation.
  4. Statelessness and Independence: Microservices should be stateless, handling requests without relying on previous communications. They should also function independently, though they may collaborate with others.
  5. Domain-Driven Design (DDD): This approach involves designing systems to reflect real-world domains, aligning closely with business functions and interactions.
  6. Small, Focused Teams: Teams responsible for microservices should be small to enhance agility and productivity.
  7. Fault Isolation: Issues in one microservice should not impact the entire application, achieved through patterns like Circuit Breakers.
  8. Decentralization: Microservices maintain their own data copies, promoting autonomous operation and reducing dependency conflicts.
  9. Process Automation: Emphasizing DevOps culture and tools like CI/CD pipelines, Microservices architecture encourages automation in deployment and operations.
  10. Scalability: Microservices can be scaled independently, allowing efficient resource utilization.
  11. Inter-Service Communication: Utilizing APIs, microservices communicate in a loosely coupled manner, accommodating different technology stacks.
  12. Monitoring and Continuous Improvement: Continuous monitoring is crucial due to the distributed nature of Microservices, enabling proactive management of system health and performance.


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)
Microservice Architecture. 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:

  1. Emphasis on Bounded Contexts: In DDD, a bounded context is a central concept that defines clear boundaries for a model or domain. This aligns with microservices architecture, where services are designed to be autonomous and self-contained within their boundaries. Microservices benefit from DDD by getting real boundaries, allowing for specialized models for distinct problems.
  2. Aggregates and Consistency Boundaries: DDD uses aggregates to define consistency boundaries around entities. This concept is essential in Microservices, where each service should be responsible for its own data and consistency. Aggregates ensure transactional integrity, particularly important in distributed systems like Microservices, where traditional database transactions may not be feasible.
  3. Decomposition and Ownership: DDD's influence on Microservices is evident in the decomposition of systems into distributed services built around business domain capabilities. This decomposition facilitates the formation of teams that can independently and autonomously own a domain capability. This is crucial for Microservices, which thrive on decentralized data ownership and domain-oriented decomposition.
  4. Strategic Design for Identifying Microservices: Strategic Domain-Driven Design helps in identifying logical boundaries for individual microservices. The boundaries act as natural barriers, protecting models inside each bounded context, which in turn represents an opportunity to implement Microservices.
  5. Handling Domain Complexity: DDD is particularly beneficial for complex domains, where the model provides clear benefits in formulating a common understanding of the domain. This is akin to Microservices, where complex systems are broken down into smaller, manageable services.
  6. Creating Isolation Between Services: Microservices can help create isolation between well-designed and poorly designed services. This isolation is a key benefit of applying DDD in Microservices architecture, as it prevents poorly designed services from affecting the entire system.
  7. Technology-Agnostic Models: DDD models are technology-agnostic, focusing on the subdomain rather than the underlying technology stack. This aligns with Microservices, where each service can use the technology stack that best suits its needs.


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:

  1. Single Concern: In Salesforce, objects and applications are often designed around specific business functions or processes, aligning with the principle of single concern in Microservices. For example, objects like Account or Contact in Salesforce are focused on specific areas (customer management, interaction tracking) and are not overloaded with unrelated functionalities.
  2. Discrete and Transportable: Salesforce components are discrete, with clear boundaries defined by their metadata structure. While not containerized for engineers to monitor like typical Microservices due to it's a hosted SaaS, Salesforce components can be packaged and transported across environments using tools like change sets or Salesforce DX, offering a degree of portability and an advantage is Salesforce takes care of the hosting and elastic scaling for you.
  3. Data Ownership: Each object in Salesforce owns its data schema, with fields and records that are specific to that object, process, event etc. This is akin to the Microservices principle where each service manages its own data, thus enabling easier updates and isolation.
  4. Statelessness and Independence: Salesforce's stateless architecture, particularly in its API interactions, mirrors the statelessness of Microservices. Each API call to Salesforce is independent and doesn’t rely on the state of previous calls, allowing for scalable and robust integrations. That said, you also have the advantage of maintaining state very easily if required.
  5. Domain-Driven Design: Salesforce encourages a domain-driven design, where the architecture is modeled around the business domain and structure out-of-the-box already provides this. This is evident in the way Salesforce can be customized to mirror an organization's specific processes and terminologies.
  6. Small, Focused Teams: Salesforce supports the development approach involving small, focused teams, especially through its declarative tools and low-code options, allowing teams to build and manage specific aspects of the Salesforce application without needing extensive programming skills and testing the entire platform. Squads can configure and deploy features when they are ready without worrying about other teams. An advantage users have is the business can focus on building features for customers and employee vs having to worry about any hosting or scaling.
  7. Fault Isolation: Salesforce's governor and execution limits prevent runaway processes, acting similarly to a circuit breaker in Microservices. This ensures that one failing process doesn’t impact the overall system stability.
  8. Decentralization: Salesforce's multitenant architecture supports decentralization. Each tenant (or org) operates independently with its own configuration and data, akin to how Microservices maintain their own data and configurations. Further, it's internal architecture allows teams to create domain bounded context to eliminate tightly coupled components allowing workload to be deployed when ready without tightly coupling.
  9. Process Automation: Salesforce has built-in process automation capabilities (like Flow Workflow Rules, Process Builder etc.) and supports CI/CD practices for deployment automation, which aligns with the Microservices emphasis on DevOps and automation. process can be designed and managed independently within their domain's context. An advantage is the rich toolset user have to compose their Microservice based processes if required.
  10. Scalability: Salesforce’s cloud-based, multitenant architecture allows for scalability. Resources are allocated and scaled as per the demand of each tenant, similar to how individual Microservices can be scaled. An advatage is Salesforce hosts and manages it for users so organisations can foucs on creating velocity and value.
  11. Inter-Service Communication: Salesforce’s robust API framework enables seamless communication between different Salesforce components and external systems, reflecting the Microservices principle of loose coupling through APIs. You can executes things using the internal platform communication, OR, you can call other Salesforce objects etc. via API's therefore fully decoupling the platform even further and aligning to both Microservices and Domain-Driven Design principals, architecture and patterns. An advantage is where required, inter-platform communication will be quicker and provide lower latency.
  12. Monitoring and Continuous Improvement: Salesforce provides comprehensive monitoring tools and various reporting features. These tools enable continuous monitoring and improvement, a critical aspect of maintaining Microservices.

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.
Salesforce Decouple Domain Example. by Paul Rashleigh.

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.

Salesforce Decouple Domain Example with Squads. by Malcolm Fitzgerald & Paul Rashleigh.
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)

Salesforce Decouple Domain Example with Squads. by Malcolm Fitzgerald & Paul Rashleigh.
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.

Illustration of DDD & Microservices for BAIN. by Malcolm Fitzgerald & Paul Rashleigh.

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.

Illustration of DDD & Microservices for BAIN. by Malcolm Fitzgerald & Paul Rashleigh.

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.

Telstra: 20,000 FRONTLINE AGENTS ENABLED WITH SALESFORCE FOR A SINGLE VIEW OF THE CUSTOMER

Native Inter-Platform Communication OR via TM Forum API's

Illustration of DDD & Microservices for TM Forum. by Paul Rashleigh.

Inter-Platform Communication via REST API's OR via TM Forum API's

Illustration of DDD & Microservices for TM Forum. by Paul Rashleigh.

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.

Illustration of decoupled platform components communicating via REST API. by Malcolm Fitzgerald & Paul Rashleigh.

  • User Interface (UI): The top layer represents the customer journey UI, where interactions like initial customer contact and needs analysis take place. This could be a Salesforce interface or a different platform, allowing users to input data and manage applications.
  • API Layer: Illustrating domain connectivity through a REST API Layer (for example)
  • Domains (DDD): At the bottom, each domain (e.g., Lead, Opportunity, Customer Onboarding) focuses on specific banking functions like pricing, opportunity management, and Know Your Customer (KYC) processes. These domains are designed to operate independently but are interconnected through the API orchestration layer.
  • BIAN Integration: On the left side, BIAN's role is emphasized, showing its integration points into the systems, ensuring that banking operations align with industry standards. For example Leads can be consumed via the BIAN API.
  • APIs: The diagram also highlights the REST API integration for external communication and the use of BIAN's own APIs, ensuring a standardized and open approach to banking software architecture.

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.

DDD & Microservice & Salesforce Alignment. by Malcolm Fitzgerald.

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.

Fantastic 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.

Scott Ohlund

Solving your Sales and Service Pain with Salesforce Expertise | Your Go-To for Salesforce Excellence

1y

Fantastic 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!

Yassine Fatihi 🟪

Crafting Audits, Process, Automations that Generate ⏳+💸| FULL REMOTE Only | Founder & Tech Creative | 30+ Companies Guided

1y

Great 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

Rory Walker

Salesforce for Banks

1y

Fantastic 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.

Lan Hua

Data + AI Solution Practice | PMP®| Technical Architect @Salesforce

1y

In another form, Salesforce's architecture is loose coupling, high cohesion, and single-purpose?

To view or add a comment, sign in

More articles by Malcolm Fitzgerald

Insights from the community

Others also viewed

Explore topics