DBA入门之路:由浅入深的总结学习法

有很多DBA朋友在入门时总觉得不得路径,长久的徘徊于门外,而过来人的经验又往往高屋建瓴难以落地,两者总觉得难以对接起来,如何才能解决这个问题呢?

我一直推荐的学习方法,之前在文章 DBA入门之路:学习与进阶之经验谈 中就有描述。如果能讲这些方法和实践一一对应起来,我想就可以更形象的帮助一些朋友。结合今天的一个小案例,和大家做一个分享。

回顾:由点及面由浅入深的学习方案

我一直主张"由点到线再及面"的学习方法。特别是对于初学者,如果没有经过专门的培训和系统学习,那么自己通过实践的学习和思考就应当深入,在知识上,从某个角度来说,是"不患寡,而患不精深"。在我们遇到问题时,就应该不断深入研究,直至问题的核心本质,这样通过一个案例或实际问题的诊断学习和研究,我们就可以带动很多连带知识的学习,这样从一个点深入下去就形成一条线,再横向扩展就可以形成一个知识网,解决和研究的问题多了,就可以逐渐覆盖一个面,形成一个知识体系,这样慢慢的你就会觉得学习不再困难,而是一件得心应手的事情。

案例:Expdp ORA-31626 错误的启示

今天有朋友在‘云和恩墨大讲堂’提出一个关于expdp的导出问题。

操作:

expdp system/password directory=expdir full=y dumpfile=20151230.dmp logfile=20151230.log

错误提示:

UDE-00008: 操作产生了 ORACLE 错误 31626 ORA-31626: 作业不存在 ORA-39086: 无法检索作业信息 ORA-06512: 在 "SYS.DBMS_DATAPUMP", line 2772 ORA-06512: 在 "SYS.DBMS_DATAPUMP", line 3886 ORA-06512: 在 line 1

在面对错误的时候,DBA不能有畏缩的心理,一定要认真阅读错误,对于这个提示,其实可以看到明确的信息“作业不存在”,也就是JOB检测不到了,那么要么这个JOB执行完了,要么异常中止了。

建议:

以下两条是我们给所有初学者的建议,收集信息、保护现场,这是寻求解决和帮助的必要手段。

在面对任何错误时,都应当详细的排查所有可以获得的日志; 在面对复杂问题时,一定要得出结论后再操作,在操作前尽量保留可回退的现场。

其实在获取了充足的信息之后,无论是提问还是自己排查都容易接近真相。

结论:

检查导出操作日志,可以看到导出是完整成功的,我们由此可以判定导出的正常执行,那么前台抛出的错误可以安全的忽略。当然也可以测试一下,判定导出文件是完好的。到这一步判断,是每一个工程师应该自主做出的。

. . 导出了 "SYSTEM"."REPCAT$_USER_ATH"0 KB 0 行 . . 导出了 "SYSTEM"."REPCAT$_USER_PS" 0 KB 0 行 . . 导出了 "SYSTEM"."SQLPLS_T_PROFILE" 0 KB 0 行 . . 导出了 "TSMSYS"."SRS$" 0 KB 0 行 已成功加载/卸载了主表 "SYSTEM"."SYS_EXPORT_FULL_01" *************************************************************************** SYSTEM.SYS_EXPORT_FULL_01 的转储文件集为: /oradata/20151230.dmp 作业 "SYSTEM"."SYS_EXPORT_FULL_01" 已于 09:41:33 成功完成

进一步的确认:

通过MOS官网进一步的确认问题,是Oracle DBA的必要技能。在MOS上可以找到这个问题的相关BUG,BUG号是5969934。

Bug 5969934 : EXPDP CLIENT GETS UDE-00008 ORA-31626 WHILE THE SERVER SIDE EXPORT IS OK

这个BUG的从 10.2.0.2 到 11.2.0.3,都可能发生,其根本原因是JOB的执行和客户端的通讯出现问题。

Oracle Support的提示也包括检查日志:

Relying on information in the log file is one way to verify that the job actually completed successfully.

问题源自:DBMS_DATAPUMP.GET_STAUS 的调用。在以下的MOS回复中,可以看到,执行EXPDP的工作是通过DBMS_DATAPUMP包进行的,其中GET_STAUS用于状态获取。当获取状态时发现JOB进程失踪,就抛出前台的异常,而从日志可以判断,事实上是导出已经完成。如果EXPDP能够争取反馈给客户端完成状态,那么这个问题就不会出现了。

The expdp client makes calls to DBMS_DATAPUMP package to start and monitor export job. Once the export job is underway, the client just monitors the job status by issuing DBMS_DATAPUMP.GET_STAUS. Therefore, if the export logfile says “job successfully completed”, the dump file generated by the job should be fine. You can simply ignore the errors, since the dump file is still valid for an import.

这是一个简单的例子,我们希望大家也能够分析、总结自己遇到的问题,如此即可以分享给大家,又可以提升自我的学习和总结能力。

这个案例,从一个最简单的错误分析猜测,到日志检查判断,进一步确认BUG根源,由此又可以进一步了解EXPDP的工作原理,这就是由浅入深,逐层递进,形成思路和方法。在遇到任何问题时,都可以借鉴这样的过程和方法。

点滴知识,在于分享;授人玫瑰,手有余香。欢迎大家向我们投稿,或者在微信群参与分享。

近期文章分享

【往期文章】

Oracle 12c ASM 防火防盗新特性揭秘

DBA入门之路:学习与进阶之经验谈

DBA入门之路:关于日常工作的建议

三十八载,Oracle伴我同行—记我的成长之路

从Approx_Count_Distinct到M7的CPU集成

诊断工具与方法:从OS到数据库

Cloud时代DBA的DevOps最佳实践 - SQL 审核

Oracle Database 12.2新特性详解

云和恩墨

数据驱动,成就未来。整合业界顶尖的技术与合作伙伴资源,围绕数据及相关领域,提供解决方案和专业服务。

业务架构

电子渠道(网络销售)分析系统、数据治理

IT基础架构

分布式存储解决方案

数据架构

Oracle DB2 MySQL NoSQL

专项服务:架构/安全/容灾/优化/整合/升级/迁移

运维服务:运维服务 代维服务

人才培养:个人认证 企业内训

软件产品:SQL审核、监控、数据恢复

应用架构

应用软件开发管控:数据建模 | SQL审核和优化

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2015-12-30

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏阮一峰的网络日志

学习C语言的教材

我的C语言是自学的,这些年看过不少教材。 下面,我对其中一些教材做个点评。 1. How to Think Like a Computer Scientist:...

2889
来自专栏申龙斌的程序人生

学会10多种语言是种什么样的体验?

80年代末,我第一次接触了Apple II电脑上的BASIC编程语言,从此走上了一条程序人生。十多年前我在博客园上开通了自己的博客,由于下象棋时经常出点“毒”招...

2926
来自专栏大咖说

贝壳金控赵文乐:基于 Spring Cloud 的服务治理实践

文章原创首发于微信公众号「 TGO 鲲鹏会」,原文地址:贝壳金控赵文乐:基于 Spring Cloud 的服务治理实践

1100
来自专栏编程

有效的学习C语言,易懂,趣味,实用的成长之路

学好C语言的秘诀就是1234:“一字真言,两种态度,三个框架,四项注意”。 各位看官,学好C语言,其实只需一个字,那就是“编”。 学习C语言,乃至学习所有的语言...

1876
来自专栏全华班

如何实现一个优质的微服务框架

摘要: 一个优质的微服务框架需要考虑的要素众多,在满足微服务设计理念的前提下,也是一个不断实践优化的过程。 本文讲述了整个 开源微服务框架 Apache Ser...

1694
来自专栏PHP技术

程序员如何做到「编程速度又快,Bug 数量又少」?

最近看到一个Quora中的回答,答到心坎上。译文引用自伯乐在线:   三个程序员被要求穿过一片田地,到达另一侧的房子。   菜鸟程序员目测了一下之间很短的距离,...

2636
来自专栏杨建荣的学习笔记

最近在读的一些文章

我犯下的代价惨痛的错误使我改变了看问题的角度,从“我知道我是对的”变成了“我怎么知道我是对的”。这些错误让我养成了谦逊的习惯,我需要用谦逊平衡我的勇敢。—《原则...

562
来自专栏Python中文社区

Python金融股票爬虫实战源码大全

Stock [1]- 终端实时获取股票价格,实时查询股票价格,默认查询了沪指、深指。需要安装requests库,通过调用新浪股票API,实时查询股票价格,支持查...

5277
来自专栏华章科技

程序员那些牛逼闪闪的禁术,看到第二条我就忍不住哈哈哈哈哈哈哈哈

在和产品经理进行需求对峙时,一本正经地把不好/不想实现的功能通过玄学等方式口述出来,让产品经理当场懵逼,知难而退。

562
来自专栏Java编程

一个牛人给Java初学者的建议

先说什么是java java是一种面向对象语言,真正的面向对象,任何函数和变量都以类(class)封装起来 至于什么是对象什么是类,我就不废话了 关于这两个概念...

2.4K3

扫码关注云+社区