当前位置:网站首页>Exploration and Practice of Database Governance
Exploration and Practice of Database Governance
2022-08-04 19:03:00 【InfoQ】
作者:十眠
背景
在分布式系统架构中,The flow of business are end-to-end.每个请求都会经过很多层处理,比如从入口网关再到 Web Server 再到服务之间的调用,再到服务访问缓存或 DB 等存储.
对于我们的系统来说,Database is very important for a.Therefore both on the control of the stability of,Still in the development of extraction effect scenarios,Database related governance ability are required of our system ability.
The following list some typical database related governance scenarios:
- A system provides a query interface,SQL Statements involve multiple tables join,In some cases will trigger slow query,耗时长达 30s,最终导致 DB 连接池/Tomcat 线程池满,Application as a whole, not with.
- 应用刚启动,由于数据库 Druid Connection pooling is still in initialization,But at this time has a large number of requests into,迅速导致 Dubbo The thread pool filled with,Many live card in the process of initialization database connection,Lead to business requests a lot of error.
- All link grayscale scene,Because the new application version changed the content of the database table,Gray flow leads to online database data disorder,Business students manual corrections online data overnight.
- At the beginning of the project not to SQL The performance of the prepared considerations,随着业务的发展,The increase of user level,Online legacy old interface SQL Gradually become the performance bottleneck,So you need to have an effective SQL Insight ability to help us find SQL,And in a timely manner performance optimization.
- SQL Statement processing time is longer slow lead to a lot of online business interface call,There is something wrong with the need to quickly locate the slow SQL,And through certain means of governance in isolation,The business quickly recover.Therefore in micro data access services layer,实时的 SQL Insights can help us to quickly locate slow SQL 调用.
In fact for most back-end applications,The bottleneck of system mainly restricted to the database,Of course the complexity of the business must also cannot leave the operation of the database.So the database problems,Is the highest priority to work,Database management is a necessary part of the micro service governance.
Database management related common scenarios
The following summarizes the micro service access database layer,Some common scenarios in database management and ability.
OpenSergo An overview about the database in the field of management
慢 SQL 治理
慢 SQL Is one of the factors affecting the stability of system is deadly,System in the slow SQL 可能会导致 CPU、Abnormal load and system resource depletion, and so on and so forth.Serious slow SQL After the may bring down the entire database,The risk of not on online business.线上生产环境出现慢 SQL 可能原因如下:
- 网络速度慢、内存不足、I/O 吞吐量小、Disk space is occupied with hardware, such as the reason.
- 没有索引或者索引失效.
- System data too much.
- At the beginning of the project not to SQL The performance of the prepared considerations.
For the online common slow SQL 问题,MSE Service governance provides the solution of scene.
- SQL 洞察
MSE Provides the second level of SQL 调用监控:
We can look for the application and resources API Dimensions of real-time data(Elaboration to the second level),同时 MSE 还提供了 SQL 的 TopN 列表,我们可以一眼看出 RT 高的 SQL 语句,Rapid positioning application slowly returning.
我们通过 MSE 提供的 SQL 洞察能力,Can effective analysis SQL Statements whether written reasonable,以及 SQL 执行的并发、RT Is in line with the system performance expectations,根据这些 SQL Insight into the data,Thus can effectively evaluate the system performance of the overall,Provide important basis for flow control degradation rule configuration.
- SQL The flow control the drop
我们可以根据 MSE 自动识别的 SQL 语句,Can appear to slow SQL Configuration of the application of the number of threads dimension flow control or downgrade rules,When there is a slow SQL Limit one time when a call is SQL 数量,To prevent too much slower SQL The statement execution resources exhausted.
关于 MSE 的 SQL Flow control degradation ability,MSE The supporting configuration flow control、隔离、Fusing and hot current limit and so on four kind of rules.
1、
流量控制
:通过流控能力,为服务接口配置流控规则,让容量范围内的请求通过,多余的请求被拒绝,相当于安全气囊的作用,可以有效保证 SQL Request access to the flow of control within the threshold value of system capacity.
后面 MSE Will provide the library、Table dimension polymerization SQL 洞察能力,We can specify the database based on the ability to control、Table of the flow control within the scope of the forecast capacity.
2、
并发隔离
:When the approximate steady-state flow:并发线程数 =QPS * RT(s),其中 RT 升高,Higher number of concurrent threads,On behalf of the service invocation appears accumulation.The traffic management services provided by the concurrent isolation ability,To the important service call configuration number of concurrent threads to limit,The equivalent of a“Soft insurance”,防止慢 SQL Or not too stable service from normal service resources.
3、
熔断降级
:业务高峰期,Some downstream of the service provider encountered a large amount of data access performance bottlenecks,A large number of slow SQL,甚至影响业务.Our database access for some non-critical services configuration rules of automatic fuse,当一段时间内的慢调用比例或错误比例达到一定条件时自动触发熔断,后续一段时间服务调用直接返回 Mock 的结果,Both to ensure calling end no being stacked data access requests down,To ensure the normal operation of the entire business link.
4、
热点流控
:通过
Hot parameters of flow control ability
,自动识别 SQL Request access to the parameters of TopN Access to the heat parameter values,And these parameters are separate flow control,To avoid a single hotspot access overload;And for some special hot spot to visit(Such as very hot for item)Configure a separate flow control value.参数可以是 SQL Access to any of the conditions with the business,如以下 tid 参数的值.
SELECT * FROM order WHERE tid = 1$
The connection pool management
The connection pool management is a very important role in database management,Through the real-time indexes of some links pool,We can effectively recognition system of risks in advance,The following are some of the common connection pool management scenarios.
1、
Built in advance even
The application release or elastic expansion scenarios,If just restart the instance of the connection is established and have not completed,But the instance has been launched to complete at this time,Readiness 检查已经通过,Means that at this time there will be a lot of business flow to enter a new start pod.A large number of requests blocking on the connection pool for connection of action,The thread pool full service,A large number of business requests failed.If we have built in advance of the application of the ability of,You can before the arrival of the traffic,Will connect requests to ensure in minIdle 之上,The ability to and cooperate with small flow preheating,More than you can solve this headache cold start problem.
2、
"坏"连接剔除
Sometimes there are some problems in the connection pool's connection,May be appeared at the bottom of the network jitter,Can also be performed business appeared slowly、死锁等问题.If we can from the Angle of view of the connection pool,In a timely manner of abnormal connection,And out in a timely manner and recycling,You can guarantee the stability of the connection pool as a whole,Not be there is something wrong with the individual business processing or network jitter to sink.
3、
访问控制
In theory, not all database tables can be casually visit,在某些时候,Some important tables may for some of the less important service,We want it to be a forbidden to write、只读的状态,Or when the database in shaking、线程池满的情况下,We hope to reduce some time-consuming read library SQL 执行,Or there is some sensitive data table only allow an application to read and write access to.Then we can through dynamic access control ability,Real-time distributed access control rules,To do for individual method、应用的 SQL For the database instance、Table of the read the writing, such as black and white list of access control.
数据库灰度
微服务体系架构中,服务之间的依赖关系错综复杂,有时某个功能发版依赖多个服务同时升级上线.我们希望可以对这些服务的新版本同时进行小流量灰度验证,这就是微服务架构中特有的全链路灰度场景,通过构建从网关到整个后端服务的环境隔离来对多个不同版本的服务进行灰度验证.MSE By means of shadow table,The user can in the case of any business code does not need to be modified,实现数据库层面全链路灰度.
总结
以上这些是 MSE The upcoming a database governance capacity forecast,We from the Angle of view of the application of the abstract we are on a visit to、When using the database scenario some stability control、性能优化、Mention effect of actual combat experience,For each back-end application,Database was undoubtedly the most important,We hope that through our database management ability,We can help to better use the database services.
Service governance standards OpenSergo
Q:OpenSergo 是什么?
A:OpenSergo 是一套开放、通用的、面向分布式服务架构、覆盖全链路异构化生态的服务治理标准,基于业界服务治理场景与实践形成服务治理通用标准.OpenSergo 的最大特点就是
以统一的一套配置/DSL/协议定义服务治理规则,面向多语言异构化架构,做到全链路生态覆盖
.无论微服务的语言是 Java, Go, Node.js 还是其它语言,无论是标准微服务还是 Mesh 接入,从网关到微服务,从数据库到缓存,从服务注册发现到配置,开发者都可以通过同一套 OpenSergo CRD Standard configuration for each layer in centralized management control,Needed to pay attention to the framework、语言的差异点,降低异构化、全链路服务治理管控的复杂度
OpenSergo 也会在 9 Month database management related standard,Further standardized database abstraction and governance related ability.目前 OpenSergo Communities are joint communities to further cooperation,Through the community to discuss and define unified service governance standards.当前社区也在联合 bilibili、字节跳动等企业一起共建标准,也欢迎感兴趣的开发者、社区与企业一起加入到 OpenSergo 服务治理标准共建中.欢迎大家加入 OpenSergo 社区交流群(钉钉群)进行讨论:34826335
点击
此处
,进入 OpenSergo 官网~
边栏推荐
猜你喜欢
随机推荐
HCIP-R&S By Wakin自用笔记(1)企业网络高级解决方案
(ECCV-2022)GaitEdge:超越普通的端到端步态识别,提高实用性
如何给MySQL添加自定义语法 ?
重构指标之如何监控代码圈复杂度
如何进行自动化测试?【Eolink分享】
面试官:MVCC是如何实现的?
如何给MySQL添加自定义语法 ?
STP实验
关于使用腾讯云HiFlow场景连接器每天提醒签到打卡
How does the intelligent video surveillance platform EasyCVR use the interface to export iframe addresses in batches?
vantui 组件 van-field 路由切换时,字体样式混乱问题
污损指纹恢复与识别
server
lc marathon 8.3
什么是内部客户服务?
我的四周年创作纪念日
如何进行自动化测试?
openharmony初体验(1)
基于YOLOV5行人跌倒检测实验
运力升级助力算力流转,中国数字经济的加速时刻