当前位置:网站首页>How to use the database like tap water?|Tencent Cloud Database TDSQL-C

How to use the database like tap water?|Tencent Cloud Database TDSQL-C

2022-08-02 12:32:00 Tencent Cloud Database

“如果说中小企业是一片片沿溪而耕的农田,Our vision is to manage to build a dam upstream water,To irrigate the downstream enterprises.”

Tencent Yang Jue cloud database senior engineer said this is the purpose of him into the database field.初创企业、The greatest needs of small and medium-sized enterprises (smes) in the database level is low cost.Power enterprise authors efficiency is tencent cloud database has been trying to direction,Especially in the outbreak of the economic and social impact,更是一份社会责任.

Deep study on technology,突破极致弹性,Let the customer like to use tap water using the database,用多少、How to use is determined by the customer,Pricing is determined by the usage,This is Yang Jue ji and his team's answer.TDSQL-C Serverless Separation by using calculation database architecture,实现自动扩缩容、按使用量计费、Without using the billing function,To achieve substantial cost reductions,Will be described in detail below function to realize the principle and application of the architecture behind the scenes.

Click here to watch the full version of the video

一、产品特点

file

Serverless 分为 FaaS 和 BaaS,其中 FaaS 是函数即服务,Which we are familiar with cloud function,Can understand as a cloud host an abstract,From the complex operations,To help developers automatically enlarge shrinks capacity,实现服务的高可用,And according to the usage billing.

BaaS 是后端即服务,比如对象存储,It was also the burden of developers file storage management,Provide enough flexibility ability,Implementation in accordance with the usage billing,So it also meet Serverless 的要求.

The way of selling or cloud cloud database host similar,Developers need to buy a fixed specifications of the cloud database,比如CPU 4 核内存 8G,即使开发者没有 SQL 请求,也将按照 4 核 8G 进行计费.

file

The industry scene database of cloud,Did help developers to achieve high availability and automatic backup,To reduce the operational burden,But developers need to predict in advance business request quantity,Initiated and enlarge shrinks capacity,There is no charge for cannot when not using.

Traditional cloud database deployment of computing and storage on the same,The kernel process directly write the local data file.When a machine is close to storage use 90%,Even if the whole instance stock of computing resource load low again,Was no longer able to allocate a new instance of the.在这种情况下,The machine on stock instance user,Although there is no use of computing resources,CPU 内存都是 0,Still want to bear the cost of this machine computational resources.反过来也一样,计算使用 90%,With less storage usage,Will also lead to the rest of the store can't sell.

According to the actual amount paid nature of the problem is according to the actual amount allocated resources.So the cloud database if you want to Serverless 这个目标,To do is to calculate storage separation.

The advantage of calculation store separation a lot,Such as storage space and write bandwidth can break through the single ceiling,Stronger ability of disaster and so on,本文重点讲解The allocation of resources elastic flexible的特点.

Store separation can make the calculation and storage of decoupling,Any storage nodes compute nodes can access tasks.Computing and storage to maintain their own resource pool,分别最大化、The most flexible to the allocation of resources.Deposit according to the amount of data storage layer charge,Calculate layer according to the real load charges.

另一方面,Traditional cloud database scalability capacity need to move data to another physical device,所以耗时长.Separation and computing storage architecture,Computing layer enlarge shrinks, let do not need to move data storage layer,Direct layer distribution computing resources can be,秒级完成扩缩容.

In the above calculation store separation,TDSQL-C 完成了 Serverless 产品功能的设计,让我们来看看具体是怎么做的.

二、架构设计

file

Pictured above is developers to access all links,Applications access computing layer through the access layer,Calculated from the layer data returned.

我们的 Serverless Form is the use of the computing layer monitoring.通过监控,Our automatic expansion of computing resources shrink capacity,And the time consumed resources for billing.When found no request,Monitoring service will trigger the computing resources recycling,And inform the access layer.用户再次访问时,Access layer will awaken instance,Provides access to again.

file

From the perspective of customer summary up to three characteristics:

自动扩缩容:According to the business load enlarge shrinks let instance,Developers need to forecast load and increase resources in advance;

按使用量计费:In the load of actual use billing,Developers do not need to use for not having to pay;

Without using the cost:Countless according to request,No billing computing resources.

1. 自动扩缩容

file

Automatic enlarge shrinks let's goal is to let the customer can use the database as use of water,Can drop by drop,Can also be like waterfall pours to use.

Developers in buying a Serverless 实例时,You need to specify the scalability capacity range,Is the minimum and maximum specification.Such as developers bought a minimum 1 核 2G 最大 2 核 4G 的实例.我们对 CPU And memory limits to the largest specification,也就是说 CPU And memory expansion and there is no time,而 Buffer Pool 根据 CPU Load regularly adjust.

This is a plan we initially consider,Is the common scalability capacity plan.

Above the vertical axis CPU,The horizontal axis shows the memory(Mem),Rectangular box on behalf of the resource limits.Instance when idle,Limits of the specifications of the instance as 1 核 2G,Load comes,CPU Quickly played,After monitoring found that,To trigger the expansion,扩成 2 核 4G,The cache is also BP Size also increases accordingly,You can see in expansion before,用户的 CPU Use is restricted,Limit the time depends on the threshold of the expansion and trigger.

file

We then use scheme is restricted to the largest specifications from the start,Load comes,Can all of a sudden to use more resources,然后根据 CPU Use to trigger the update of the cache size.Under the deal users to use the database can be no sense CPU 扩容,And also won't because links jump cause instance OOM.

2. 按使用量计费

file

Usage charging target of second level is particle size,And any unit specification of resources,比如用到 0.7 核,就按 0.7 Nuclear charge,Not less than 1 核算 1 核.

Our control room each 5 秒采集一次,Result, unified use CCU(TDSQL-C Compute Unit)As a unified force unit,其计算方法为 CPU、内存的1/2A maximum and the minimum specifications take.

以上图为例,With the minimum specifications when 0.25 CCU 计费,The load comes to CPU 进行收费,即为 3;When the load at the end of the,The memory is still in release,为内存的1/2 ,也就是 0.8.

3. Without using the billing

file

问题来了,You may think according to the minimum when 0.25 CCU Billing is much more,Then we launched without using cost function.

10 Minutes didn't receive user connection,Will recycle the compute nodes,To pause the instance of the.Examples of suspended after receiving the user requests,启动计算节点,Revert to the running instance.

We calculated by monitoring the number of connections,No connection to control a pause.

file

暂停后,We recycle all resources for calculating layer,No longer charging for computing resources,Only to charge storage resources.Access layer after receiving the user requests,Controls will restart the instance,提供给用户访问.

file

The more important is the recovery time of,Is the cold start time.On the recovery time,We have done quite a lot of optimization,Including find persistence log site and BP And transaction system initialization.目前,Recovery time can only2秒.

Some readers may be interested in computing architecture details of store separation,Then briefly share architecture details.

file

在计算层,We use a yes TXSQL,完全兼容 MySQL 协议,Able to reuse community bugfix 和特性.主从复制使用 redo 复制,优点是延迟低.redo Log on local,But sent to the storage layer.

在存储层,We are using the cloud drive HiStore 存储平台,保障了数据安全、GB Backup retracement level、As well as the performance and cost of various storage options,我们在 HiStore Add database logic,Implement log replay and operator pushed down.

You if you are not familiar with database and don't be alarmed by this these nouns,Is of our foreign is provided with MySQL 一致的数据库服务,Difference is that the internal we do the calculation store separation,Layer separation after computing resources can be more free、灵活地分配.

三、应用场景

Application scenario is of the biggest concerns of the developers,The next six class scene to share practical application.

1. 慢查询

file

当开发者的 SQL Optimize aren't good enough,Or occasionally need a full table scan analysis data,There will be a slow query,Is often accompanied by slow query CPU 使用率高(Because of the scanning data more).

This is also the user can actually perceive,Can be seen in the above monitoring慢查询与 CPU 是正相关的.If the user to buy a bigger fixed specification instance,So will bear the extra cost;If the purchase is small specification instance,So in the slow query arrives user CPU 会被占满,进而影响业务.使用Serverless The database will not have to worry about this problem,大部分时间Serverless Database with a low CCU 进行付费,The slow query comes can immediately use additional CPU,所以On the whole is also affect slow query time billing.

2. 定时任务

file

Similar to the slow query,There are quite a few business has regularly processing logic,Including the time cleaning up the old data、The day before timing to generate reports, etc.上图可以看到,Users in every day 0 Point would run a lot of request,But most of the time at ordinary times is a low load.用户使用了 Serverless 数据库之后,Don't have to go to do weigh the specifications and cost,和上一个例子一样,Billing as much as they use.

3. 归档数据库

file

If long time no database,就不用对 CPU And memory.This usually occurs in some database file、Machine learning sample database、Personal family history of sensor database etc,不会经常使用,But occasionally visit the state of the.Such is the common practice of data directly there COS 里,Need to download.而Serverless The database has a big advantage is the need to immediately provide index,And has a strong analysis function,The developer does not have to write code can search to the data you need.

4. Low frequency access business

file

For the average daily traffic is less than 10 Time of low-frequency access business,例如个人博客、垂直社区论坛、微信小程序,We with the cloud function、云开发、WeChat cloud hosting have in-depth cooperation,To achieve access after the stop billing.

5. 开发测试环境

file

The picture above you can see in a week,用户在晚上、Weekend did not access and use.用户通过 TDSQL-C Serverless 数据库的Auto pause function,Save a lot of research and development testing cost.

6. 微服务场景

file

As the micro service more and more popular,The function of each individual service is responsible for is becoming more and more small,Then the corresponding is micro service backend database load will be smaller.More than one way of doing this is micro service share a large database,But it will be a problem of mutual influence.所以,Serverless Database provides small specifications of the database instance,To ensure that the isolation between micro service.

四、总结与展望

TDSQL-C Serverless Added to the database in the field of Serverless 的空白.On the automatic enlarge shrinks, let,可以使 CPU Instant use biggest specification,According to usage billing to according to CPU Real-time usage for billing,Don't use will not be paid on the cold start time is 2 秒,目前在 Serverless The database is absolutely leading.In the future we will do further optimization on the cold start,And help customers to further reduce the cost.

原网站

版权声明
本文为[Tencent Cloud Database]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/214/202208021224517260.html