SQLSERVER DBA容易犯的十个错误

SQLSERVER DBA容易犯的十个错误

翻译自:http://sqlsentry.tv/top-10-administrative-mistakes-on-sql-server/

除了排名前十的错误之外,其他排名靠前的错误

抛开SQL Server方面的错误,这些错误主要体现在开发或者是设计的时候:

1、不合理的规范和不合理的数据库设计

2、没有设计好可伸缩性的需求

3、没有数据库性能基线或基准

4、索引的问题

5、对语句调优不够重视



错误倒数第十位(磁盘-只要磁盘空间充足就不理会磁盘IO了)

经常只考虑磁盘子系统的磁盘空间,不理会IO负载

没有足够的专业知识,有可能会出现以下问题:

选择了不恰当的容错机制

IO性能不足:

OLTP系统需要较高的TPS

OLAP需要较高的传输速度

选择了较差的RAID类型、控制器、通道

没有足够的磁盘主轴

SSD固态硬盘可以改变这个IO游戏的规则



错误倒数第九位(对业务规则不理解)

作为一位IT PRO,你应该知道SQL Server内部是如何工作的

什么是checkpoint?什么是Lazy writer?

TempDB的使用方式是怎样的?plan cache里面有什么?

你要知道DBA是企业资产数据的保护者

业务和IT之间的联系,你应该知道如何以及在何种方式使用您的服务器

当程序down掉的时候谁会在意,每分钟的停机时间公司需要损失多少钱?

商业周期是什么?

什么时候是最好的宕机?

什么样的的基线、基准是正常的?



错误倒数第八位(没有一套自己的故障排除方法)

危急时,DBA需要一个强大的、一步一步的方法进行根源分析。

如果没有,你将会:

1、错过了数据库的错误和问题

2、由于错误引起的数据丢失或者灾难性的问题

3、很差的响应时间或者会违反SLA服务级别协议

4、失去信誉

如果您还没有一套方法论,那么可以参考

End-to-End Troubleshooting on http://SQLSentry.TV

SQL Server Troubleshooting Guide by J. Kehayias on http://www.simple-talk.com



错误倒数第七位(基本上都使用默认值)

使用默认值安装SQL Server安装的目的是尽快让服务器启动并运行

但是这样会造成运行时得不到最优,例如如下设置:

数据库自动增长 、自动收缩

数据库自动增长的大小

默认文件组

一些小问题也会成为大问题

1、并行度

2、填充因子

其他一些服务器和数据库的设置选项



错误倒数第六位(在事后才想起数据库的安全性)

现在互联网上面的SQL 注入漏洞成为第一位

值得注意的是,十年前很多关于防SQL注入的方法,直到今天我们依然继续在使用

提前计划好使问题最小化:

确保您的服务器上运行的应用程序只有最小的权限,并且这个权限能够保证你的程序能正常运行

你的服务器暴露面有多少?暴露越多受攻击面就越广

谁有权访问你的服务器?

当出问题的时候你如何找出谁开了一些不恰当的权限?



错误倒数第五位(没有充分使用自动化)

自动化能减轻DBA的很多工作,讽刺的是,一开始DBA就需要将大量的工作进行自动化

没有自动化,DBA必须面对下面问题:

如果全靠人去操作有可能容易出错和遗漏

当服务器的数量增加的时候你的工作将会加倍

使用自动化的例子:

自动报错通知

维护计划作业

基本都是脚本,而不需要使用GUI



错误倒数第四位(在工作上使用了不合适的功能或技术)

DBA是公司里IT程序的“性能工程师”

他的工作是对于每个业务需求使用最合适的功能

否则就会:

使应用程序变复杂

过度的资源消耗

有一条定理:没有IT的项目,只有利用IT解决商业项目



错误倒数第三位(对管理的变更很冷漠)

变更管理是很重要的!没有管理变更,dba将面临:

如果不变,那么他们所做的事情将会更加糟糕

改变控制对改变管理

合理的管理改变意味着:

在规定好的时间限制里面预先规划好时间

在生产环境里面,管理改变的好坏会被验证和测试

改变是隔离的、原子的、可逆的



错误倒数第二位(不恰当的维护计划)

适当的预防性维护(PM)可以帮助您:

在出现问题之前抓住问题

能确定优化方向

用户在系统上执行资源密集型的操作会减少

预防性维护在SQLSERVER里应该包括

数据库一致性检查和DBCC CHECKIDENT

备份和还原数据库的时候使用校验选项

索引填充因子、碎片整理

索引统计信息

不要依赖数据库维护计划向导!!

不用重复做轮子,有很多维护计划已经有仙人帮我们写好了

www.sqlfool.com

www.olahallengren.com



错误倒数第一位(备份和还原)

DBA不会经常验证备份的可用性

这会带来一些问题:

您对客户的SLA不能保证,还有RTO和RPO不能保证

没人能确保备份可用

如有不对的地方,欢迎大家拍砖o(∩_∩)o 

SQLSERVER DBA容易犯的十个错误,布布扣,bubuko.com

时间: 2024-11-04 11:12:09

SQLSERVER DBA容易犯的十个错误的相关文章

Python程序员最常犯的十个错误

不管是在学习还是工作过程中,人都会犯错.虽然Python的语法简单.灵活,但也一样存在一些不小的坑,一不小心,初学者和资深Python程序员都有可能会栽跟头.本文是Toptal网站的程序员梳理的10大常见错误,非常有参考意义.大家在开发过程中需要格外注意.译文中如有理解错误的地方,可以在网站留言或通过微信公众号编程派回复. 常见错误1:错误地将表达式作为函数的默认参数 在Python中,我们可以为函数的某个参数设置默认值,使该参数成为可选参数.虽然这是一个很好的语言特性,但是当默认值是可变类型时

Java开发者常犯的十个错误

翻译自:Top 10 Mistakes Java Developers Make 文章列出了Java开发者最常犯的是个错误. 1.将数组转换为ArrayList 为了将数组转换为ArrayList,开发者经常会这样做: List<String> list = Arrays.asList(arr); Arrays.asList()会返回一个ArrayList,但这个ArrayList是Arrays的私有静态类,不是java.util.ArrayList.java.util.Arrays.Arra

SQLServer DBA 三十问

很多开发人员都想成为一名DBA,也有很多人一开始就把自己定位成为一名DBA,DBA究竟需要掌握些什么知识和技能呢?以下是我 做DBA工作和面试DBA时,整理的一些DBA方面的三十个问题,三十个大问题中还有许多小的问题,涵括了SQLServer DBA比较多的技 术知识点,与大家分享下,希望给有志做DBA的朋友们一些帮助: 1. char.varchar.nvarchar之间的区别(包括用途和空间占用):xml类型查找某个节点的数据有哪些方法,哪个效率高:使用存储 过程和使用T-SQL查询数据有啥

翻译brent ozar的sqlserver dba训练课程——第一章:建立数据库服务器清单

在公司里,走进销售副总裁的办公室,询问他手下有多少销售人员.不,我的意思是你并不要那么做,他们会问你销售工具为什么那么慢. 其实我的意思是,如果你能走进他的办公室问他这个问题.我敢打赌,他会马上回答,不会有片刻犹豫.或者你走进ceo的办公室问他有多少员工,或者问cfo年度预算是多少,他们肯定会迅速回答. 因此,我的观点是,当你负责某个事物时,你需要清楚的知道你所负责的是那些. 制作一个表格清单 让我们开始制作一个表格清单.在表格的顶部,我们列出以下列: sqlserver版本(2005.2008

使用Core Data应避免的十个错误

Core Data是苹果针对Mac和iOS平台开发的一个框架,主要用来储存数据.对很多开发者来说,Core Data比较容易入手,但很难精通,如果没有正确的学习方法,你将很难真正理解它,更不用说精通了.很多开发者常常在这方面犯一些错误,而这篇文章列出了开发者在iOS开发过程中使用Core Data常见的一些错误,并对如何避免这些错误进行了分析.   1.不了解关键术语 对于iOS开发者来说,会使用Core Data是一项必备技能. 没有它,很多app都不会存在.当在互联网上四处搜索Core D

web开发易犯的低级错误

web开发过程中,我们经常会犯一些小错误,但是却浪费了大量的时间,这里总结几个错误,以示警醒. 1.调试js的时候,明明设置了断点,但是就是不走断点.期初遇到这个问题,我不停的修改js代码,修改网页的html,不停的刷新浏览器,以为缓存的问题.结果后来发现,是因为有多出引入js,当我设置了一个断点,而程序走的却是其他的js,这个问题如果发现了,就根本不是问题,但是如果没发现,就要浪费你很长的时间咯. 2.提交表单,有的field的值却没有传递到后台.明明写了name属性啊,明明其他的field都

再聪明,你也会常犯的数据分析错误 &nbsp;

如果你不了解大数据,你就不会明白大数据的核心价值有多大.当然你不光要了解大数据,还要学会科学的数据分析方法,才能让大数据产生价值.而在数据分析过程中,聪明的数据分析师也会常犯些错误,纽带线CRM小编跟大家分享这些常犯的错误,在以后应用过程中尽量避免. 错把相关性当成因果性  correlation vs. causation 经典的冰淇凌销量和游泳溺水人数成正比的数据,这并不能说明冰淇凌销量的增加会导致更多的人溺水,而只能说明二者相关,比如因为天热所以二者数量都增加了.这个例子比较明显,说起来可

我(作为一名开发者)所犯过的错误[转]

投递人 itwriter 发布于 2016-11-10 17:49 评论(6) 有657人阅读 原文链接 [收藏] ? ? 英文原文:Mistakes I made (as a developer) 我 2006 年开始工作,至今已经 10 年.10 年是个里程碑,我开始回顾自己曾经犯过的错误,以及我希望从同行那里得到什么类型的忠告.一切都在快速改变,10 年了,我不能确定这些秘诀是否还有用. 不管您是新人还是老手,您都会发现我的话是有用的.我期待听到您的观点,所以请不吝赐教给我回信. 坚持使用

java继承会犯的小错误

注意事项:阅读本文前应该先了解java的继承.本文定位为已经继承基础知识. 一:试图覆盖私有方法 先上代码 1 public class Father { 2 3 private void print() { 4 System.out.println("private print"); 5 } 6 7 public static void main(String[] args) { 8 Father father = new Son(); 9 father.print(); 10 }