公司最近的客户需要在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. Zabbix 添加内存告警

    1.在Template OS Linux模板创建item Configuration-->Templates-->Template OS Linux-->items-->cre ...

  2. springboot 登录实现源代码解析

    springboot 可以使用springsecurity 作为安全框架,我们可以使用springsecurity 实现安全登录. springsecurity 是使用一系列的过滤器来实现安全的. 实 ...

  3. 为 Jupyter Notebook指定虚拟环境的 Python 解释器

    说明:本机系统为 win10 64 位, base 是集成于 Anaconda3 的 64 位的python,以下是创建虚拟环境 py366-32,安装 3.6.6 版的 32 为python,把 3 ...

  4. django url注册器组件, 响应器组件, 分页器组件

    一.url注册器的使用 1.1导入模块 from django.urls import re_path, include from .serializer import views from rest ...

  5. ubuntu配置定时任务crontab何保存退出

    crontab -e配置完成后,如何把保存并退出? 1.Ctrl+o 写入 2.出现“FIile name to Write...”,输入Enter 3.Ctrl+x 保存输出 提示“crontab: ...

  6. wordpress后台添加左侧边栏菜单如何操作

    我们有时为了方便操作会把一些特定的链接添加到wordpress后台左侧菜单栏中,这个要如何实现呢?其实不会很难,使用两个WordPress内置函数就可以解决问题,分别是add_menu_page()和 ...

  7. 04-cmake语法-STREQUAL

    STREQUAL 用于比较字符串,相同返回 true .

  8. Scrapy笔记05- Item详解

    Scrapy笔记05- Item详解 Item是保存结构数据的地方,Scrapy可以将解析结果以字典形式返回,但是Python中字典缺少结构,在大型爬虫系统中很不方便. Item提供了类字典的API, ...

  9. Pandas | 07 函数应用

    要将自定义或其他库的函数应用于Pandas对象,有三个重要的方法,下面来讨论如何使用这些方法.使用适当的方法取决于函数应用于哪个层面(DataFrame,行或列或元素). 表合理函数应用:pipe() ...

  10. 字符串的方法slice、substr、substring对比

    三个方法的参数1都代表子串开始位置,参数2在slice和substring中表示结束位置,而在substr中代表的则是子串长度: 对于负数态度,当出现在参数1的位置时,slice和substr从末尾开 ...