公司最近的客户需要在LINUX系统中做数据迁移,备份出来的内容数据库物理文件,回档日志和SpfileXXXX

客户用的是北京霆智的X8备份阵列,X8与数据库服务器都放在IDC机所,IDC机房与客户之间用VPN相连,我这边只能通过远程连接到客户办公室的一个笔记本电脑作为跳板机在远程到ORACLE服务器与ORACLE恢复机,恢复机客户的机房;

首先就是下载X8中的备份,X8每天都是备份ORACLE数据太大有时候服务器吞吐量大的时候一天愣是传不完。还好客户要的不是最新数据,我看了一下当月23号的数据,

二话不说,在恢复机上安装X8的客户端,输入用户名,下载,搞定睡觉,明天在看。。。。

诸事不顺,客户数据下载下来之后测试机放不了,磁盘满。。。。GAMEOVER

跟客户那边联系人说了一下,那边说申请加个磁盘。(汗!这个说怪我也不怪说,霆智的X8III里备份后的数据都是经过打包,压缩,分割成小块,ORACLE库物理文件+一大堆归档日志文件,我也算不出过来),最后算了一下,大约500G左右,让客户加个1T的硬盘。

过两天,客户硬盘申请完毕,开始,登录客户端,输入用户名密码,恢复,下载。睡觉!! 为什么问我总是在睡觉,因为白天在跑客户晚上才有时间远程啊,这里不得不说现在的远程工具还真方便 ,不过什么时候公司把我们家的网费报销一下?-_-|||

第二天,远程在看没下载完。。。然后就是快乐的5.1劳动节了!5.1客服放假,跳板机不知道是被关机还是被拿走了,反正我是连不上了!好吧,给自己放个假,出去带家人玩了3天,回来就生病了,这IT人员的破身体真是不行!!

不过不得不说IT人员有病也能工作,5.1开班了,继续远程,这回是白天了,上去看了一下,恢复机的下载被人中断了,备份没有下载完全。马上去X8中上月23号的备份,一看傻眼了,23号的备份被覆盖了,霆智X8III的覆盖机制是7天,这TMD都半个月了。我也是真傻眼,下载了一个最新的少的那两个文件想试试能不能恢复。

这回不知道IDC机房的网速怎么这么给力,25M/s 晚上就下载完了,下班回来看了连了一个跳板机在线,两分钟吃完饭开搞

跟我一样的小白从这里开看,上面都是啰嗦!

切换Linux用户:su - oracle

把SPfileXXXX文件复制到ORACLE_HOME/dbs/文件夹下:

CP /data2/Oracle\ Database\ Server/oracle/app/oracle/product/11.2.0/db_1/dbs/spfileXXXX.ora   /app/oracle/product/11.2.0.4.0/dbhome_1/dbs/spfileXXXX.ora

创建实例密码文件:orapwd file=/oracle/app/oracle/product/11.2.0/db_1/dbs/XXXX password=111111

设置当前实例:export ORACLE_SID=XXXX

进SQLPLUS:sqlqlus / as sysdba

创建pfileXXXX.ora:

create  /app/oracle/product/11.2.0.4.0/dbhome_1/dbs/pfileXXXX.ora  /app/oracle/product/11.2.0.4.0/dbhome_1/dbs/spfileXXXX.ora

查看一下pfile文件:

cat /app/oracle/product/11.2.0.4.0/dbhome_1/dbs/pfileXXXX.ora

主要看一里面的路径,其它一般都不用改(这次我就遇到了不一般的情况,这个一会儿在说)

看完了头疼了一下,ORACLE主目录不一样,数据文件存放路径不一样,就没有一样的;

看了一下磁盘空间

根目录 / 还有340M

tmpfs目录空间 总大小 4G,使用率80%

看完之后头疼了第二下,在难也要搞!稍微清理了一下根目录,腾出6G空间,其它全部用文件链接,linux的文件链接真是个好东西

用软链接命令 ls: ls -s 源文件 目标文件或s -s 源文件夹 目标文件夹,很长一大串的文件链接和文件夹链接,测试一下,全部OK

sqlplus / as sysdba

startup mount pfile=$ORACLE_HOME/dbs/spfileXXXX.ora; 启动实例

报错:ORA-00845

这个简单,刚才说了tmpfs目录总大小是4G,被使用了80%,说明这个Oracle里面还有其它实例,停了它 shutdown immediate;

sqlplus / as sysdba

startup mount pfile=$ORACLE_HOME/dbs/spfileXXXX.ora; 启动实例

继续报错:ORA-00845

说明4G不够,我们用的,加大到8G,这样一来,我们的根目录又小了,应该还有2G了

mount -o size=8G -o nr_inodes=1000000 -o noatime,nodiratime -o remount /dev/shm

上面这个命令要在root用户下执行,我用shell连接的Linux,用多个命令窗口,这样方便多了,要不然来回切用户的话还要重新初始化当前Oracle实例;

sqlplus / as sysdba

startup mount pfile=$ORACLE_HOME/dbs/spfileXXXX.ora; 启动实例

继续继续报错:ORA-00845

还是不够大,看看pfileXXX.ora文件里的 memory_target 值,我的天,40多G,改吧,恢复机是没办法达到这个要求的,去掉一位数

sqlplus / as sysdba

startup mount pfile=$ORACLE_HOME/dbs/spfileXXXX.ora; 启动实例

这回成功到mount 模式下了,用命令打开一下事实,alter database open resetlogs;

system01.dbf 报错 ORA-01113

restore database;报错 一致性错误
recover database; 报错一致性错误,我想不起来错误号了,这里说明一下,我的控制文件是4月23号的,部分表空间文件是5月6号的

听说可以用recover datafile 来恢复文件介质,好像是叫不一致性恢复。反正我没试过,哪位高手用过教我一下可好?

进RMAN用归档文件恢复一下试试 :recover database until sequence=21709 thread=1;

还是报错,缺少一在堆归档日志文件。下载了最新的控制文件也不行,最新的归档日志文件,告诉我要从SCN编号为xxxxxxxxxxxxx的开始恢复

完全失败,一看时间,半夜1点多了,睡觉吧!把旧的备份文件全部删除,重新下载。3点睡吧

第二天,下载完是晚上8点半了,远程链接跳板机,一个对话框蹦出来了,电量不足,看了下笔记本,插着电源呢?看了下跳板机,天啊,没电了,发微信给客户,公司有人没,笔记本没电了,客户回:公司没人,走的时候电源接着呢,可能是客户走了之后有同事把电源拔走了;

没办法,看了一下,8%电量,抓紧时间,干吧

还好昨天晚上把软链接都建好了,什么都不用改,Pfile文件也都改好了,抓紧时间,启动

报错:控制文件不让写入

越忙越乱,忘记从X8备份阵列下载下来的文件用户跟用户组都是root了

改Linux用户及用户组命令: chown -R oracle:oinstall 目标文件夹

在启动,成功!

到RMAN里恢复归档文件

屏幕一黑,完了,跳板机没电了,现在还早,不到9点,开个博客吧,把这段经历写下来,以后回忆一下!

明天继续!

Oracle For Linux 恢复日记 霆智X8III的更多相关文章

  1. rman恢复方案和oracle异机恢复

    这篇文章主要介绍了rman恢复方案和oracle异机恢复,需要的朋友可以参考下 注:①恢复的前提是已经做好备份②完全恢复数据库是数据库遇到故障,在恢复时候没有丢失任何已经提交事物数据的恢复不完全恢复数 ...

  2. Linux学习日记-使用EF6 Code First(四)

    一.在linux上使用EF 开发环境 VS2013+mono 3.10.0 +EF 6.1.0 先检测一下EF是不是6的 如果不是  请参阅 Linux学习日记-EF6的安装升级(三) 由于我的数据库 ...

  3. 大并发连接的oracle在Linux下内存不足的问题的分析

    大并发连接的oracle在Linux下内存不足的问题的分析 2010-01-28 20:06:21 分类: Oracle 最近一台装有Rhel5.3的40G内存的机器上有一个oracle数据库,数据库 ...

  4. Oracle Enterprise Linux 64-bit下安装apache-tomcat-7.0.53步骤

    測试环境:VMware Workstation v9.0.2软件中安装好Oracle Enterprise Linux 5.8 64-bit虚拟机 安装软件:jdk-7u40-linux-x64.rp ...

  5. Oracle Enterprise Linux 64-bit 下Oracle11g的监听配置修改及测试步骤

    测试环境:Oracle Enterprise Linux 64-bit (5.8版本) + Oracle 11g 64位 相关说明: Oracle11g64位软件的安装位置为/u01/app/orac ...

  6. Linux管理日记(二)

    14  启动内网端口转发 ### 2. 查看IP以及网卡信息 # 可以发现, eth0 的地址 inet addr:10.144.7.195, 此为内网网卡 # 公网网卡, eth1 的地址 inet ...

  7. Oracle Enterprise Linux 6.4 下挂载ISCSI 设备

    Oracle Enterprise Linux 6.4 下挂载ISCSI 设备一.发现① 要求安装iscsi客户端软件   yum install iscsi-initiator-utils ② 发现 ...

  8. Oracle 备份、恢复单表或多表数据步骤

    Oracle 备份.恢复单表或多表数据步骤,适用于 Oracle 8.9.10.        *备份单表或多表数据: exp user/password@server file=filefullpa ...

  9. Oracle Enterprise Linux 64-bit 下Oracle11g的监听配置改动及測试步骤

    測试环境:Oracle Enterprise Linux 64-bit (5.8版本号) + Oracle 11g 64位 相关说明: Oracle11g64位软件的安装位置为/u01/app/ora ...

随机推荐

  1. Extended Traffic LightOJ - 1074

    题目链接:https://vjudge.net/problem/LightOJ-1074 思路:(busyness of destination - busyness of source)3 可能会是 ...

  2. 使用Supervisor管理Django应用进程

    官方文档 1.安装 pip install supervisor 2.使用说明 2.1  查看默认配置 echo_supervisord_conf 一般情况下,不需要去修改默认配置,而是将默认配置重定 ...

  3. 201871020225-牟星源 《面向对象程序设计(java)》课程学习进度条

    <2019面向对象程序设计(java)课程学习进度条> 周次 (阅读/编写)代码行数 发布博客量/评论他人博客数量 课余学习时间(小时) 学习收获最大的程序 阅读或编译让我 第一周 25/ ...

  4. 数据库备份 DBS(Database Backup),知识点

    资料 网址 什么是DBS https://help.aliyun.com/document_detail/59133.html?spm=5176.13685554.103.6.3fa463f9CDwW ...

  5. 08-numpy-笔记-sum

    求和: axis = 0 按列求和 axis = 1 按行求和 >>> import numpy as np >>> a = np.mat([[1,2,3],[4, ...

  6. C# Cef winform 脚本的执行 踩过的坑

    先从后端代码 如何执行js 代码谈起; 一个简单的需求: 在winform上点击一个按钮,实现登录信息的填入 流程: 就是让C#去运行一段脚本,. 运行的方式有两种, 异步与同步, 因为CEF是一帧一 ...

  7. 优先队列优化的 Huffman树 建立

    如果用vector实现,在运行时遍历寻找最小的两个节点,时间复杂度为O(N^2) 但是我们可以用priority_queue优化,达到O(N logN)的时间复杂度 需要注意的是priority_qu ...

  8. some 模板

    注:此博客部分模板(也有可能是全部)来源于其它大佬的bolg 1.高精度 #include<bits/stdc++.h> #define MAXN 501 ; ; inline ; : ; ...

  9. ZROI 暑期高端峰会 A班 Day4 树上数据结构

    FBI Warning:本文含有大量人类的本质之一. 你经历过绝望吗? [ZJOI2007]捉迷藏 询问树上最远黑点对. 动态边分治可以比点分治少一个 \(\log\). bzoj3730 咕了. [ ...

  10. Mikrotik: Setup SSTP Server for Windows 10 Client

    原文: http://www.dr0u.com/mikrotik-setup-sstp-server-for-windows-10-client/ Basic how-to on SSTP for a ...