做数据库管理员 需要了解哪些技能?

参与7

2同行回答

匿名用户匿名用户
数据库管理员,需要了解哪些技能?解读:1、数据库管理员 是理解成 运维型DBA 还是 专家型DBA?2、技能:仅仅是了解是不够的,需要掌握才行建议:1、数据库管理员:分析问题、排查故障的能力一定是至关重要的,所以一定要有怀疑一切、根据日志信息、问题现状去猜测分析 的逻辑能力;其...显示全部

数据库管理员,需要了解哪些技能?

解读:

1、数据库管理员 是理解成 运维型DBA 还是 专家型DBA?

2、技能:仅仅是了解是不够的,需要掌握才行

建议:

1、数据库管理员:分析问题、排查故障的能力一定是至关重要的,所以一定要有怀疑一切、根据日志信息、问题现状去猜测分析 的逻辑能力;其次,一定要至少学习掌握分析解决Oracle数据库故障、MySQL数据库故障、PG数据库故障的能力

1.1 Oracle数据库的日志是非常完善的,检测工具也很多,有利于培养逻辑分析判断能力

1.2 国产数据库 要么MySQL体系的、要么是PG体系的,所以掌握这两款开源数据库故障分析解决的能力,就间接等于掌握国产数据库的的技能,大概率国产数据库产品在产品化过程不同则有较多差异,至少大方向不会错

2、数据库管理员:最好是掌握SQL调优能力,这样有利于跟业务系统研发人员一起沟通配合

收起
软件开发 · 2023-09-24
浏览354
bjc96333bjc96333研发工程师bjc
1.理解数据备份/恢复与灾难恢复。恢复已损坏的数据库是每个DBA最应该掌握的。不知道这个怎么做,就不能说是一名DBA。DBA需要完全理解数据库所有可能的备份与恢复方法,以及不同备份方法与不同恢复策略的对应关系。此外,DBA还需要与业务部门合作,一起确认业务需求,明确用户能够...显示全部

1.理解数据备份/恢复与灾难恢复。

恢复已损坏的数据库是每个DBA最应该掌握的。不知道这个怎么做,就不能说是一名DBA。DBA需要完全理解数据库所有可能的备份与恢复方法,以及不同备份方法与不同恢复策略的对应关系。此外,DBA还需要与业务部门合作,一起确认业务需求,明确用户能够容忍的数据丢失底线。此外,业务用户还需要确定在系统故障情况下,他们的业务能够维持多长时间。理解这些需求可以帮助DBA开发出一个满足业务用户要求的备份/恢复方法。DBA一定要定期测试备份与恢复流程,保证他们有能力恢复业务数据,满足企业所规定的业务数据丢失与恢复要求。

2.工具集的使用

工具集应该包含不同的小代码片段,它们可以快速诊断问题或执行一个特定的任务。这些工具脚本应该按DBA的活动类型归类,如备份、索引维护、性能优化、容量管理等。由于总是会执行新任务、发现新问题或找到其他人开发的好用脚本,因此一个优秀的DBA会不断地给这个工具集增加新脚本。此外,他还应该了解网上哪里能够找到一些免费的工具和脚本。一个好的DBA知道什么时候可以利用其他人编写的脚本,从而节省自己的时间和改进自己的工具集。

3.知道如何快速寻找答案

数据库每天会面临各种各样故障的挑战,从硬件到网络,从性能压力到程序bug,DBA都要从容应对,一一排除。即使是数据库大牛,也不可能是无所不知的,因此每个DBA一方面需要不断修炼自己,积累操作系统、网络、硬件、存储系统、分布式计算等理论基础,另一方面还要有快速寻找新问题解决方法的能力。如果一个数据库实例不能按预期方式运转,那么快速寻找新问题的解决方法也是一个重要能力。一个好的DBA知道如何快速地在网上查找一个未知问题的解决方法。此外,他们也可能已经知道了一些非常不错的网站,也知道业界专家会提供一些好建议,同时知道什么时候应该忽略一些不好的建议。你可能想象不到,确实有一些建议不值得参考。

4.知道如何监控和优化数据库性能

对于任何数据库产品,性能都尤其重要,它会直接影响产品的响应速度和用户体验。对于一个DBA来说,性能优化一般需要占用50%的工作时间,因此DBA需要知道如何监控和优化数据性能。

5.研究新版本

在技术领域中,没有什么是一成不变的。每隔两三年,主流数据库厂商都会发布一个大版本的更新。DBA应该紧跟新版本所作的修改,它们可能有许多变化方法,最好的方法是迟早介入这个过程。测试版开放后马上下载和安装,尽快掌握第一手使用经验。一名好的DBA总是走在学习排头兵,总是会第一时间安装和测试新版本。这样他们就可以尽早理解新特性,然后提出一些合理的新建议,帮助组织更好地利用新版本数据库。

6.理解代码最佳实践方法

DBA应该了解如何编写高效的代码。有许多糟糕的编码实践方法会导致拙劣的性能。一名好的DBA要能够理解和识别这些糟糕的编码实践方法,知道如何修改这些烂代码,让它们变成高效代码。此外,他们还要记录下写代码的最佳实践方法,并且将这些实践方法分享给其他人。

7.持续不断地学习

数据库及其组件涉及面非常广。DBA很难理解一个技术的方方面面。DBA需要持续学习如何管理数据库。这个可以订阅一些定期发布数据库新技巧和新文章的社区网站。此外,还可以加入一些用户组织,可以在周末参加一些当地的免费沙龙活动。

8.数据库安全性

DBA应该完全掌握如何实现数据库的安全访问。他们应该理解操作系统身份验证和数据库身份验证的区别,以及它们各自的使用场合。他们应该理解如何使用数据库角色来管理不同类型用户的安全配置。他们应该理解连接数据库的端口与协议。此外,他们还应该理解如何加密整个数据库,或者加密一个数据库中一个表的某一个字段,同时理解关于加密数据的各种问题。

9.数据库设计

决定数据库性能的一个关键问题是数据库设计。DBA需要理解关于数据库设计的各个方面。他们要能够理解设计好坏的区别。他们需要理解为什么使用正确的外键约束、主键、检查约束和使用数据类型能够保持数据库的数据完整性和实现高效的数据查询与更新。

10.索引设计

数据库索引是提高应用程序检索和更新数据速度的重要环节。DBA需要知道索引的工作原理。他们应该知道聚簇索引和非聚簇索引的区别,知道这些索引的物理存储方式。DBA应该知道如何在执行计划中使用这些索引。他们应该理解如何找到索引的使用统计、理解索引碎片及如何发现丢失的索引。他们应该知道如何维护索引,以及索引统计信息对于查询引擎的重要作用。

11.容量监控与规划

数据库往往要使用大量的资源,包括CPU、内存、I/O及磁盘空间。DBA应该理解如何监控数据库所需要的不同主机资源的用量。他们应该能够理解这些资源在不同时间的使用情况,以及利用历史使用数据来规划未来的容量需求。在监控过程中,DBA应该能够预见到容量规划会在将来什么时候出现问题,然后采取必要的措施保持数据库不会因为容量限制而出现中断。

12.数据库许可证

不同的产品有许多不同的许可证授权方式。而且,同一款产品本身又有许多不同的版本。DBA应该理解所负责的数据库版本的不同授权模式。他们应该能够提供指导如何通过合理购买授权来减少数据库总拥有成本,以及如何合理利用授权方法来降低未来版本的升级成本。

13.尽可能实现自动化

DBA每天都需要执行许多的日常任务。其中一些任务需要每天执行,而另一些则每周、每月或每年执行。一名好的DBA需要理解如何高效地安排自己的时间。其中一种方法是建立工作流程,这些日常任务的自动执行。通过实现日常任务的自动化执行,DBA就可以用更多的时间去关注于数据库环境管理中遇到的严重问题。

收起
系统集成 · 2021-09-18
浏览920

提问者

zwb13588722974
其它上海英方软件股份有限公司
擅长领域: 数据库灾备

相关问题

相关资料

相关文章

问题状态

  • 发布时间:2021-09-18
  • 关注会员:3 人
  • 问题浏览:1489
  • 最近回答:2023-09-24
  • X社区推广