What are the requirements of resource management and SLA management for the microservices?

requirements of resource management and SLA management for the micro services by Citta
Categorized : Cloud Computing Tagged :

What are the requirements of resource management and SLA management for the microservices?

External cloud resource administrators use various tools and interfaces to configure and manage cloud-based IT resources (Lin, Lin, & Huang, 2016). A remote administration system offers vital tools to such administrators to manage cloud-based IT resources. For resource management and SLA management, a portal needs to be established through a remote administration system which would provide the necessary access for administration (Zirkelbach, Krause, & Hasselbring, 2018). 

Two types of primary portals need to be established with a remote administration system for the purpose. These are as follows: 

Usage and Administration Portal

This is a general-purpose portal that can centralize administration controls to a wide range of cloud-based IT resources. A major benefit of this portal is that it can also offer IT resource usage reports. 

Self-Service Portal

This is basically a shopping portal that facilitates cloud consumers to search an up-to-date list of cloud services and IT resources that are generally offered by a cloud provider for lease. The cloud consumer has to submit items chosen by him to the cloud provider for the purpose of provisioning (Taibi, Lenarduzzi, & Pahl, 2017). 

There are some critical points that need to be taken into cognizance before adopting a microservice approach. These have been discussed below: 

1. The first thing which needs to be considered is the degree of independence of the services (Jamshidi, Pahl, Mendonça, Lewis, & Tilkov, 2018). 

There are two scenarios here to choose from. Either each service is completely independent with its own database and user interface or some components like the database can be shared. The first scenario is that of an extreme microservices architecture where the services share nothing and are completely decoupled. In the second scenario, it is much easier to maintain standards across all the teams and ensure consistency across all the services. 

In the first case, the team for each microservice can choose a particular database according to its requirements. However, in this scenario, it would be really difficult to ensure that all the data stores are consistent and synchronized. Apart from this, various tasks related to database management such as backing up need to replicate by each team. The disadvantage of sharing some of the components is that if a table or something like it is updated then it would affect the other services as well (Cerny, Donahoo, & Trnka, 2018). This is because the services are not completely decoupled. 

2. The second thing is to organize the code-base. Here also two things are possible. Either a separate repository for each service can be created or there can be a single mono-repository for all the services which would have a separate folder for each service. 

3. Each microservice is a monolithic application for which a separate technology stack has to be chosen. The option which appears attractive in theory can be really troublesome in practice if the services are heterogeneous. Standardization would also be difficult if each team uses a separate stack. Moreover, it would also be difficult to shift between the teams in such a case. The best thing would be to have a default stack across the application and if a particular team wants to override that stack they should do so after prior justification (Mustafa, Gómez, Hamed & Pargmann, 2018). 

4. The microservice approach increases the complexity of operations as they have to be conceived from scratch. The consumer has to take important decisions regarding infrastructure, load balancing and scaling, service discovery, and monitoring. He should be prepared to face the complexities.

5. For the proper development, implementation, and management of the microservices it would be necessary to designate a separate team for each microservice as it would not be possible for a single specialist to work on different microservices. 

These are the requirements that have to be considered by Citta Solutions to conduct remote administration, resource management, and SLA management to adopt the microservice approach. 

Recommendations for Citta Solutions

A. Description About the steps for planning the migration of the services

 following steps can be followed by Citta Solutions to migrate to microservices:

The first step is to revisit the Java application packaging structure and adopt new packaging structures before changing the codes. Earlier we used to build large EAR files for our logical applications. Those EAR files were then placed across each and every web sphere application server. This resulted in the attachment of each code in that application to the same deployment schedules and physical servers. To change something, it had to be retested which made the entire process too expensive. But the scenario has changed now and three principles need to be taken into cognizance while repackaging. Instead of packaging all the related WARs into one EAR file, they should be separated. Next is to deploy each WAR in its separate containers which can be scaled separately. Once the WARs are split, they can be managed independently by using an automated DevOps pipeline. It is also advantageous to build, deploy and manage each WAR independently. 

The next step is to refractor the WARs to basic levels. In this way, the code can be refactored to accommodate a packaging approach that facilitates the packaging of each microservice independently. One may use services that are compatible with a microservices architecture or which could be made compatible. Another option is to refactor services design which is functionally based on assets-based services design. Then the domain objects should be identified by applying domain-driven designs. This will help to identify the domain services layer. After the new service is packaged in its own WAR, a totally new interface can be developed. It is important to adopt REST which is a standard protocol for service access (Pigazzini, Fontana & Maggioni, 2019). 

The most difficult challenge which is faced while adopting Micro-Services is to refactor the data structures on which the applications are built. There are two things that can be followed in such scenarios:

One thing that is common to all mapping systems related to objects is reference data is combined in a table which is sucked in an in-memory cache. Generally, the elements of reference data are continuously read not regularly updated. This kind of data is generally used to substantiate dropdowns in the graphical user interface. The usual pattern is to first read the list from a table each time it is required. But this pattern works in a prohibitive way. So the system reads it into an in-memory cache such as cache at start-up. The reference data is generally independent of the rest of the database structure or is loosely coupled. In such a case the data and its services should be split away from the rest of the system.

The next thing is to follow the principle of master data management which implies that one should not have more than one view of an important concept like a ‘customer’ in an enterprise. The master data management tools help one to combine the different views of an idea so that there is no repetition. The only variance is that MDM solutions are not API-centric but are data-centric. The centralized APIs should be considered as the basis of the multi-services approach in which implementation is done in a separate tool. The code should be split out into services that function on a similar database so that the resultant codes are easy to manage. Another thing to remember is that independent tables and blob storage should be used as a part of data architecture. 

requirements of resource management and SLA management for the microservices by Citta

Migration to a microservices approach
(Source: Zirkelbach, Krause & Hasselbring, 2018)


B. Critical points and issues associated with the steps and the reasons that those points and issues are critical 

Some of the critical issues which occur at the above-mentioned steps are discussed below:

The first issue is that of rehosting. In some high-profile migration scenarios, some organizations look to migrate or rescale in a short period of time to meet their business requirements. In such a case the majority of the applications are rehosted which can be easily automated using tools such as AWS SMS. it is easy to change the architecture of an application that is already running in the cloud. This is mainly because of two reasons. The first one is that the organization has already developed superior skills and the second reason is that the application, data, and traffic have already been migrated. 

The second issue is that of changing the platform. This involves cloud optimization to obtain tangible results without altering the core architecture of the application. 

The next issue is that of repurchasing. This refers to the decision of an organization to shift to a different product which entails a change in the licensing model used hitherto. In the case of those workloads which can be easily upgraded, it can result in the up-gradation of a particular feature and smoother application. 

The fourth issue is that of refactoring or change of the architecture. Generally, the motivation behind changing the architecture is to add new features or increase the scale of the business which can be difficult in the current ambiance of the application. If the organization is aiming to increase mobility through shifting to a service-oriented architecture then refactoring can be highly beneficial. But it should be remembered that this is the most expensive solution (Cerny, Donahoo & Trnka, 2018). 

The next issue is that of retiring. An organization should look do away with those IT resources which are no longer used in the business and look to focus on those resources which are relevant and used regularly. 

The last issue is that of retaining parts of the IT portfolio that are not suitable for migration. Such applications are kept on the premises.

Conclusion 

In addition to it, Citta Solutions should also look to make improvements in its technologies regularly to provide quality service to its customers. At the same time, the company officials need to be very careful in adopting new ways of securing its important as well as essential data from being misused. In this context, it needs to be stated the company should look to invent more ways of securing the essential data that will prove to be beneficial for them in expanding its business.

Leave a comment

Your email address will not be published. Required fields are marked *