Default HubSpot Blog

Jim Bugwadia


Recent Posts

REST is not about APIs, Part 2

[fa icon="calendar'] Nov 12, 2013 1:12:40 AM / by Jim Bugwadia posted in Engineering

[fa icon="comment"] 0 Comments

Most articles on REST seem to focus only on APIs. This view misses several key benefits of a RESTful system. The true potential of REST is to build systems as scalable, distributed, resilient, and composable as the Web. Yes, APIs play a role in this but by themselves are not enough.

In Part 1 of this article I described the 6 architectural constraints, 4 interface constraints, and 3 architectural components defined in the REST architectural style. I also detailed why the API centric view of REST merely scratches the surface.

In this final part, I will show how to apply the full REST architectural style, discuss how the benefits are achieved, and provide a way to incrementally migrate to an RESTful architecture.

Applying the basic constraints

Lets try and build a conceptual system from the REST constraints and elements. Our first attempt uses the following constraints:

  • Client – Server: separation of client and server roles

  • Stateless: externalize all data & state (including request state) from the server. We can choose some combination of NoSQL, SQL, or distributed cache data management solutions.

  • Cache: add a cache component to the client, as well as the server

  • Uniform Interface: provide a RESTful API at the server

  • Layered System: the application and data tier are separated into layers

Since we made the application server stateless, we can now add a gateway component for common request management, and scale server instances up & down behind it. The gateway could be implemented using a load balancer or a reverse proxy, and itself can scale up or down as needed. Based on the choice of data management solution, we can also replace the single server with a cluster of data management servers.

We now have a classic tiered architecture and each tier is elastic. This may be good enough for some applications. In fact most current applications use this, or a close variant of this, tiered architecture.

However, this architecture will become quickly difficult to scale and manage in a cloud. Here are a few reasons why:

  • The application server is monolithic; scaling requires deploying the entire application as a separate instance.

  • The failure domain is the entire application. A single bug, or issue, can impact the full application.

  • A single type of data tier is assumed for the entire application. In reality, different modules will need different types of data management services.

  • Incremental changes, that impact only a small set of functions, are not possible to test and manage

To solve these problems we need to further apply the REST constraints on the application tier itself.

The next step would be to further decompose the application server, into multiple RESTful services. Lets say we had two top-level modules in our application, we can make each of them a separate service. A service is now the fundamental unit of deployment and management. Each service is stateless and has its own uniform interface. Each service has its own data cache and storage tier, and these can use different types of data management technologies based on the requirements. A service can also be scaled up or down independently of other services.

The tradeoff with this architecture is that now additional services will be needed to manage the inter-service communication. We can add a service registry to allow services to lookup services. The gateway also needs more intelligence for routing requests and finding services.

Case Studies

Businesses adopting cloud computing have also adopted a RESTful distributed cloud services architecture. Here are a few examples:

  • Netflix transitioned from monolithic tiers to a cloud services approach. They have open-sourced their service registry (Eureka), gateway (Zuul) and several other components. Their engineering blog and the Netflix OSS GitHub repository are great resources.
  • LinkedIn made the transition from monolithic application to distributed services. This InfoQ presentation from Jay Krepps is a great overview.
  • Twitter switched from what they called a “monorails” application to distributed JVM based services. Jeremy Cloud discusses this in an InfoQ presentation, “Decomposing Twitter”.
  • Amazon has not directly presented this, but there are reports of their architecture based on internal APIs and services.
  • Yammer also uses a distributed services based approach, and has open sources a tool called DropWizard to aid in building RESTful Java services.

Applying to Existing Systems

If you are like most developers, it may seem like a stretch to even consider making bold changes to your system to move towards a RESTful architecture. However, the fine-grained services approach has another key advantage. You can leverage the emphasis on modularity to incrementally transform a monolithic application to a cloud services architecture.

You can select an existing module, or when its time to build a new module, built it as a library which can be run as part of your monolithic application or as a separate service.

Summary

If your goal is to build an elastic & composable system - like the internet, you need to learn more than the ‘uniform interface’ constraint in REST. In this article we applied all five required REST constraints, and used different architectural elements to build an elastic architecture where an application is composed of multiple RESTful services. This architecture yields several benefits, and most importantly enables continuous delivery of software. Now small, autonomous DevOps teams can build and manage individual services and get direct feedback on usage! Enterprises can incrementally adopt this architecture by migrating modules in a monolithic application.

Read More [fa icon="long-arrow-right"]

REST is not about APIs, Part 2

[fa icon="calendar'] Nov 12, 2013 1:12:40 AM / by Jim Bugwadia posted in REST, Engineering, Cloud Architecture

[fa icon="comment"] 0 Comments

Most articles on REST seem to focus only on APIs. This view misses several key benefits of a RESTful system. The true potential of REST is to build systems as scalable, distributed, resilient, and composable as the Web. Yes, APIs play a role in this but by themselves are not enough.

In Part 1 of this article I described the 6 architectural constraints, 4 interface constraints, and 3 architectural components defined in the REST architectural style. I also detailed why the API centric view of REST merely scratches the surface.

In this final part, I will show how to apply the full REST architectural style, discuss how the benefits are achieved, and provide a way to incrementally migrate to an RESTful architecture.

Applying the basic constraints

Lets try and build a conceptual system from the REST constraints and elements. Our first attempt uses the following constraints:

  • Client – Server: separation of client and server roles

  • Stateless: externalize all data & state (including request state) from the server. We can choose some combination of NoSQL, SQL, or distributed cache data management solutions.

  • Cache: add a cache component to the client, as well as the server

  • Uniform Interface: provide a RESTful API at the server

  • Layered System: the application and data tier are separated into layers

Since we made the application server stateless, we can now add a gateway component for common request management, and scale server instances up & down behind it. The gateway could be implemented using a load balancer or a reverse proxy, and itself can scale up or down as needed. Based on the choice of data management solution, we can also replace the single server with a cluster of data management servers.

We now have a classic tiered architecture and each tier is elastic. This may be good enough for some applications. In fact most current applications use this, or a close variant of this, tiered architecture.

However, this architecture will become quickly difficult to scale and manage in a cloud. Here are a few reasons why:

  • The application server is monolithic; scaling requires deploying the entire application as a separate instance.

  • The failure domain is the entire application. A single bug, or issue, can impact the full application.

  • A single type of data tier is assumed for the entire application. In reality, different modules will need different types of data management services.

  • Incremental changes, that impact only a small set of functions, are not possible to test and manage

To solve these problems we need to further apply the REST constraints on the application tier itself.

The next step would be to further decompose the application server, into multiple RESTful services. Lets say we had two top-level modules in our application, we can make each of them a separate service. A service is now the fundamental unit of deployment and management. Each service is stateless and has its own uniform interface. Each service has its own data cache and storage tier, and these can use different types of data management technologies based on the requirements. A service can also be scaled up or down independently of other services.

The tradeoff with this architecture is that now additional services will be needed to manage the inter-service communication. We can add a service registry to allow services to lookup services. The gateway also needs more intelligence for routing requests and finding services.

Case Studies

Businesses adopting cloud computing have also adopted a RESTful distributed cloud services architecture. Here are a few examples:

  • Netflix transitioned from monolithic tiers to a cloud services approach. They have open-sourced their service registry (Eureka), gateway (Zuul) and several other components. Their engineering blog and the Netflix OSS GitHub repository are great resources.
  • LinkedIn made the transition from monolithic application to distributed services. This InfoQ presentation from Jay Krepps is a great overview.
  • Twitter switched from what they called a “monorails” application to distributed JVM based services. Jeremy Cloud discusses this in an InfoQ presentation, “Decomposing Twitter”.
  • Amazon has not directly presented this, but there are reports of their architecture based on internal APIs and services.
  • Yammer also uses a distributed services based approach, and has open sources a tool called DropWizard to aid in building RESTful Java services.

Applying to Existing Systems

If you are like most developers, it may seem like a stretch to even consider making bold changes to your system to move towards a RESTful architecture. However, the fine-grained services approach has another key advantage. You can leverage the emphasis on modularity to incrementally transform a monolithic application to a cloud services architecture.

You can select an existing module, or when its time to build a new module, built it as a library which can be run as part of your monolithic application or as a separate service.

Summary

If your goal is to build an elastic & composable system - like the internet, you need to learn more than the ‘uniform interface’ constraint in REST. In this article we applied all five required REST constraints, and used different architectural elements to build an elastic architecture where an application is composed of multiple RESTful services. This architecture yields several benefits, and most importantly enables continuous delivery of software. Now small, autonomous DevOps teams can build and manage individual services and get direct feedback on usage! Enterprises can incrementally adopt this architecture by migrating modules in a monolithic application.

Read More [fa icon="long-arrow-right"]

Introducing Nirmata

[fa icon="calendar'] Sep 30, 2013 2:45:16 AM / by Jim Bugwadia posted in Product

[fa icon="comment"] 0 Comments

My co-founders and I started Nirmata to transform software development & operations, and make better software. We believe that a new approach to software development is necessary as the demand for software continues to grow, and as software architecture and development is being significantly affected by three major trends:

  1. Cloud Computing
  2. Apps over Applications
  3. Software-defined Everything

Trend #1: Cloud Computing

As businesses are adopting cloud computing to replace traditional data centers, software applications now need to operate in a new environment. Current software was designed for environments where resources are manually allocated (typically over-allocated) and carefully managed. This approach does not work in a cloud. Migrating existing applications to a cloud causes fixed usage at peak-load requirements of leased resources. Also, applications that are deployed as a single monolithic runtime unit (e.g. the app tier of a JEE Web App) will create operational complexity in a cloud environment, as they are not designed to handle failures or scale in a granular manner.

“Unfortunately, without the proper architecture, there's a very real risk that Cloud Computing won't live up to its promise or in some situations will fail outright.” -- Bloomberg, Jason (2013-01-23). The Agile Architecture Revolution

Software that needs to run in a cloud requires a different architecture. Additional drivers for this new architecture are mobile computing, big data, the internet of things, and software-defined data centers.

It is important to note that although cloud computing disables existing software architectures, it also enables a new delivery model for software designed to operate in clouds.

Trend #2: Apps over Applications

It has been estimated that 80% of features in enterprise software applications are typically unused. Thanks to the smart phone, a new model has taken hold, and consumers are getting hooked on simpler software “apps”, instead of bloated, complex enterprise software. The "app" approach also affects backend (server-side) software architectures, as well as software development and operations. Large, monolithic software applications are being re-written as easy-to-use, focused, and co-operating services that run on a common platform.

Trend #3: Software-defined Everything

As more and more devices, even entire data centers, are becoming software-defined a new layer of software applications is needed to control and manage these devices. Application software will rely on platforms, controllers, and policy engines that manage the underlying devices. These special purpose software infrastructure components will be required to run in public and private clouds.

What will Nirmata Provide?

Nirmata provides a platform for development and operations of cloud native applications. With the Nirmata Platform, an application is designed as a set of loosely coupled cloud services. Each cloud service has pluggable modules for common features such as uniform APIs, security, metrics, etc. The Nirmata Platform also provides common services for service discovery and registration, data management, and auto-scaling. With Nirmata's solution, a cloud service becomes the fundamental unit of development & operations. This architecture provides several key benefits, such as the ability to version, scale and deploy individual services. New applications can now be composed by using existing services.

We are just getting started at Nirmata. If you are building cloud applications and would like to learn more about the Nirmata Platform, we would love to hear from you.

Summary

To summarize, I would like to quote Jan Bosch, who "nails it" in his presentations:

  • Increasing SPEED trumps ANY other improvement R&D can provide to the company – the goal is continuous deployment of new functionality
  • Teams should be small, multi-disciplinary, self-selected and -directed, use data (not opinions) for decision making and optimize quantitative output metrics
  • Software architecture is central in allowing for independent, continuous deployment to customers

At Nirmata, our goal is to enable rapid development of complex software. Software built using Nirmata will allow small autonomous DevOps teams to deliver and control incremental code changes. Nirmata enables businesses to move from 1-2 software releases per year to a continuous delivery model.

-----

Jim Bugwadia

Follow us on Twitter @NirmataCloud

 

References

Read More [fa icon="long-arrow-right"]

Introducing Nirmata

[fa icon="calendar'] Sep 30, 2013 2:45:16 AM / by Jim Bugwadia posted in Cloud Services Platform, Product, Cloud Architecture

[fa icon="comment"] 0 Comments

My co-founders and I started Nirmata to transform software development & operations, and make better software. We believe that a new approach to software development is necessary as the demand for software continues to grow, and as software architecture and development is being significantly affected by three major trends:

  1. Cloud Computing
  2. Apps over Applications
  3. Software-defined Everything

Trend #1: Cloud Computing

As businesses are adopting cloud computing to replace traditional data centers, software applications now need to operate in a new environment. Current software was designed for environments where resources are manually allocated (typically over-allocated) and carefully managed. This approach does not work in a cloud. Migrating existing applications to a cloud causes fixed usage at peak-load requirements of leased resources. Also, applications that are deployed as a single monolithic runtime unit (e.g. the app tier of a JEE Web App) will create operational complexity in a cloud environment, as they are not designed to handle failures or scale in a granular manner.

“Unfortunately, without the proper architecture, there's a very real risk that Cloud Computing won't live up to its promise or in some situations will fail outright.” -- Bloomberg, Jason (2013-01-23). The Agile Architecture Revolution

Software that needs to run in a cloud requires a different architecture. Additional drivers for this new architecture are mobile computing, big data, the internet of things, and software-defined data centers.

It is important to note that although cloud computing disables existing software architectures, it also enables a new delivery model for software designed to operate in clouds.

Trend #2: Apps over Applications

It has been estimated that 80% of features in enterprise software applications are typically unused. Thanks to the smart phone, a new model has taken hold, and consumers are getting hooked on simpler software “apps”, instead of bloated, complex enterprise software. The "app" approach also affects backend (server-side) software architectures, as well as software development and operations. Large, monolithic software applications are being re-written as easy-to-use, focused, and co-operating services that run on a common platform.

Trend #3: Software-defined Everything

As more and more devices, even entire data centers, are becoming software-defined a new layer of software applications is needed to control and manage these devices. Application software will rely on platforms, controllers, and policy engines that manage the underlying devices. These special purpose software infrastructure components will be required to run in public and private clouds.

What will Nirmata Provide?

Nirmata provides a platform for development and operations of cloud native applications. With the Nirmata Platform, an application is designed as a set of loosely coupled cloud services. Each cloud service has pluggable modules for common features such as uniform APIs, security, metrics, etc. The Nirmata Platform also provides common services for service discovery and registration, data management, and auto-scaling. With Nirmata's solution, a cloud service becomes the fundamental unit of development & operations. This architecture provides several key benefits, such as the ability to version, scale and deploy individual services. New applications can now be composed by using existing services.

We are just getting started at Nirmata. If you are building cloud applications and would like to learn more about the Nirmata Platform, we would love to hear from you.

Summary

To summarize, I would like to quote Jan Bosch, who "nails it" in his presentations:

  • Increasing SPEED trumps ANY other improvement R&D can provide to the company – the goal is continuous deployment of new functionality
  • Teams should be small, multi-disciplinary, self-selected and -directed, use data (not opinions) for decision making and optimize quantitative output metrics
  • Software architecture is central in allowing for independent, continuous deployment to customers

At Nirmata, our goal is to enable rapid development of complex software. Software built using Nirmata will allow small autonomous DevOps teams to deliver and control incremental code changes. Nirmata enables businesses to move from 1-2 software releases per year to a continuous delivery model.

-----

Jim Bugwadia

Follow us on Twitter @NirmataCloud

 

References

Read More [fa icon="long-arrow-right"]

The Nirmata Story

[fa icon="calendar'] Sep 1, 2013 2:40:36 AM / by Jim Bugwadia posted in Business

[fa icon="comment"] 0 Comments

Nirmata means architect or maker in Hindi. We created Nirmata to transform software development & operations, and make better software.

Read More [fa icon="long-arrow-right"]

The Nirmata Story

[fa icon="calendar'] Sep 1, 2013 2:40:36 AM / by Jim Bugwadia posted in Business

[fa icon="comment"] 0 Comments

Nirmata means architect or maker in Hindi. We created Nirmata to transform software development & operations, and make better software.

Read More [fa icon="long-arrow-right"]

Subscribe to Email Updates

Recent Posts