Welcome!

Microservices Expo Authors: Liz McMillan, Elizabeth White, Pat Romanski, Automic Blog, Mamoon Yunus

Related Topics: Microservices Expo, @CloudExpo

Microservices Expo: Blog Feed Post

Microservices: New SOA or Buzzword? | @CloudExpo [#Microservices #API]

Microservices is a new architectural style based upon independent services

Capability Analysis
Source: English Wikipedia

Microservices is a new architectural style based upon independent services.

The terms Microservices and Microservices Architecture are often used. It is an architecture based on independent relatively small components named Micro Services.

Some people may think that Microservices Architecture is a new and improved Service Oriented Architecture (SOA). It is not.

Martin Fowler is the first name mentioned in articles about Micro Services. Fowler is a British Software Engineer specialized in Software development.

I read the article: Microservices in Fowler's Web site. I am more confused about Microservices characteristics after reading the article.

The article was written by James Lewis and Martin Fowler.

What Microservice Architecture is and what Microservice is?
The articles discussed the following characteristics of Microservice Architecture and Microservices:

1. It is a new Architectural style

OK, let's understand what is new and what is its Value Proposition.

2. "approach to developing a single application as a suite of small services"

Nothing to write home about. Remember Cool:Gen?

A leading Client/Server IDE. It was a leading Component Based Development (CBD) tool. Its first version was launch in 1987. It is easy to find other IDE tools which were available 15 years or twenty years ago and were based on CBD methodology.

The Services granularity is small, unlike the coarse grained granularity of SOA Services.

3. "each running in its own process and communicating with light weight mechanism, often an HTTP resource API."

This is a performance issue: is the Overhead of many Microservices small enough?

I am sure that for large applications it is not, unless light weight communication mechanism is used.

Similarly, REST is preferred over SOAP because of better Performance and reduced Complexity.

4. The Microservices are "independently deployable by fully automated deployment machinery"

It could be a good technical approach for Deployment and for Change Management.

5. Monolithic applications run a in a single process they are scaled by multiple instances. Each Microservice is deployed under a different process. No need to multiple instances, so Change Management is simpler and less error prawn.

Monolithic Applications are not Silo Systems or Monolithic Applications in SOA context. In this article they refer to Server Side only applications, while in SOA context they include all layers: Server as well as Clients and Middleware.

As in previous section the focus is technical. By running each Micro Process under different process, Performance could be improved and Deployment and Change Management of each Micro Service is less dependent on other Micro Services.

6. "These services are build around Business Capabilities"
Now I am really confused. How componentization of Application could be related to Business Capabilities?

Capabilities and SOA Services
Capabilities are defined as Coarse grained Business elements. Capability Analysis is used for bridging between Business Architecture and Service Oriented Architecture.

Capabilities are Business entities defining what and not How the Organization could do something Valuable.

System Analysis in Service Oriented Architecture could use Capability Analysis. After defining the Capabilities, you could map each Capability to Services i.e. according to the frequently used definition of Capabilities, a Capability is more Coarse Grained than a Service.

How could a Capacity will be related to a Fine Grained entity such as Microservice?

What is the relationship between an Inter-Application entity (Micro Service) and a Business Entity (Capability)?

I do not have adequate answers to those questions.

Even if you define Capability as a smaller Business entity mapped  Many to One to SOA Service, i.e. few capabilities included in a Service, I am still confused about its relationship to Micro Services.

It should be noted, that some companies, defined Capability as a less Coarse Grained entity than a SOA Service.

The Bottom Line
Microservice Architecture is a new architectural style using terminology and approach resembling Service Oriented Architecture. However, the scope of Micro Service Architecture is Inter-Application.

SOA scope is Enterprise and Virtual Enterprise. Virtual Enterprise may refer to Public Clouds and Hybrid Clouds, as well as other types of implementing some of the Applications or some of the Services outside the Enterprise boundaries.

SOA Services are defined by Business Services  boundaries. The alignment of Micro Services to Business Services is not well defined.

My Take
Microservice Architecture could be useful. It is a small scale SOA like Architecture within an Application. It should be compared to other approaches to defining and managing Application Components.

Service Oriented Architecture is defined in another level and is orthogonal to Inter-Application Architectural styles such as: Microservices Architecture or OMG's CBD model.

Micro Service Architecture could be useful for Agile Software Development Methodologies. It completes the methodology by adding a development and deployment style.  

More Stories By Avi Rosenthal

Ari has over 30 years of experience in IT across a wide variety of technology platforms, including application development, technology selection, application and infrastructure strategies, system design, middleware and transaction management technologies and security.

Positions held include CTO for one of the largest software houses in Israel as well as the CTO position for one of the largest ministries of the Israeli government.

@MicroservicesExpo Stories
@DevOpsSummit at Cloud Expo taking place Oct 31 - Nov 2, 2017, at the Santa Clara Convention Center, Santa Clara, CA, is co-located with the 21st International Cloud Expo and will feature technical sessions from a rock star conference faculty and the leading industry players in the world. The widespread success of cloud computing is driving the DevOps revolution in enterprise IT. Now as never before, development teams must communicate and collaborate in a dynamic, 24/7/365 environment. There is ...
With Cloud Foundry you can easily deploy and use apps utilizing websocket technology, but not everybody realizes that scaling them out is not that trivial. In his session at 21st Cloud Expo, Roman Swoszowski, CTO and VP, Cloud Foundry Services, at Grape Up, will show you an example of how to deal with this issue. He will demonstrate a cloud-native Spring Boot app running in Cloud Foundry and communicating with clients over websocket protocol that can be easily scaled horizontally and coordinate...
Docker is on a roll. In the last few years, this container management service has become immensely popular in development, especially given the great fit with agile-based projects and continuous delivery. In this article, I want to take a brief look at how you can use Docker to accelerate and streamline the software development lifecycle (SDLC) process.
DevOps at Cloud Expo, taking place October 31 - November 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA, is co-located with 21st Cloud Expo and will feature technical sessions from a rock star conference faculty and the leading industry players in the world. The widespread success of cloud computing is driving the DevOps revolution in enterprise IT. Now as never before, development teams must communicate and collaborate in a dynamic, 24/7/365 environment. There is no time to w...
In his session at 20th Cloud Expo, Scott Davis, CTO of Embotics, discussed how automation can provide the dynamic management required to cost-effectively deliver microservices and container solutions at scale. He also discussed how flexible automation is the key to effectively bridging and seamlessly coordinating both IT and developer needs for component orchestration across disparate clouds – an increasingly important requirement at today’s multi-cloud enterprise.
IT organizations are moving to the cloud in hopes to approve efficiency, increase agility and save money. Migrating workloads might seem like a simple task, but what many businesses don’t realize is that application migration criteria differs across organizations, making it difficult for architects to arrive at an accurate TCO number. In his session at 21st Cloud Expo, Joe Kinsella, CTO of CloudHealth Technologies, will offer a systematic approach to understanding the TCO of a cloud application...
API Security has finally entered our security zeitgeist. OWASP Top 10 2017 - RC1 recognized API Security as a first class citizen by adding it as number 10, or A-10 on its list of web application vulnerabilities. We believe this is just the start. The attack surface area offered by API is orders or magnitude larger than any other attack surface area. Consider the fact the APIs expose cloud services, internal databases, application and even legacy mainframes over the internet. What could go wrong...
The goal of Continuous Testing is to shift testing left to find defects earlier and release software faster. This can be achieved by integrating a set of open source functional and performance testing tools in the early stages of your software delivery lifecycle. There is one process that binds all application delivery stages together into one well-orchestrated machine: Continuous Testing. Continuous Testing is the conveyer belt between the Software Factory and production stages. Artifacts are m...
In IT, we sometimes coin terms for things before we know exactly what they are and how they’ll be used. The resulting terms may capture a common set of aspirations and goals – as “cloud” did broadly for on-demand, self-service, and flexible computing. But such a term can also lump together diverse and even competing practices, technologies, and priorities to the point where important distinctions are glossed over and lost.
In his session at @DevOpsSummit at 20th Cloud Expo, Kelly Looney, director of DevOps consulting for Skytap, showed how an incremental approach to introducing containers into complex, distributed applications results in modernization with less risk and more reward. He also shared the story of how Skytap used Docker to get out of the business of managing infrastructure, and into the business of delivering innovation and business value. Attendees learned how up-front planning allows for a clean sep...
Most companies are adopting or evaluating container technology - Docker in particular - to speed up application deployment, drive down cost, ease management and make application delivery more flexible overall. As with most new architectures, this dream takes a lot of work to become a reality. Even when you do get your application componentized enough and packaged properly, there are still challenges for DevOps teams to making the shift to continuous delivery and achieving that reduction in cost ...
Enterprise architects are increasingly adopting multi-cloud strategies as they seek to utilize existing data center assets, leverage the advantages of cloud computing and avoid cloud vendor lock-in. This requires a globally aware traffic management strategy that can monitor infrastructure health across data centers and end-user experience globally, while responding to control changes and system specification at the speed of today’s DevOps teams. In his session at 20th Cloud Expo, Josh Gray, Chie...
"At the keynote this morning we spoke about the value proposition of Nutanix, of having a DevOps culture and a mindset, and the business outcomes of achieving agility and scale, which everybody here is trying to accomplish," noted Mark Lavi, DevOps Solution Architect at Nutanix, in this SYS-CON.tv interview at @DevOpsSummit at 20th Cloud Expo, held June 6-8, 2017, at the Javits Center in New York City, NY.
We have already established the importance of APIs in today’s digital world (read about it here). With APIs playing such an important role in keeping us connected, it’s necessary to maintain the API’s performance as well as availability. There are multiple aspects to consider when monitoring APIs, from integration to performance issues, therefore a general monitoring strategy that only accounts for up-time is not ideal.
Web services have taken the development world by storm, especially in recent years as they've become more and more widely adopted. There are naturally many reasons for this, but first, let's understand what exactly a web service is. The World Wide Web Consortium (W3C) defines "web of services" as "message-based design frequently found on the Web and in enterprise software". Basically, a web service is a method of sending a message between two devices through a network. In practical terms, this ...
In his session at 20th Cloud Expo, Mike Johnston, an infrastructure engineer at Supergiant.io, discussed how to use Kubernetes to set up a SaaS infrastructure for your business. Mike Johnston is an infrastructure engineer at Supergiant.io with over 12 years of experience designing, deploying, and maintaining server and workstation infrastructure at all scales. He has experience with brick and mortar data centers as well as cloud providers like Digital Ocean, Amazon Web Services, and Rackspace. H...
All organizations that did not originate this moment have a pre-existing culture as well as legacy technology and processes that can be more or less amenable to DevOps implementation. That organizational culture is influenced by the personalities and management styles of Executive Management, the wider culture in which the organization is situated, and the personalities of key team members at all levels of the organization. This culture and entrenched interests usually throw a wrench in the work...
When you focus on a journey from up-close, you look at your own technical and cultural history and how you changed it for the benefit of the customer. This was our starting point: too many integration issues, 13 SWP days and very long cycles. It was evident that in this fast-paced industry we could no longer afford this reality. We needed something that would take us beyond reducing the development lifecycles, CI and Agile methodologies. We made a fundamental difference, even changed our culture...
As many know, the first generation of Cloud Management Platform (CMP) solutions were designed for managing virtual infrastructure (IaaS) and traditional applications. But that’s no longer enough to satisfy evolving and complex business requirements. In his session at 21st Cloud Expo, Scott Davis, Embotics CTO, will explore how next-generation CMPs ensure organizations can manage cloud-native and microservice-based application architectures, while also facilitating agile DevOps methodology. He wi...
We have Continuous Integration and we have Continuous Deployment, but what’s continuous across all of what we do is people. Even when tasks are automated, someone wrote the automation. So, Jayne Groll evangelizes about Continuous Everyone. Jayne is the CEO of the DevOps Institute and the author of Agile Service Management Guide. She talked about Continuous Everyone at the 2016 All Day DevOps conference. She describes it as "about people, culture, and collaboration mapped into your value streams....