Chinaunix首页 | 论坛 | 博客
  • 博客访问: 35428
  • 博文数量: 7
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 45
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-25 19:09
文章分类
文章存档

2012年(7)

我的朋友

分类:

2012-03-25 19:39:15

原文地址:数据库迁移 作者:linux_kaige

mtouch数据迁移,新的服务器、软件已安装完毕。
1.检查新的服务器Oracle是否正常启动
2.新的服务器Oracle正常,则创建用户(因为之备份的数据库都是按照用户备份的),用户名、密码、表空间、权限,commit
3.scp 备份数据库文件
4.imp dmp
5.已该用户登录,检查是否正常,如字符集
6.登陆web系统,检查系统是否可以正常运行

部分操作步骤:
  1. [oracle@cms01 ~]$ sqlplus /nolog
  2. SQL*Plus: Release 11.2.0.3.0 Production on Wed Mar 21 22:32:12 2012
  3. Copyright (c) 1982, 2011, Oracle. All rights reserved.
  4. SQL> conn /as sysdba;
  5. SQL>create user le identified by 123456 fefault tablespace USERS;
  6. create user seccuessful!
  7. [oracle@cms-db ~]$ scp /home/oracle/important/dbbackyangkai.sh oracle@192.168.40.239:/home/oracle/dbback/
  8. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  9. @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @
  10. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  11. IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
  12. Someone could be eavesdropping on you right now (man-in-the-middle attack)!
  13. It is also possible that the RSA host key has just been changed.
  14. The fingerprint for the RSA key sent by the remote host is
  15. ed:8d:ce:f2:82:fa:84:ec:43:ab:ce:39:d8:2e:ed:64.
  16. Please contact your system administrator.
  17. Add correct host key in /home/oracle/.ssh/known_hosts to get rid of this message.
  18. Offending key in /home/oracle/.ssh/known_hosts:5
  19. RSA host key for 192.168.40.239 has changed and you have requested strict checking.
  20. Host key verification failed.
  21. lost connection
  22. #我从另台机器上scp过去就可以,奇怪了操!
  23. [oracle@cms-db ~]$ ping 192.168.40.239
  24. PING 192.168.40.239 (192.168.40.239) 56(84) bytes of data.
  25. 64 bytes from 192.168.40.239: icmp_seq=1 ttl=61 time=0.202 ms
  26. ------------------------------------------------------------
  27. [oracle@cms01 backup]$ imp le/123456 file=/home/oracle/dbback/home/oracle/data/backup/2012-03-20-cms.dmp
  28. Import: Release 11.2.0.3.0 - Production on Wed Mar 21 22:26:56 2012
  29. Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
  30. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
  31. With the Partitioning, OLAP, Data Mining and Real Application Testing options
  32. Export file created by EXPORT:V10.02.01 via conventional path
  33. Warning: the objects were exported by CSCMS, not by you
  34. import done in ZHS16GBK character set and UTF8 NCHAR character set
  35. IMP-00031: Must specify FULL=Y or provide FROMUSER/TOUSER or TABLES arguments
  36. IMP-00000: Import terminated unsuccessfully
  37. [oracle@cms01 backup]$
  38. [oracle@cms01 backup]$ imp le/123456 full=y file=/home/oracle/dbback/home/oracle/data/backup/2012-03-20-cms.dmp
  39. Import: Release 11.2.0.3.0 - Production on Wed Mar 21 22:28:58 2012
  40. Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
  41. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
  42. With the Partitioning, OLAP, Data Mining and Real Application Testing options
  43. Export file created by EXPORT:V10.02.01 via conventional path
  44. Warning: the objects were exported by CSCMS, not by you
  45. import done in ZHS16GBK character set and UTF8 NCHAR character set
  46. . importing CSCMS's objects into LE
  47. . . importing table "TADMIN" 8 rows imported
  48. . . importing table "TADMINLOG" 1604 rows imported
  49. . . importing table "TCLASS" 6 rows imported
  50. . . importing table "TINTERFACEINFO" 979 rows imported
  51. . . importing table "TINTERFACE_RESPONSE_TIME" 2748 rows imported
  52. . . importing table "TPURVIEW" 37 rows imported
  53. . . importing table "TREPLYOPINION" 948 rows imported
  54. . . importing table "TROLE" 2 rows imported
  55. . . importing table "TROLE_PURVIEW" 41 rows imported
  56. . . importing table "TUSEROPINION" 979 rows imported
  57. Import terminated successfully without warnings.
  58. [oracle@cms01 backup]$
  59. [oracle@cms01 ~]$ sqlplus /nolog
  60. SQL*Plus: Release 11.2.0.3.0 Production on Wed Mar 21 22:32:12 2012
  61. Copyright (c) 1982, 2011, Oracle. All rights reserved.
  62. SQL> conn /as sysdba;
  63. SQL> select * from tadmin;
  64. select * from tadmin
  65. *
  66. ERROR at line 1:
  67. ORA-00942: table or view does not exist
  68. SQL> select * from le.tadmin;
  69. CEMAIL
  70. --------------------------------------------------------------------------------
  71. CCONTENT
  72. --------------------------------------------------------------------------------
  73. ILOGINTIMES DLASTLOGINTIME CLASTLOGINIP BAUDITED BADMIN
  74. ----------- ------------------- -------------------- ---------- ----------
  75. DADDTIME DEDITTIME
  76. ------------------- -------------------
  77. CADDUSER S S IROLEID
  78. -------------------------------------------------- - - ----------
  79. 管理员 0 1 1
  80. IADMINID CADMINNAME
  81. ---------- --------------------------------------------------
  82. CADMINPASS
  83. --------------------------------------------------
  84. CUSERNAME B*** CTELPHONE
  85. ------------------------------ ---------- --------------------
  86. CMOBILE
  87. --------------------
  88. CEMAIL
  89. --------------------------------------------------------------------------------
  90. CCONTENT
  91. --------------------------------------------------------------------------------
  92. ILOGINTIMES DLASTLOGINTIME CLASTLOGINIP BAUDITED BADMIN
  93. ----------- ------------------- -------------------- ---------- ----------
  94. DADDTIME DEDITTIME
  95. ------------------- -------------------
  96. CADDUSER S S IROLEID
  97. -------------------------------------------------- - - ----------
  98. 8 rows selected.
  99. SQL>
  100. #如果用le登陆,那么操作表的时候就不用加上用户名了。
下面内容来源于网络:
  1. exp/imp命令详解
  2. exp/imp两个命令可以说是oracle中最常用的命令了.
  3. ORACLE数据库有两类备份方法。第一类为物理备份,该方法实现数据库的完整恢复,但
  4. 数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行),且需要极大的外部
  5. 存储设备,例如磁带库;第二类备份方式为逻辑备份,业务数据库采用此种方式,此方
  6. 法不需要数据库运行在归挡模式下,不但备份简单,而且可以不需要外部存储设备。
  7. 数据库逻辑备份方法
  8. ORACLE数据库的逻辑备份分为三种模式:表备份、用户备份和完全备份。
  9. 表模式
  10. 备份某个用户模式下指定的对象(表)。业务数据库通常采用这种备份方式。
  11. 若备份到本地文件,使用如下命令:
  12. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  13. feedback=100000 volsize=0
  14. file=exp_icdmain_csd_yyyymmdd.dmp
  15. log=exp_icdmain_csd_yyyymmdd.log
  16. tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
  17. 若直接备份到磁带设备,使用如下命令:
  18. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  19. feedback=100000 volsize=0
  20. file=/dev/rmt0
  21. log=exp_icdmain_csd_yyyymmdd.log
  22. tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
  23. 注:在磁盘空间允许的情况下,应先备份到本地服务器,然后再拷贝到磁带。出于速度
  24. 方面的考虑,尽量不要直接备份到磁带设备。
  25. 用户模式
  26. 备份某个用户模式下的所有对象。业务数据库通常采用这种备份方式。
  27. 若备份到本地文件,使用如下命令:
  28. exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
  29. feedback=100000 volsize=0
  30. file=exp_icdmain_yyyymmdd.dmp
  31. log=exp_icdmain_yyyymmdd.log
  32. 若直接备份到磁带设备,使用如下命令:
  33. exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
  34. feedback=100000 volsize=0
  35. file=/dev/rmt0
  36. log=exp_icdmain_yyyymmdd.log
  37. 注:如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。如果数据库数据量较小,
  38. 可采用这种办法备份。
  39. 完全模式
  40. 备份完整的数据库。业务数据库不采用这种备份方式。备份命令为:
  41. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  42. feedback=100000 volsize=0 full=y
  43. file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)
  44. log=exp_fulldb_yyyymmdd.log
  45. 对于数据库备份,建议采用增量备份,即只备份上一次备份以来更改的数据。增量备份
  46. 命令:
  47. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  48. feedback=100000 volsize=0 full=y inctype=incremental
  49. file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)
  50. log=exp_fulldb_yyyymmdd.log
  51. 注:关于增量备份必须满足下列条件:
  52. 1.
  53. 只对完整数据库备份有效,且第一次需要full=y参数,以后需要inctype=increment
  54. al参数。
  55. 2. 用户必须有EXP_FULL_DATABASE的系统角色。
  56. 3. 话务量较小时方可采用数据库备份。
  57. 4. 如果磁盘有空间,建议备份到磁盘,然后再备份到磁带。
  58. 业务数据库备份方法及周期
  59. 用EXP进行备份前,先在SYS用户下运行CATEXP.SQL文件(如果以前已运行该文件,则不
  60. 要执行这个脚本)。
  61. 没有特殊说明,不允许在客户端执行备份命令。
  62. 备份命令参照表模式下的备份命令。
  63. 从磁盘文件备份到磁带
  64. 如果首先备份到本地磁盘文件,则需要转储到磁带设备上。
  65. 1. 若需查看主机上配置的磁带设备,使用如下命令:
  66. lsdev -Cc tape
  67. 显示的结果如下例所示:
  68. rmt0 Available 30-58-00-2,0 SCSI 4mm Tape Drive
  69. rmt1 Defined  30-58-00-0,0 SCSI 4mm Tape Drive
  70. 标明Available的设备是可用的磁带设备。
  71. 2. 若需查看磁带存储的内容,使用如下命令:
  72. tar -tvf /dev/rmt0
  73. 显示的结果如下例所示:
  74. -rw-r--r-- 300 400 8089600 Jan 11 14:33:57 2001 exp_icdmain_20010111.dmp
  75. 如果显示类似如下内容,则表示该磁带存储的备份数据是从数据库直接备份到磁带上,
  76. 而非从本地磁盘转储到磁带的备份文件,因此操作系统无法识别。
  77. tar: 0511-193 An error occurred while reading from the media.
  78. There is an input or output error.
  79. tar: 0511-169 A directory checksum error on media; -267331077 not equal to
  80. 2
  81. 5626.
  82. 3. 对于新磁带或无需保留现存数据的磁带,使用如下命令:
  83. tar -cvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  84. 注:A. 该命令将无条件覆盖磁带上的现存数据。
  85.   B. 文件名不允许包含路径信息,如:/backup/exp_icdmain_yyyymmdd.dmp。
  86. 4. 对于需要保留现存数据的磁带,使用如下命令:
  87. tar -rvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  88. 注:该命令将文件exp_icdmain_yyyymmdd.dmp追加到磁带的末端,不会覆盖现存的数据
  89. 特别强调:如果备份时是从数据库直接备份到磁带上,则不可再向该磁带上追加复制任
  90. 何其他文件,否则该备份数据失效。
  91. 5. 若需将转储到磁带上的备份文件复制到本地硬盘,使用如下命令:
  92. A. 将磁带上的全部文件复制到本地硬盘的当前目录
  93. tar -xvf /dev/rmt0
  94. B. 将磁带上的指定文件复制到本地硬盘的当前目录
  95. tar -xvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  96. 备份时间安排
  97. 由于备份时对系统I/O有较大影响,所以,建议在晚上11点以后进行备份工作。
  98. 业务数据库Oracle版本的恢复
  99. 恢复方案需根据备份方案确定。由于业务数据库采用表备份和用户备份相结合的方案,
  100. 所以业务数据库的恢复需根据实际情况采用表恢复和用户恢复相结合的方案。
  101. 恢复方案
  102. 数据库的逻辑恢复分为表恢复、用户恢复、完全恢复三种模式。
  103. 表模式
  104. 此方式将根据按照表模式备份的数据进行恢复。
  105. A. 恢复备份数据的全部内容
  106. 若从本地文件恢复,使用如下命令:
  107. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  108. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  109. file=exp_icdmain_cs
  110. d_yyyymmdd.dmp
  111. log=imp_icdmain_csd_yyyymmdd.log
  112. 若从磁带设备恢复,使用如下命令:
  113. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  114. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  115. log=imp_icdmain_csd_yyyymmdd.log
  116. B. 恢复备份数据中的指定表
  117. 若从本地文件恢复,使用如下命令:
  118. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  119. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  120. file=exp_icdmain_cs
  121. d_yyyymmdd.dmp
  122. log=imp_icdmain_csd_yyyymmdd.log
  123. tables=commoninformation,serviceinfo
  124. 若从磁带设备恢复,使用如下命令:
  125. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  126. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  127. file=/dev/rmt0
  128. log=imp_icdmain_csd_yyyymmdd.log
  129. tables=commoninformation,serviceinfo
  130. 用户模式
  131. 此方式将根据按照用户模式备份的数据进行恢复。
  132. A. 恢复备份数据的全部内容
  133. 若从本地文件恢复,使用如下命令:
  134. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  135. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  136. file=exp_icdmain_yy
  137. yymmdd.dmp
  138. log=imp_icdmain_yyyymmdd.log
  139. 若从磁带设备恢复,使用如下命令:
  140. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  141. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  142. log=imp_icdmain_yyyymmdd.log
  143. B. 恢复备份数据中的指定表
  144. 若从本地文件恢复,使用如下命令:
  145. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  146. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  147. file=exp_icdmain_yy
  148. yymmdd.dmp
  149. log=imp_icdmain_yyyymmdd.log
  150. tables=commoninformation,serviceinfo
  151. 若从磁带设备恢复,使用如下命令:
  152. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  153. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  154. log=imp_icdmain_yyyymmdd.log
  155. tables=commoninformation,serviceinfo
  156. 完全模式
  157. 如果备份方式为完全模式,采用下列恢复方法:
  158. 若从本地文件恢复,使用如下命令:
  159. imp system/manager rows=y indexes=n commit=y buffer=65536
  160. feedback=100000 ignore=y volsize=0 full=y
  161. file=exp_icdmain_yyyymmdd.dmp
  162. log=imp_icdmain_yyyymmdd.log
  163. 若从磁带设备恢复,使用如下命令:
  164. imp system/manager rows=y indexes=n commit=y buffer=65536
  165. feedback=100000 ignore=y volsize=0 full=y
  166. file=/dev/rmt0
  167. log=imp_icdmain_yyyymmdd.log
  168. 参数说明
  169. 1. ignore参数
  170. Oracle在恢复数据的过程中,当恢复某个表时,该表已经存在,
  171. 就要根据ignore参数的设置来决定如何操作。
  172. 若ignore=y,Oracle不执行CREATE TABLE语句,直接将数据
  173. 插入到表中,如果插入的记录违背了约束条件,比如主键约束,
  174. 则出错的记录不会插入,但合法的记录会添加到表中。
  175. 若ignore=n,Oracle不执行CREATE TABLE语句,同时也不会
  176. 将数据插入到表中,而是忽略该表的错误,继续恢复下一个表。
  177. 2. indexes参数
  178. 在恢复数据的过程中,若indexes=n,则表上的索引不会被恢复
  179. ,但是主键对应的唯一索引将无条件恢复,这是为了保证数据
  180. 的完整性。
  181. 字符集转换
  182. 对于单字节字符集(例如US7ASCII),恢复时,数据库自动转
  183. 换为该会话的字符集(NLS_LANG参数);对于多字节字符集
  184. (例如ZHS16CGB231280),恢复时,应尽量使字符集相同
  185. (避免转换),如果要转换,目标数据库的字符集应是输出数
  186. 据库字符集的超集。
  187. 恢复方法
  188. 业务数据库采用表恢复方案。在用IMP进行恢复前,先在SYS
  189. 用户下运行CATEXP.SQL文件(如果以前已运行该文件,则
  190. 不要执行这个脚本),然后执行下列命令:
  191. IMP ICDMAIN/ICD FILE=文件名 LOG=LOG文件名 ROWS=Y
  192. COMMIT=Y BUFFER=Y IGNORE=Y TABLES=表名
  193. 注:要恢复的表名参照备份的表名
  194.   。恢复是在原表基础上累加数据
  195.   。没有特殊说明,不允许在客户端执行恢复命令
  196. 将一个数据库的某用户的所有表导到另外数据库的一个用户下面的例子  
  197. exp userid=system/manager owner=username1 file=expfile.dmp
  198. imp userid=system/manager fromuser=username1 touser=username2 ignore=y file=expfile.dmp
  199. 将一个数据库的某用户的所有表导到另外数据库的一个用户下面的例子  
  200. exp userid=system/manager owner=username1 file=expfile.dmp
  201. imp userid=system/manager fromuser=username1 touser=username2 ignore=y file=expfile.dmp
  202. ORACLE数据库有两类备份方法。第一类为物理备份,该方法实现数据库的完整恢复,但
  203. 数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行),且需要极大的外部
  204. 存储设备,例如磁带库;第二类备份方式为逻辑备份,业务数据库采用此种方式,此方
  205. 法不需要数据库运行在归挡模式下,不但备份简单,而且可以不需要外部存储设备。
  206. 数据库逻辑备份方法
  207. ORACLE数据库的逻辑备份分为三种模式:表备份、用户备份和完全备份。
  208. 表模式
  209. 备份某个用户模式下指定的对象(表)。业务数据库通常采用这种备份方式。
  210. 若备份到本地文件,使用如下命令:
  211. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  212. feedback=100000 volsize=0
  213. file=exp_icdmain_csd_yyyymmdd.dmp
  214. log=exp_icdmain_csd_yyyymmdd.log
  215. tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
  216. 若直接备份到磁带设备,使用如下命令:
  217. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  218. feedback=100000 volsize=0
  219. file=/dev/rmt0
  220. log=exp_icdmain_csd_yyyymmdd.log
  221. tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
  222. 注:在磁盘空间允许的情况下,应先备份到本地服务器,然后再拷贝到磁带。出于速度
  223. 方面的考虑,尽量不要直接备份到磁带设备。
  224. 用户模式
  225. 备份某个用户模式下的所有对象。业务数据库通常采用这种备份方式。
  226. 若备份到本地文件,使用如下命令:
  227. exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
  228. feedback=100000 volsize=0
  229. file=exp_icdmain_yyyymmdd.dmp
  230. log=exp_icdmain_yyyymmdd.log
  231. 若直接备份到磁带设备,使用如下命令:
  232. exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
  233. feedback=100000 volsize=0
  234. file=/dev/rmt0
  235. log=exp_icdmain_yyyymmdd.log
  236. 注:如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。如果数据库数据量较小,
  237. 可采用这种办法备份。
  238. 完全模式
  239. 备份完整的数据库。业务数据库不采用这种备份方式。备份命令为:
  240. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  241. feedback=100000 volsize=0 full=y
  242. file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)
  243. log=exp_fulldb_yyyymmdd.log
  244. 对于数据库备份,建议采用增量备份,即只备份上一次备份以来更改的数据。增量备份
  245. 命令:
  246. exp icdmain/icd rows=y indexes=n compress=n buffer=65536
  247. feedback=100000 volsize=0 full=y inctype=incremental
  248. file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)
  249. log=exp_fulldb_yyyymmdd.log
  250. 注:关于增量备份必须满足下列条件:
  251. 1.
  252. 只对完整数据库备份有效,且第一次需要full=y参数,以后需要inctype=increment
  253. al参数。
  254. 2. 用户必须有EXP_FULL_DATABASE的系统角色。
  255. 3. 话务量较小时方可采用数据库备份。
  256. 4. 如果磁盘有空间,建议备份到磁盘,然后再备份到磁带。
  257. 业务数据库备份方法及周期
  258. 用EXP进行备份前,先在SYS用户下运行CATEXP.SQL文件(如果以前已运行该文件,则不
  259. 要执行这个脚本)。
  260. 没有特殊说明,不允许在客户端执行备份命令。
  261. 备份命令参照表模式下的备份命令。
  262. 从磁盘文件备份到磁带
  263. 如果首先备份到本地磁盘文件,则需要转储到磁带设备上。
  264. 1. 若需查看主机上配置的磁带设备,使用如下命令:
  265. lsdev -Cc tape
  266. 显示的结果如下例所示:
  267. rmt0 Available 30-58-00-2,0 SCSI 4mm Tape Drive
  268. rmt1 Defined  30-58-00-0,0 SCSI 4mm Tape Drive
  269. 标明Available的设备是可用的磁带设备。
  270. 2. 若需查看磁带存储的内容,使用如下命令:
  271. tar -tvf /dev/rmt0
  272. 显示的结果如下例所示:
  273. -rw-r--r-- 300 400 8089600 Jan 11 14:33:57 2001 exp_icdmain_20010111.dmp
  274. 如果显示类似如下内容,则表示该磁带存储的备份数据是从数据库直接备份到磁带上,
  275. 而非从本地磁盘转储到磁带的备份文件,因此操作系统无法识别。
  276. tar: 0511-193 An error occurred while reading from the media.
  277. There is an input or output error.
  278. tar: 0511-169 A directory checksum error on media; -267331077 not equal to
  279. 2
  280. 5626.
  281. 3. 对于新磁带或无需保留现存数据的磁带,使用如下命令:
  282. tar -cvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  283. 注:A. 该命令将无条件覆盖磁带上的现存数据。
  284.   B. 文件名不允许包含路径信息,如:/backup/exp_icdmain_yyyymmdd.dmp。
  285. 4. 对于需要保留现存数据的磁带,使用如下命令:
  286. tar -rvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  287. 注:该命令将文件exp_icdmain_yyyymmdd.dmp追加到磁带的末端,不会覆盖现存的数据
  288. 特别强调:如果备份时是从数据库直接备份到磁带上,则不可再向该磁带上追加复制任
  289. 何其他文件,否则该备份数据失效。
  290. 5. 若需将转储到磁带上的备份文件复制到本地硬盘,使用如下命令:
  291. A. 将磁带上的全部文件复制到本地硬盘的当前目录
  292. tar -xvf /dev/rmt0
  293. B. 将磁带上的指定文件复制到本地硬盘的当前目录
  294. tar -xvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp
  295. 备份时间安排
  296. 由于备份时对系统I/O有较大影响,所以,建议在晚上11点以后进行备份工作。
  297. 业务数据库Oracle版本的恢复
  298. 恢复方案需根据备份方案确定。由于业务数据库采用表备份和用户备份相结合的方案,
  299. 所以业务数据库的恢复需根据实际情况采用表恢复和用户恢复相结合的方案。
  300. 恢复方案
  301. 数据库的逻辑恢复分为表恢复、用户恢复、完全恢复三种模式。
  302. 表模式
  303. 此方式将根据按照表模式备份的数据进行恢复。
  304. A. 恢复备份数据的全部内容
  305. 若从本地文件恢复,使用如下命令:
  306. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  307. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  308. file=exp_icdmain_cs
  309. d_yyyymmdd.dmp
  310. log=imp_icdmain_csd_yyyymmdd.log
  311. 若从磁带设备恢复,使用如下命令:
  312. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  313. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  314. log=imp_icdmain_csd_yyyymmdd.log
  315. B. 恢复备份数据中的指定表
  316. 若从本地文件恢复,使用如下命令:
  317. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  318. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  319. file=exp_icdmain_cs
  320. d_yyyymmdd.dmp
  321. log=imp_icdmain_csd_yyyymmdd.log
  322. tables=commoninformation,serviceinfo
  323. 若从磁带设备恢复,使用如下命令:
  324. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  325. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  326. file=/dev/rmt0
  327. log=imp_icdmain_csd_yyyymmdd.log
  328. tables=commoninformation,serviceinfo
  329. 用户模式
  330. 此方式将根据按照用户模式备份的数据进行恢复。
  331. A. 恢复备份数据的全部内容
  332. 若从本地文件恢复,使用如下命令:
  333. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  334. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  335. file=exp_icdmain_yy
  336. yymmdd.dmp
  337. log=imp_icdmain_yyyymmdd.log
  338. 若从磁带设备恢复,使用如下命令:
  339. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  340. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  341. log=imp_icdmain_yyyymmdd.log
  342. B. 恢复备份数据中的指定表
  343. 若从本地文件恢复,使用如下命令:
  344. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  345. commit=y buffer=65536 feedback=100000 ignore=n volsize=0
  346. file=exp_icdmain_yy
  347. yymmdd.dmp
  348. log=imp_icdmain_yyyymmdd.log
  349. tables=commoninformation,serviceinfo
  350. 若从磁带设备恢复,使用如下命令:
  351. imp icdmain/icd fromuser=icdmain touser=icdmain rows=y indexes=n
  352. commit=y buffer=65536 feedback=100000 ignore=n volsize=0 file=/dev/rmt0
  353. log=imp_icdmain_yyyymmdd.log
  354. tables=commoninformation,serviceinfo
  355. 完全模式
  356. 如果备份方式为完全模式,采用下列恢复方法:
  357. 若从本地文件恢复,使用如下命令:
  358. imp system/manager rows=y indexes=n commit=y buffer=65536
  359. feedback=100000 ignore=y volsize=0 full=y
  360. file=exp_icdmain_yyyymmdd.dmp
  361. log=imp_icdmain_yyyymmdd.log
  362. 若从磁带设备恢复,使用如下命令:
  363. imp system/manager rows=y indexes=n commit=y buffer=65536
  364. feedback=100000 ignore=y volsize=0 full=y
  365. file=/dev/rmt0
  366. log=imp_icdmain_yyyymmdd.log
  367. 参数说明
  368. 1. ignore参数
  369. Oracle在恢复数据的过程中,当恢复某个表时,该表已经存在,
  370. 就要根据ignore参数的设置来决定如何操作。
  371. 若ignore=y,Oracle不执行CREATE TABLE语句,直接将数据
  372. 插入到表中,如果插入的记录违背了约束条件,比如主键约束,
  373. 则出错的记录不会插入,但合法的记录会添加到表中。
  374. 若ignore=n,Oracle不执行CREATE TABLE语句,同时也不会
  375. 将数据插入到表中,而是忽略该表的错误,继续恢复下一个表。
  376. 2. indexes参数
  377. 在恢复数据的过程中,若indexes=n,则表上的索引不会被恢复
  378. ,但是主键对应的唯一索引将无条件恢复,这是为了保证数据
  379. 的完整性。
  380. 字符集转换
  381. 对于单字节字符集(例如US7ASCII),恢复时,数据库自动转
  382. 换为该会话的字符集(NLS_LANG参数);对于多字节字符集
  383. (例如ZHS16CGB231280),恢复时,应尽量使字符集相同
  384. (避免转换),如果要转换,目标数据库的字符集应是输出数
  385. 据库字符集的超集。
  386. 恢复方法
  387. 业务数据库采用表恢复方案。在用IMP进行恢复前,先在SYS
  388. 用户下运行CATEXP.SQL文件(如果以前已运行该文件,则
  389. 不要执行这个脚本),然后执行下列命令:
  390. IMP ICDMAIN/ICD FILE=文件名 LOG=LOG文件名 ROWS=Y
  391. COMMIT=Y BUFFER=Y IGNORE=Y TABLES=表名
  392. 注:要恢复的表名参照备份的表名
  393.   。恢复是在原表基础上累加数据
  394.   。没有特殊说明,不允许在客户端执行恢复命令

阅读(650) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~