手工管理在复制数据库

简介:  手工创建复制数据库时,必须备份复制数据库所需的所有数据文件。其中system 和undo表空间的数据文件是必须的。必须使用CREATER CONTROLFILE 命令创建备份数据库的控制文件。

 手工创建复制数据库时,必须备份复制数据库所需的所有数据文件。其中system 和undo表空间的数据文件是必须的。必须使用CREATER CONTROLFILE 命令创建备份数据库的控制文件。可以将主数据库的控制文件备份到控制文件里。

下面 创建复制数据库DUPDB1 ,主数据库名为ORACL

1)复制主数据库的数据文件。

ORACL> select name from v$datafile;
NAME                                                                           
--------------------------------------------------------------------------------
F:\APP\YANG\ORADATA\ORACL\SYSTEM01.DBF                                         
F:\APP\YANG\ORADATA\ORACL\SYSAUX01.DBF                                         
F:\APP\YANG\ORADATA\ORACL\UNDOTBS01.DBF                                        
F:\APP\YANG\ORADATA\ORACL\USERS01.DBF                                          
F:\APP\YANG\ORADATA\ORACL\EXAMPLE01.DBF                                        
F:\APP\YANG\ORADATA\ORACL\TEST.DBF                                             
F:\APP\YANG\ORADATA\ORACL\TEST1.DBF                                            
已选择7行。

2)备份主数据库的数据文件和控制文件                                    
ORACL> alter database begin backup;
数据库已更改。

ORACL> host copy f:\app\yang\oradata\oracl\*.dbf f:\hotbackup\*.dbf


ORACL> alter database end backup;
数据库已更改。

ORACL> alter system archive log current;---归档当前日志
系统已更改。
ORACL> alter database backup controlfile to trace resetlogs;--备份到跟踪文件里
数据库已更改。
ORACL> @f:\sql\gettrace.sql---获取跟踪文件 脚本在文章最后给出
TRACE_FILE__NAME                                                               
--------------------------------------------------------------------------------
f:\app\yang\diag\rdbms\oracl\oracl\trace/oracl_ora_3560.trc
                    
 

3)建立存放复制数据库的各种目录

img_7fd58ce64ff6f2864f84ffb1c0137443.jpg

4)建立例程服务 在windows系统下,使用如下命令,

oradim -new -sid  dupdb1 -intpwd oracle

5)

1。 建立参数文件。先建立pfile文件,然后根据实际情况进行修改。
ORACL> create pfile='F:\app\yang\product\11.1.0\db_1\database\initdupdb1.ora' from spfile;
文件已创建。

2。修改initdupdb1.ora文件。修改db_name,instance_name,service_names,control_files ,*_dest 等初始化参数。部分参数如下(基本上这些就够了)

*.db_name='dupdb1'
*.instance_name='dupdb1'
*.service_names='dupdb1'
*.user_dump_dest='d:\dupdb1\udump'
*.background_dump_dest='d:\dupdb1\bdump'
*.db_recovery_file_dest='d:\dupdb1\flash_recovery_area'
*.db_recovery_file_dest_size=2147483648
*.log_archive_dest_1='location=d:\dupdb1\archive'

3。根据修改的INITDUPDB1.ORA 创建spfile文件

ORACL>create spfile='F:\app\yang\product\11.1.0\db_1\database\spfileDUPDB1.ora'
  2  from pfile='F:\app\yang\product\11.1.0\db_1\database\initdupdb1.ora';
create spfile='F:\app\yang\product\11.1.0\db_1\database\spfileDUPDB1.ora'
*
第 1 行出现错误:
ORA-01078: 处理系统参数失败
ORA-32003: 处理参数 'service_name' 时出错----第一次做的时候 name少了个s
LRM-00101: unknown parameter name 'service_name'

ORACL>create spfile='F:\app\yang\product\11.1.0\db_1\database\spfileDUPDB1.ora'
  2  from pfile='F:\app\yang\product\11.1.0\db_1\database\initdupdb1.ora';
文件已创建。

6)复制主数据库的数据文件到复制数据库的目录。

ORACL>host copy f:\hotbackup\*.dbf d:\dupdb1



ORACL>create spfile='F:\app\yang\product\11.1.0\db_1\database\spfileDUPDB1.ora'
  2  from pfile='F:\app\yang\product\11.1.0\db_1\database\initdupdb1.ora';
文件已创建。

以下是在复制数据库上的操作。

7)启动复制数据库的例程。

C:\>SET ORACLE_SID=DUPDB1

C:\>sqlplus  sys/oracle as sysdba

DUPDB1>startup nomount
ORA-02778: Name given for the log directory is invalid

---第一次时的错误,由于初始化参数配置的问题,你在做的时候,一定要仔细检查目录和路径是否正确。
修改后,重新启动。可以了。

8)要根据从获取跟踪文件中修改相应的路径,来重建控制文件。

DUPDB1>startup nomount
ORACLE instance started.
Total System Global Area  535662592 bytes                                      
Fixed Size                  1334380 bytes                                      
Variable Size             150995860 bytes                                      
Database Buffers          377487360 bytes                                      
Redo Buffers                5844992 bytes
                                      
DUPDB1>@f:\sql\crtdupdbctlret.sql
Control file created.

DUPDB1>startup mount--启动到mount状态,
ORACLE instance started.
Total System Global Area  535662592 bytes                                      
Fixed Size                  1334380 bytes                                      
Variable Size             150995860 bytes                                      
Database Buffers          377487360 bytes                                      
Redo Buffers                5844992 bytes                                      
Database mounted.
DUPDB1>select instance_name ,status from v$instance;
INSTANCE_NAME    STATUS                                                        
---------------- ------------
                                                  
dupdb1           MOUNTED       

9)由于数据库是在open状态下做的备份,是非一致性的备份,所以在重建控制文件后,要做复制数据库上进行恢复,用主数据库的归档日志,并在最后的日志使用完后,取消。                                                
DUPDB1>set logsource 'F:\app\yang\archive1'--用主数据库的归档日志
DUPDB1>recover database using backup controlfile until cancel
ORA-00279: change 3430744 generated at 06/04/2010 17:57:21 needed for thread 1
ORA-00289: suggestion : F:\APP\YANG\ARCHIVE1\28_1_720218966.LOG
ORA-00280: change 3430744 for thread 1 is in sequence #28
Specify log: {=suggested | filename | AUTO | CANCEL}

auto
ORA-00279: change 3430948 generated at 06/04/2010 18:00:46 needed for thread 1
ORA-00289: suggestion : F:\APP\YANG\ARCHIVE1\29_1_720218966.LOG
ORA-00280: change 3430948 for thread 1 is in sequence #29
ORA-00278: log file 'F:\APP\YANG\ARCHIVE1\28_1_720218966.LOG' no longer needed
for this recovery
ORA-00308: cannot open archived log 'F:\APP\YANG\ARCHIVE1\29_1_720218966.LOG'

ORA-27041: unable to open file
OSD-04002: 无法打开文件
O/S-Error: (OS 2) 系统找不到指定的文件。

--出现这个情况是由于以resetlogs方式打开创建控制文件的(脚本在最后给出),以前的归档不能使用(参考我的以前的日志,重建控制文件http://space.itpub.net/22664653/viewspace-663963)要应用当前的重做日志文件。这里我把重做日志拷贝到复制数据库的目录下了。也可以不拷贝。输入路径就好。
DUPDB1>recover database using backup controlfile until cancel
ORA-00279: change 3430948 generated at 06/04/2010 18:00:46 needed for thread 1
ORA-00289: suggestion : F:\APP\YANG\ARCHIVE1\29_1_720218966.LOG
ORA-00280: change 3430948 for thread 1 is in sequence #29
Specify log: {=suggested | filename | AUTO | CANCEL}

d:\dupdb1\redo01.log
ORA-00310: archived log contains sequence 28; sequence 29 required
ORA-00334: archived log: 'D:\DUPDB1\REDO01.LOG'
DUPDB1>recover database using backup controlfile until cancel
ORA-00279: change 3430948 generated at 06/04/2010 18:00:46 needed for thread 1
ORA-00289: suggestion : F:\APP\YANG\ARCHIVE1\29_1_720218966.LOG
ORA-00280: change 3430948 for thread 1 is in sequence #29
Specify log: {=suggested | filename | AUTO | CANCEL}

d:\dupdb1\redo02.log
Log applied.
Media recovery complete.-----成功的标志

10)在恢复数据库之后用resetlogs方式打开数据库,系统会自动建立所有重做日志
DUPDB1>alter database open resetlogs;

Database altered.
DUPDB1>select instance_name ,status from v$instance;
INSTANCE_NAME    STATUS                                                        
---------------- ------------
                                                  
dupdb1           OPEN     

至此,手工在同一台主机上创建复制数据库 成功。。

附:

1 crtdupdbctlret.sql 的脚本

STARTUP NOMOUNT
CREATE CONTROLFILE SET DATABASE "DUPDB1" RESETLOGS  ARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 'D:\DUPDB1\REDO01.LOG'  SIZE 50M,
  GROUP 2 'D:\DUPDB1\REDO02.LOG'  SIZE 50M,
  GROUP 3 'D:\DUPDB1\REDO03.LOG'  SIZE 50M
-- STANDBY LOGFILE
DATAFILE
  'D:\DUPDB1\SYSTEM01.DBF',
  'D:\DUPDB1\SYSAUX01.DBF',
  'D:\DUPDB1\UNDOTBS01.DBF',
  'D:\DUPDB1\USERS01.DBF',
  'D:\DUPDB1\EXAMPLE01.DBF',
  'D:\DUPDB1\TEST.DBF',
  'D:\DUPDB1\TEST1.DBF'
CHARACTER SET ZHS16GBK;
 

2: gettrace.sql的脚本

select
  d.value||'/'||lower(rtrim(i.instance,chr(0)))||'_ora_'||p.spid||'.trc' trace_file__name
from
    (select p.spid
     from sys.v$mystat m,sys.V$session s,sys.v$process p
     where m.statistic# =1 and s.sid =m.sid and p.addr = s.paddr) p,
    (select t.instance from sys.v$thread t ,sys.v$parameter v
      where  v.name = 'thread' and (v.value =0 or t.thread#=to_number(v.value))) i,
    (select value from sys.v$parameter where name='user_dump_dest') d
 /

img_e25d4fb2f8de1caf41a735ec53088516.png1.jpg

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
9天前
|
存储 SQL 监控
Visual Basic与数据库交互:实现数据访问和管理
【4月更文挑战第27天】本文探讨了使用Visual Basic进行数据库编程的基础,包括数据库基础、连接、数据访问技术如ADO.NET,数据绑定,事务处理,存储过程与视图。还强调了性能优化、安全性、测试与调试,以及持续维护的重要性。通过掌握这些概念和技巧,开发者能构建高效、可靠的数据驱动应用。
|
25天前
|
Oracle 安全 关系型数据库
【Oracle】玩转Oracle数据库(六):模式对象管理与安全管理
【Oracle】玩转Oracle数据库(六):模式对象管理与安全管理
26 10
|
25天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(三):数据库的创建和管理
【Oracle】玩转Oracle数据库(三):数据库的创建和管理
64 5
|
4月前
|
SQL 关系型数据库 MySQL
MySQL| 数据库的管理和操作【操作数据库和操作表】【附练习】
MySQL | 数据库的基本操作和表的基本操作【附练习】
|
4月前
|
弹性计算 关系型数据库 MySQL
快速上手阿里云RDS MySQL实例创建,轻松管理数据库
快速上手阿里云RDS MySQL实例创建,轻松管理数据库 在数字化时代,数据已成为企业的核心资产。如何高效、安全地存储和管理这些数据,成为企业在云计算时代亟待解决的问题。阿里云的RDS(关系型数据库服务)应运而生,为用户提供稳定、可靠的云上数据库解决方案。本文将详细介绍如何通过阿里云RDS管理控制台快速创建RDS MySQL实例,让您轻松上手,快速部署数据库。
179 2
|
5月前
|
存储 Oracle 关系型数据库
postgresql数据库|wal日志的开启以及如何管理
postgresql数据库|wal日志的开启以及如何管理
329 0
|
2月前
|
SQL 安全 数据管理
在阿里云数据管理DMS(Data Management Service)中,您可以按照以下步骤来创建和管理数据库
【2月更文挑战第33天】在阿里云数据管理DMS(Data Management Service)中,您可以按照以下步骤来创建和管理数据库
47 7
|
6天前
|
监控 关系型数据库 MySQL
初体验:数据库监控、管理和可观测性工具(PMM)
Percona Monitoring and Management (PMM) 是一个开源工具,用于监控MySQL、PostgreSQL和MongoDB的性能。它提供实时监控、数据可视化、故障排除和管理功能,支持本地和云端数据库。要安装PMM,首先需安装Docker,然后通过提供的脚本部署PMM服务器和客户端。在MySQL服务器上创建PMM用户后,使用`pmm-admin`命令添加数据库。访问PMM的HTTPS网址(默认用户名和密码为admin)进行配置。本文还包含了安装Docker和PMM的命令行步骤。
初体验:数据库监控、管理和可观测性工具(PMM)
|
4月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(一)
MySQL | 数据库的管理和操作【表的增删改查】
|
4月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(二)
MySQL | 数据库的管理和操作【表的增删改查】(二)