官术网_书友最值得收藏!

Origin of microservices

The term microservices was used for the first time in mid-2011 at a workshop on software architects. In March 2012, James Lewis presented some of his ideas about microservices. By the end of 2013, various groups from the IT industry started having discussions about microservices, and by 2014, they had become popular enough to be considered a serious contender for large enterprises.

There is no official introduction available for microservices. The understanding of the term is purely based on the use cases and discussions held in the past. We will discuss this in detail, but before that, let's check out the definition of microservices as per Wikipedia (https://en.wikipedia.org/wiki/Microservices), which sums it up as:

"Microservices is a specialization of and implementation approach for SOA used to build flexible, independently deployable software systems."

In 2014, James Lewis and Martin Fowler came together and provided a few real-world examples and presented microservices (refer to http://martinfowler.com/microservices/) in their own words and further detailed it as follows:

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

It is very important that you see all the attributes Lewis and Fowler defined here. They defined it as an architectural style that developers could utilize to develop a single application with the business logic spread across a bunch of small services, each having their own persistent storage functionality. Also, note its attributes—it can be independently deployable, can run in its own process, is a lightweight communication mechanism, and can be written in different programming languages.

We want to emphasize this specific definition since it is the crux of the whole concept. And as we move along, it will come together by the time we finish this book.

主站蜘蛛池模板: 遂宁市| 蛟河市| 怀柔区| 上饶县| 夹江县| 保亭| 华安县| 竹溪县| 正安县| 荣昌县| 揭阳市| 肇庆市| 泰州市| 玛曲县| 芦山县| 福清市| 岳阳县| 大同县| 惠来县| 手游| 泰和县| 志丹县| 绥芬河市| 天柱县| 天气| 商都县| 双峰县| 府谷县| 佛教| 黄大仙区| 崇义县| 景洪市| 牙克石市| 黄浦区| 大石桥市| 婺源县| 龙井市| 浙江省| 新巴尔虎左旗| 成都市| 峡江县|