This is the 17th day of my participation in Gwen Challenge

A list,

In recent years, the software design scale is becoming larger and larger, and the business requirements are becoming more and more complex, which puts forward higher requirements for the performance, high throughput, high stability, high expansion and other characteristics of the system. It can be said that business requirements are the number one driving force of software architecture capabilities, and software architecture thinking and related technologies are changing dramatically due to these factors. These changes are reflected in the software architecture industry, where we are beginning to hear more and more new terms such as “distributed”, “SOA”, “microservices”, “mid-stage”, etc.

Today I will record my learning process of microservices, including all the technical implementation details and personal understanding. As the saying goes: good memory, as bad pen, in case they forget, can query later. Of course, these things have a lot of things are their own understanding, the inside of the illustration is also their own drawing, there may be some biased place, of course, I hope that a master can correct, not effective give advice, we make progress together.

Second, the development of the framework

Nowadays science and technology can be said to be changing with each passing day and developing rapidly. Compared to us, software design industry is also undergoing great changes, with more and more complex businesses and larger and more complex demands. Software architecture and deployment scale are also undergoing earth-shaking changes. As one of the software architecture ideas, “micro-service architecture” is also evolving according to its own laws. Let’s take a quick look at the three phases of microservices architecture, just for personal understanding.

1. Monolithic Architecture

Single application era: An application, no matter how layered, is a solution, or a project. “Solution” and “project” are not the concepts we use in Visual Studio. The final application code will run in a process. As shown in figure:

Advantages: simple development, centralized management, no distributed loss, are communication within the system process.

Disadvantages: poor maintenance, difficult upgrade, severe coupling, inability to cope with high concurrency and big data scenarios, and inability to iterate quickly.

  • (1) Only the same technology can be used, and it is difficult to develop different modules in different languages or different versions of the same language.

  • (2) The system coupling is too strong, one module has a problem, the system will break down, a module upgrade, the whole system will have to shut down maintenance.

  • (3) To go online, they must go online together and wait for each other, unable to respond to market demand quickly.

  • (4) Cluster burden, if you want to cluster, can only cluster the whole system, even if a module is under pressure.

2, vertical split

As the business scale becomes larger and larger, the system design becomes more and more complex, and large systems begin to carry out vertical separation of services. For example: there are specialized departments that do commodity seconds to kill, specialized departments that do fresh goods, specialized departments that do supermarkets, and so on. Of course, this is naturally divided according to departments, and there are systematic divisions according to business needs. As shown in figure:

Advantages: Vertical split, system independent deployment and maintenance, each system in its own process execution, divide and conquer.

Disadvantages: the more split, the more complex the storage, the more things are repeated between systems, a single system or a single mode.

3. Distributed services

As the business system becomes larger and larger, software system design becomes more and more complex. In order to avoid overly complex business requirements, service systems are vertically split to form multiple independent service systems. If multiple systems need to communicate with each other, cross-process technology can be used to complete communication. However, vertical split also leads to the generation of a large number of duplicate codes and modules, such as user module, log module, payment module, authentication and authorization module, etc. Such scattered codes also bring difficulties to the maintenance and upgrade of the system. When we repartition the business to interface and servize individual modules for greater reuse, we begin to enter the era of distributed services. (The first rule of distribution is not to be distributed.

Advantages:

  • 1, independent process deployment, independent process operation, independent evolution. Services can achieve high cohesion and low coupling.

  • 2, independent development and maintenance, business decoupling, both business system and distributed services are independent evolution.

  • 3. Distributed management

  • 4. Enhanced isolation

  • 5. The system is assembled by a series of services, without repeated construction, modules and codes can be reused.

Disadvantages:

  • 1. Data consistency (multiple services to complete a task) and system availability (clustering) become problems

  • 2. The database has also been split.

  • 3, maintenance, design, architecture cost increases, debugging, error correction more difficult.

  • 4. Distributed loss cost of network transmission

  • 5. Not suitable for environments with high concurrency and big data.

4. Microservices architecture

When the emergence of microservices, distributed architecture has been very mature, and various problems in the architecture have been very mature solutions. For the current business system, distributed architecture has become a conventional means, at this time, microservices emerged. Microservices architecture is an architectural pattern (architectural style) that decouples business logic with distributed services.

Micro service must be a kind of distributed, is in the distributed technology matures, then use distributed as decoupling method to architecture system — — — — — because the separation of service is very meticulous, service quantity scale began to grow more, the service volume begins to shrink, by a few big service before, into multiple independent operation, the atomic nature of the service.

As shown in figure:

The most important features of microservices are:

  • (1) Availability: Describes the ability of a system to provide useful resources over a period of time, thereby reducing downtime while maintaining the high availability of its services.

  • (2) Scalability: the ability to dynamically add and delete resources in the system according to demand, which is a specialized implementation of horizontal or vertical expansion.

Clustering (load balancing) addresses the high availability and scaling characteristics of the system.

Advantages:

  • (1) Each module can be developed in different languages or different versions of the same language.

  • (2) Low system coupling, each module is divided and ruled, independent deployment, independent release, independent maintenance.

  • (3) It can meet the needs of the corresponding market faster and is more in line with agile development.

  • (4) Cluster strategy can be used for different modules to solve problems where there are.

Disadvantages:

  • (1) The development is more difficult and the system structure is more complex.

  • (2) Low operation efficiency and high cost of network invocation.

5. SOA Service-oriented Architecture

Service-oriented Architecture: A component model that separates the different functional units of an application, called services, and connects them through well-defined interfaces and protocols. As shown in figure:

Iii. Development history of microservice architecture

When we want to solve the two problems of high availability and scalability of microservices, it is natural to think of clustering, and this idea is correct. If we implement service clustering, two other issues arise that lead to different versions of microservice architectures.

  • The first one is the problem of service discovery, how the caller discovers the service, how do we know when there is a new service, how do we know that it is important to discover the service, this is the basic problem, the first problem is not solved, the second problem can not be realized;

  • Second: how to invoke the service, how to manage so many service instances. With so many cluster instances, there are so many service instances. How do we invoke these services? What is the relationship between multiple service invocations?

Given these issues, let’s look at how three versions of the microservices architecture address them.

1. Centralized proxy —-Nginx (V1.0 (service registration/service discovery —- manual)

  • (1) Service discovery, manually modify the configuration file, and restart.

  • (2) load balancing, rotation training, weight, hash and so on.

  • (3) New services cannot be discovered and need to be manually configured. Service offline can be checked automatically.

  • (4) The implementation of the client is very simple, without additional code, simple and efficient.

2. Client embedded —-Consul (V2.0 version (Service Registration/Service Discovery — Automatic — Service governance))

  • (1) Service registration and discovery, dynamic increase, automatic completion.

  • (2) Health check, you can check the damaged service, remove the service, automatic completion.

  • (3) Load balancing. Consul returns all active service instances and the client implements load balancing by itself.

Powerful functions, automatic discovery and automatic offline, complex client integration, load balancing on the client.

3. Service Mesh (V3.0– immature technology, Huawei + ViPSHOP, LSTIO)

The SideCar service manages registration and discovery of service instances, and governance and invocation of service instances. Service Mesh’s Control Plan Manages all sidecArs. I will not talk about this technology, there are many online information, this technology is not very mature, the scope of use is not very wide, only some large companies have used, such as: Microsoft and so on.

4. Essential technology stack for microservice architecture

Microservices is a software design, architecture idea, and, of course, the relevant technical points to solve the current priorities. Learning micro-services, we can not talk about empty talk, must be implemented on the specific technology stack. At present, there are more than two technology systems in use, one is Java and the other is Net. Without further ado, I am a software architect who uses Microsoft’s related technology stack, and of course the “microservices” architecture technology stack is also Microsoft’s. Today I listed the stack of technologies used in microservices architecture. I also want to point out that many of the technologies in microservices architecture are language-independent and can be used on both.NET and Java platforms. In the future, step by step, we are doing in-depth research on each technology.

1. Micro-service architecture —- Service communication

WebService, WCF, WebAPI, even ASHX,ASPX, these are Microsoft’s own technology architecture, nothing to say.

  • (1) Active trigger

  • (2) Data serialization transfer

  • (3) Cross-platform.

  • (4) Cross-language

  • (5) Http penetrates the firewall.

2. Microservice architecture —- process communication

  • (1), Net Remoting: Net platform to monitor mail, do not support cross-platform.

  • (2) gRPC: high-performance, open source and general RPC framework, service-oriented and mobile, based on HTTP/2 design, recommended use.

3. Microservices Architecture –API Gateway Service (Ocelot)

API Gateway – this is an exposed access point to the system. This sort of proxy access guy is a corporate gatekeeper who takes on addressing, restricted access, security checks, location guidance, and so on. Ocelot is one of them. NET Core implementation and open source API gateway, it has powerful features, including: routing, request aggregation, Service discovery, authentication, authentication, limiting fuses, and built-in load balancer integration with Service Fabric, Butterfly Tracing. These functions only require simple configuration.

As shown in figure:

Liverpoolfc.tv: ocelot. Readthedocs. IO/en/latest/I…

4. Microservices Architecture — Authentication & Authorization

Nowadays, application development is emerging in an endless stream. Browser-based web applications, wechat public accounts and small programs, IOS and Android based apps, Windows-based desktop applications and UWP applications and so on, so many kinds of applications bring challenges to application development. In addition to implementing each application separately, we also need to consider the interaction between each application and the extraction of general modules, among which the authentication and authorization of identity is an essential part of each application. And now the Internet, for information security requirements are very demanding, so a unified identity authentication and authorization is crucial.

One such framework is IdentityServer4, an authentication and authorization middleware tailored for ASP.NET CORE that implements the OpenId Connect and OAuth2.0 protocols.

Project address: github.com/IdentitySer…

5. Microservices Architecture — Transient fault handling

Polly is a powerful class library. Polly is a kind of. NET elastic and transient fault handling libraries allow us to implement strategies such as line retries, disconnections, timeouts, and failover in a very smooth and thread-safe manner. Polly targets.NET 4.0,.NET 4.5 and. NET Standard 1.1 as well. NET Core implementation, the project author is now a. As a member of the.net Foundation, the project is constantly iterating and updating, and you deserve it.

Project address: github.com/App-vNext/P…

6. Microservices architecture —- Distributed tracking

With the popularity of micro service architecture, some problems also will be more and more prominent under the service architecture, such as a request will involve multiple services, and the service itself may also depend on other services, the entire request path will form a network of invocation chain, and an exception occurs when a node in the call chain, the stability of the entire invocation chain will be affected, There is no such thing as a silver bullet, and every architecture has its pros and cons.

In this case, we need tools to understand system behavior and analyze performance problems, so that when a failure occurs, we can quickly locate and resolve the problem. This is where APM (Application performance management) tools come in. Project address: github.com/SkyAPM/SkyA…

7. Micro-service architecture —- Distributed log

Generally, we need to perform log analysis scenarios: directly grep and awk in log files to obtain the desired information. However, in large scale, that is, a large number of logs and complex scenarios, this method is inefficient, and there are problems such as how to archive too many logs, how to search text too slowly, and how to query multi-dimensional logs. Centralized log management is required. Logs from all servers are collected and summarized. The common solution is to set up a centralized log collection system to collect, manage, and access logs on all nodes in a unified manner.

Large system is usually a distributed deployment architecture, different service module is deployed on a different server, problems arise, mostly need according to the problems exposed the key information, positioning module to specific servers and services, to build a centralized logging system, can improve the efficiency of the positioning problem.

(1), the exceptionalism is an open source real-time log collection framework, which can be applied in applications based on ASP.NET, ASP.NET Core, Web Api, Web Forms, WPF, Console, MVC and other technology stack. It also provides Rest interfaces that can be applied in Javascript and Node.js. It makes log collection easy to use and does not require a lot of technical details and configuration. In the past, we mostly used Log4net, Nlog, and other frameworks for log collection. As applications become more complex and clustered, the traditional approach may not be suitable because collecting individual logs and analyzing them becomes cumbersome and time-consuming.

Now the Exceptionalism Team has given us a better framework to do this, and I think that’s great and meaningful, thanks to them.

Liverpoolfc.tv: exceptionless.com/

GitHub:github.com/exceptionle…

ELK is short for Elasticsearch, Logstash, and Kibana, all of which are open source software. However, Beats is a lightweight log collection and processing tool (Agent). Beats occupies less resources and is suitable for collecting logs from various servers and transferring them to Logstash. This tool is also recommended officially. The ELK Stack is now called Elastic Stack because of the addition of Beats. Recommended.

8. Microservice architecture —- Distributed Configuration Center

Apollo is a configuration management platform developed by The Framework department of Ctrip. It can centrally manage the configurations of applications in different environments and clusters, and push the configurations to the application end in real time after modification. It also has standardized permissions and process governance features.

The server is developed based on Spring Boot and Spring Cloud, and can run directly after packaging, without additional installation of Application containers such as Tomcat.

The Java client is framework independent, runs in all Java runtime environments, and has good support for the Spring environment.

.NET clients do not depend on any framework and can run in all.NET runtime environments.

Project address: github.com/ctripcorp/a…

9. Microservices architecture —- Distributed lock

There are many solutions for distributed locking, and I will list some of them here. I will implement these technical points in the future practice.

  • Consul can implement distributed lock

  • (2) Redis can realize distributed lock, which is recommended.

  • (3) Zookeeper can realize distributed lock

  • (4) Database can realize distributed lock

10. Microservices architecture —- Distributed transactions

There are many ways to implement distributed transactions, so study hard in the future.

  • (1), 2PC (two-phase Commit Protocol, strong consistency, no availability)

  • (2) 3PC

  • (3), TCC (try-confirm-cancel)

  • (4) Local message table, recommend RabbitMQ.

  • (5) Saga mode

Local Message table: MQ Distributed Transaction – Local Message table – Based on message consistency.

  • (1) There is delivery message on

  • (2) Downstream access to messages

  • (3) Stability of upstream delivery

  • (4) Downstream acceptance stability

11. Microservices Architecture — containerization

Docker is an open source application container engine that packages applications and dependencies into a portable image and then distributes them to any popular Linux or Windows machine, as well as virtualization.

Docker uses a client-server (C/S) architecture pattern that uses remote apis to manage and create Docker containers. Docker containers are created by Docker images. The relationship between containers and images is similar to that between objects and classes in object-oriented programming.

Docker uses C/S architecture Docker Daemon as a server to accept requests from customers, and process these requests (create, run, distribute containers). The client and server can run on the same machine or communicate with each other through sockets or RESTful apis.

Docker Daemons typically run in the background on the host and wait to receive messages from the client. The Docker client provides a series of executable commands for users to interact with the Docker Daemon.

As shown in figure:

Microservices Architecture — Container Choreography

Kubernetes is a Google open source container orchestration engine that supports automated deployment, large-scale scalability, and containerized application management. When deploying an application in a production environment, it is common to deploy multiple instances of the application to load balance application requests.

In Kubernetes, we can create multiple containers, each running an application instance, and then through the built-in load balancing strategy, to achieve the management, discovery, access to this group of application instances, and these details do not require complex manual configuration and processing operations personnel.

Kubernetes can also be understood as Docker’s orchestration container, which is a tool for managing the full life cycle of applications. It is very convenient for application creation/deployment, application service provision, capacity expansion and reduction, and update, and self-healing of faults can be achieved

Chinese community: docs.kubernetes.org.cn/

Liverpoolfc.tv: kubernetes. IO/docs/home /

13. Microservices Architecture — CI/CD

Jenkins is an open source continuous integration (CI) tool that provides a user-friendly interface for continuous, automated building/testing of software projects and monitoring of external tasks.

Website: www.jenkins.org.cn/

V. Concluding remarks

Well, today is write here, today is to write a lot, nothing else today, is to do the record of related technology stack, later have time, then each technology study, may be every technology, may also be based on a project to study, the project may contain a lot of other technologies, at that time, and then make a decision. Make progress every day. Come on.