- Mastering Microservices with Java
- Sourabh Sharma
- 399字
- 2021-07-02 13:03:28
Problems in adopting new technologies
Monolithic applications are mostly developed and enhanced based on the technologies primarily used during the initial development of a project or a product. This makes it very difficult to introduce new technology at a later stage of development or once the product is in a mature state (for example, after a few years). In addition, different modules in the same project that depend on different versions of the same library make this more challenging.
Technology is improving year on year. For example, your system might be designed in Java and then, a few years later, you may want to develop a new service in Ruby on Rails or Node.js because of a business need or to utilize the advantages of new technologies. It would be very difficult to utilize the new technology in an existing monolithic application.
It is not just about code-level integration, but also about testing and deployment. It is possible to adopt a new technology by rewriting the entire application, but it is a time-consuming and risky thing to do.
On the other hand, because of its component-based development and design, microservices architectures give us the flexibility to use any technology, new or old, for development. They do not restrict you to using specific technologies, and give you a new paradigm for your development and engineering activities. You can use Ruby on Rails, Node.js, or any other technology at any time.
So, how is this achieved? Well, it's very simple. Microservices-based application code does not bundle into a single archive and is not stored in a single directory. Each μService has its own archive and is deployed separately. A new service could be developed in an isolated environment and could be tested and deployed without any technical issues. As you know, microservices also own their own separate processes, serving their purpose without any conflicts to do with things such as shared resources with tight coupling, and processes remain independent.
Monolithic systems does not provide flexibility to introduce new technology. However, introduction of new technology comes as low risk features in microservices based system because by default these small and self contained components.
You can also make your microservice available as open source software so it can be used by others, and, if required, it may interoperate with a closed source, a proprietary one, which is not possible with monolithic applications.
- Puppet 4 Essentials(Second Edition)
- Dependency Injection in .NET Core 2.0
- iOS開發(fā)實(shí)戰(zhàn):從零基礎(chǔ)到App Store上架
- iOS應(yīng)用逆向工程(第2版)
- The Complete Coding Interview Guide in Java
- Mastering ArcGIS Enterprise Administration
- R語言數(shù)據(jù)可視化:科技圖表繪制
- Docker:容器與容器云(第2版)
- Java程序設(shè)計(jì)教程
- MongoDB Administrator’s Guide
- 算法精解:C語言描述
- Python滲透測(cè)試編程技術(shù):方法與實(shí)踐(第2版)
- C#網(wǎng)絡(luò)編程高級(jí)篇之網(wǎng)頁游戲輔助程序設(shè)計(jì)
- 多接入邊緣計(jì)算實(shí)戰(zhàn)
- Learning Predictive Analytics with R