This is the first day of my participation in the Gwen Challenge in November. Check out the details: the last Gwen Challenge in 2021


What’s the difference between AlibabaCloud and SpringCloud?


1, address

Spring. IO/projects/sp…

2. First, the difference between the two and the corresponding technology stack

Background:

1. Cloud microservice technology stack of the project developed before 2018

【SpringCloud family Barrel 】

  • Service registration discovery Eureka (not maintained)
  • Call open-Feign-SpringCloud remotely
  • Service Gateway Zuul (not maintained)
  • Hystrix (no maintenance)
  • Distributed configuration center Config
  • Link tracing Sleuth+Zipkin

At first SpringCloud was not mature, so it was used with many third party components in the industry (a hodgepodge), but due to the limitations of others, there were many technical frameworks that were closed source or not maintained.

2. Cloud microservice technology stack of the project developed from 2019 to now

AlibabaCloud (also known as SpringCloud Alibaba)

  • Service registration discovers Naocs
  • Call open-Feign-SpringCloud remotely
  • Service gateway SpringCloudGateway
  • Sentinel current limiting degradation
  • Distributed configuration center Nacos
  • Link tracing Sleuth+ Zipkin

As the microservices community has grown, SpringCloud has launched its own bucket like SpringCloudGateway, and several of the industry’s top companies have launched microservices, And joined Spring officials such as SpringCloud Azure(Microsoft) and Alibaba Cloud (Alibaba), so the SpringCloud ecosystem is very strong.

What is the current technology stack of domestic Internet companies?


The mainstream is the combination of SpringCloud and AlibabaCloud, that is, part of SpringCloud is developed by itself, and part of AlibabaCloud is developed by itself, that is, this set of technology stacks used in the course are now combined. So it’s also called AlibabaCloud or SpringCloud Alibaba.

Will the architect be concerned about upgrading the company’s technology stack?

Most companies are upgrading their architecture from multiple old technology stacks to a new one, upgrading the old SpringCloud to SpringCloud Alibaba. However, there are a few companies that have not made architectural upgrades (ROI not cost-effective, non-fatal issues, other urgent projects).


Multi-room deployment – Database replication delay – Solution


Objective:

  • Real-time DISASTER recovery for failover
  • Read/write separation and query services
  • Read/write separation was introduced, with the master responsible for read/write operations and the slave responsible for only read operations

Problem:

There is delay in replication – cross-machine room – cross-city – transnational business. The master database writes new data but the slave database does not update in a hurry, leading to problems in business reading from the slave database.

Problem scenario:

The user registered and logged in, but the user registration information was written into the master database. When logging in, the user could not be queried from the secondary database, indicating that the user was not registered.

Solution 1:

The simplest solution is to reduce the delay, not avoid it (spend money on it) :

  • Branch library architecture, mysql service level expansion
  • Mysql for different services is stored on different physical machines
  • Use better hardware, like solid state rather than hard drive
  • Expansion multi-room deployment – Data consistency is usually a dedicated line

Solution 2:

The distinction between real-time and non-real-time services is controlled by the user, who decides whether the call should query the master or slave library

Registration login is the core, so are access to the master library, query user information go to the secondary library.

  • Advantages: Avoid data inconsistency caused by replication delay
  • Disadvantages: Code increases coupling, requiring additional parameters to access master or slave libraries

Solution 3:

The cache is introduced, the DB is written, then synchronized to the distributed cache, and the response is returned to the user.

Conclusion:

There is no general solution, but it needs to be combined according to the business. The cost of data synchronization is high. Many enterprises use dedicated lines and the cost is high, so not all businesses need to achieve real-time data consistency, but basically the final consistency.