余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

初级DBA需要知道的十件事|数据中心运维之数据库篇

xiyangw 2022-11-25 11:52 16 浏览 0 评论

成为一个合格的DBA(Database Administrator,数据库管理员),光了解SQL语句是不够的。DBA通常工作在数据库、服务器、运维人员和开发者的交集上,所以一个合格的DBA需要了解IT的方方面面,从而可以具备对性能、硬件和软件问题排错的能力。本文将介绍一个初级的DBA需要知道的十件事,快来看看自己是否已经都具备这些能力啦?

备份和恢复


任何一个名副其实的DBA都应该了解如何使用DBMS(数据库管理系统)的内建工具来备份和恢复数据,比如Oracle Recovery Manager和SQL Server Management Studio。除此之外,了解有哪些第三方的数据库备份工具也是很有必要的。了解过后你会发现,这些工具各有优势。事实上,仅仅备份了数据库文件并不代表这个备份是一个“好”备份。

基本的优化


当创建索引时,DBA需要知道如何提出优化建议。你需要知道一些基本的索引策略,同时还要知道下面这些问题的答案。比如,何时引入聚集索引(Clustered Index)?何时使用覆盖索引(Covered Index)?数据库优化器如何工作?它是否依赖于特殊表的统计数据?如何更新这些数据?使用优化器对重组表和索引意味着什么?它们应该如何被重组,以及是否能自动化这一过程?

协助软件开发者

软件开发人员可以搭建也可以摧毁你的数据库。帮助他们撰写有效率的查询代码是很重要的。你要帮助他们了解,一次发起1个查询请求比同时发起1000个请求要有效率得多:大数据情况下,1次查询返回1000行结果比1000次查询每次返回一条快得多。作为一个DBA,帮助他们理解有些时候在DBMS执行操作要比在代码中更好。典型的案例就是,通过网络抓取大量数据再在本地合并,很有可能比直接一个合计函数(Aggregate Function)查询慢。

存储系统

大多数数据库的性能瓶颈在磁盘,了解你的数据库位置所在以及DBMS是如何访问物理数据也是非常重要的。如果你的企业有存储团队,联系他们,并且掌握他们是如何监控存储的一些重要性能指标,如IOPS和响应时间。

了解查询计划

一个初级DBA应该知道如何生成和阅读基本的查询计划。并不一定要求你完全理解所有的内容,但几个关键的过程还是要掌握的,比如随意的全表扫描(Full Table Scan)和嵌套循环(Nested Loops)可能会出现问题。同样,你需要知道何时优化器会推荐更改,为什么这样的更改会生效,以及这些操作会对系统造成怎样的性能妥协。

了解规范化

规范化的数据库表(Normalized Tables)是一个优良设计的关系型数据库的基础,但有时这也会带来灾难。DBA需要理解并知道如何将数据纳入第一、第二和第三范式。为什么规范化很重要以及何时它可能成为一个不利因素?知道主键、外键和唯一键的区别,同时知道如何强制一对一、一对多的关系。

了解SQL语言

DBA还需要掌握SQL DML(数据操作语言)和DDL(数据定义语言)。DML包含的项目包括Select(查询)、Update(更新)、Insert(插入)和Delete(删除)。DDL包含Create Table(创建表)和Alter Table(删除表)。初级DBA应该了解如何创建和修改表以及索引,并且知道删除记录、截断表和丢弃表间的区别。当然,也不能忘了视图(View)。

操作系统

DBA还需要熟悉操作系统,知道不同操作系统之间的差别,比如安全设置、与活动目录(AD)、LDAP的集成和命名规范。同时你还需知道数据库是如何启动的,需要哪些脚本来启动、关闭或临时锁住用户的访问。

脚本

为了让工作更有效率,脚本是必不可少的。想象一下你有十个或更多的数据库需要管理,你是否只能逐一登录并手动启动/关停它们?快去找本脚本指南来看看如何批量地执行这些操作吧。

存储过程和触发器

将存储过程和触发器单独列开一项是因为考虑到这更像是编程而不是“组合”SQL语句。不管怎样,你需要知道何时使用它们,并让开发团队知道不在代码中完成操作的优点。同样,许多第三方应用会自带需要的存储过程和触发器。能够读懂这些过程并了解它们的逻辑,对将来性能问题的排错很有帮助。能越快理解这些过程,你就能对自己管理的数据库更得心应手。

相关推荐

spring利用spring.handlers解析自定义配置(spring validation 自定义)

一、问题我们在spring的xml配置文件里经常定义各种各样的配置(tx、bean、mvc、bean等等)。以及集成第三方框架时,也会看到一些spring之外的配置,例如dubbo的配置、securi...

「Spring源码分析」AOP源码解析(上篇)(spring源码深度解析(第2版))

前言前面写了六篇文章详细地分析了SpringBean加载流程,这部分完了之后就要进入一个比较困难的部分了,就是AOP的实现原理分析。为了探究AOP实现原理,首先定义几个类,一个Dao接口:1&nbs...

Spring 解析注册BeanDefinition这一篇就Over
Spring 解析注册BeanDefinition这一篇就Over

一、简介:学习过Spring框架的人一定都会听过Spring的IoC(控制反转)、DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC、...

2023-03-20 14:53 xiyangw

域、模块、空间、闭包,你真的懂了吗?(模块控制域与作用域的关系)

Javascript有一个特性叫做域。尽管对于初学者来说理解域是有难度的,但我会尽力用最简单的方式让你理解域。理解域能让你的代码更优秀,减少错误,及有助于你做出更强大的模式设计。什么是域域是在运行时,...

这一次搞懂Spring自定义标签以及注解解析原理
这一次搞懂Spring自定义标签以及注解解析原理

前言在上一篇文章中分析了Spring是如何解析默认标签的,并封装为BeanDefinition注册到缓存中,这一篇就来看看对于像context这种自定义标签是如...

2023-03-20 14:53 xiyangw

前端基础进阶(七)-前端工程师最容易出错的问题-this关键字
前端基础进阶(七)-前端工程师最容易出错的问题-this关键字

我们在学习JavaScript的时候,因为对一些概念不是很清楚,但是又会通过一些简洁的方式把它给记下来,那么这样自己记下来的概念和真正的概念产生了很强的偏差.当...

2023-03-20 14:52 xiyangw

深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)
深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)

建议学习:膜拜!阿里内部都在强推的K8S(kubernetes)学习指南,不能再详细了最近也一直在加班,处理项目中的事情,发现问题越多越是感觉自己的能力不足,...

2023-03-20 14:52 xiyangw

Spring 是如何解析 bean 标签的?(spring beans标签)
Spring 是如何解析 bean 标签的?(spring beans标签)

前情回顾上回「SpringIoC容器初始化(2)」说到了Spring如何解析我们定义的<bean>标签,代码跟进了一层又一层,跋山涉水,...

2023-03-20 14:52 xiyangw

快速了解JavaScript文本框操作(javascript文本框代码)
快速了解JavaScript文本框操作(javascript文本框代码)

HTML中使用<input>元素表示单行输入框和<textarea>元素表示多行文本框。HTML中使用的<input&...

2023-03-20 14:51 xiyangw

荐读|30道JavaOOP面试题,可以和面试官扯皮了
荐读|30道JavaOOP面试题,可以和面试官扯皮了

面试是我们每个人都要经历的事情,大部分人且不止一次,今天给大家准备了30道JavaOOP面试题,希望能够帮助到对Java感兴趣的同学,让大家在找工作的时候能够...

2023-03-20 14:51 xiyangw

源码系列——mybatis源码刨析总结,下(mybatis源码分析)
源码系列——mybatis源码刨析总结,下(mybatis源码分析)

接上文简答题一.1.Mybatis动态sql是做什么的?1.动态sql就是根据条件标签动态的拼接sql,包括判空,循环,拼接等2.哪些动态sql?动态sql大...

2023-03-20 14:50 xiyangw

Java面试题(第二弹)(java面试题及答案整理)
Java面试题(第二弹)(java面试题及答案整理)

1.抽象类和接口的区别?接口可以被多重implements,抽象类只能被单一extends接口只有定义,抽象类可以有定义和实现接口的字段定义默认为:public...

2023-03-20 14:50 xiyangw

mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)
mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)

大纲动态sql使用示例SqlSource和BoundSql以及实现类LanguageDriver以及实现类SqlNode以及实现类动态sql解...

2023-03-20 14:50 xiyangw

第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)
第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)

本内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。文本节点用Text类型表示,包含的是可以按字面解释...

2023-03-20 14:49 xiyangw

Qt读写三种文件(qt读取文件数据并赋值给变量)

第一种INI配置文件.ini文件是InitializationFile的缩写,即初始化文件。除了windows现在很多其他操作系统下面的应用软件也有.ini文件,用来配置应用软件以实现不同用户的要...

取消回复欢迎 发表评论: