热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

问题2:重新命名或者移动数据文件、日志文件到新的位置

本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。

目的:在某些情况下,数据文件或者日志文件必须被重新命名或迁移到新的位置上,然而想要让这些文件仍然有效,那么就需要为这些文件定义一个物理的名字或者物理位置,例如,在以下情况发生时,就需要重新命名数据文件或者日志文件:

1.出于性能或者维护原因,需要将一个数据库文件移动到一个不同的磁盘上

2.从备份中恢复一个数据文件,但是这个以前存放数据文件的磁盘已经崩溃,那么就需要将这个数据文件重新分配到一个新的磁盘上

3.在操作系统级别,已经移动或者重命名一个数据文件,但是在数据库层即数据库内却没有进行重命名,在数据库启动的过程中得到 ORA-01157 和 ORA-01110 报错信息。如果数据库处于打开状态下,在操作系统级别重命名了数据文件或者移动了数据文件到其他的位置,当通过normal 或者 immediate 方式关闭数据库的时候,会得到 ORA-01116 和 ORA-01110 报错;

以下将通过三个方面来对本主题进行相关的讨论:

I    数据库打开的状态下,重命名或者移动数据文件

II  数据库关闭的状态下,重命名或者移动数据文件

III  重命名或者移动日志文件

【注意】

如果要重命名或者移动的数据文件是 SYSTEM 表空间中的文件,那么,必须用第 II 种方法来达到最终的目的即“数据库关闭的状态下,重命名或者移动数据文件”,因为在数据库打开的状态下,不能够让 SYSTEM 表空间出于 OFFLINE 即离线的状态;

下面分别来对不同的情景进行说明:

I    数据库打开的状态下,重命名或者移动数据文件

在数据库出于打开的状态下,可以对数据文件进行重新命名或者移动,但是,表空间必须被置于READ-ONLY状态。在 READ-ONLY 状态下,用户可以对这个表空间进行SELECT操作,但不能对表空间进行INSERTS UPDATES 和 DELETES 操作。表空间READ-ONLY状态需要的总时间,取决于数据文件的大小和将一个数据文件从一个位置拷贝到一个新位置的时间消耗

将表空间置于READ-ONLY状态,冻结文件头,从而阻止数据文件头被更新。只有在数据文件处于 READ-ONLY状态下,才有可能在数据库出于打开的状态下,对文件进行拷贝。

通过以下的步骤来达到重命名或者移动数据文件的目的,本例中,以 USERS 表空间为数据文件所在的表空间:

1. 查看 USERS表空间中有多少数据文件

SQL>select file_name, status from dba_data_files where tablespace_name = 'USERS';

FILE_NAME                     STATUS

------------------------------------------------------

/u01/oradata/radius/users01.dbf       AVAILABLE

2. 确保,在返回的查询结果中,所有数据文件的状态即STATUS的值都是 AVAILABLE

3. USERS表空间置为 READ ONLY状态

altertablespace users read only;

4. 确保 USERS表空间在数据字典中已经被置于 READ ONLY状态

SQL>select tablespace_name, status from dba_tablespaces where tablespace_name ='USERS';

TABLESPACE_NAME        STATUS

---------------------------------------

USERS                 READ ONLY

5. 使用操作系统命令,将数据文件拷贝到一个新的位置。当数据文件被拷贝到一个新的位置之后,需要做的也是最重要的就是要比较两个数据文件的大小是否一致,因为可能在复制的过程中出现数据丢失的情况

【注意】

同样,可以利用上面的方法,进行数据文件的重命名,而不是改变数据文件的位置。

然而,在 Windows 上可能会出现类似于以下的报错信息:

"Cannotrename USERS01: It is being used by another person or program.

Closeany programs that might be using the file and try again."

以上的报错不是真正的限制,因为,这个过程的目的是移动数据文件到新的位置上,以便进行存储的管理,在上面只是重命名文件名没有生效,这个操作可以在停机的时间进行操作。

6. 当数据文件已经拷贝到新的位置之后,将USERS表空间置于 OFFLINE状态

altertablespace users offline;

7. 当表空间被置于 OFFLINE状态时,需要做的是在数据库层重新命名数据文件到新的位置上,这个操作会更新控制文件中的数据文件的位置信息

alter database rename file '/u01/oradata/radius/users01.dbf' to '/u01/newlocation/users01.dbf';

【注意】

需要对这个表空间中的所有的文件进行同样的操作;同样,可以使用 alter tablespace... rename datafile 语法来达到同样的目的

8. 当确认所有的 rename操作完成之后,将 USERS表空间上线即 ONLINE

alter tablespace users online;

9. 当将表空间重新置为 ONLINE状态,需要将表空间重新置为 READ WRITE即读写状态

alter tablespace users read write;

10. 检查表空间的状态是否为READ WRITE状态

SQL>select tablespace_name, status from dba_tablespaces where tablespace_name ='USERS';

TABLESPACE_NAME        STATUS

---------------------------------------

USERS                 ONLINE

11. 查看修改后的数据文件的位置

SQL>select file_name, status from dba_data_files where tablespace_name = 'USERS';

FILE_NAME                     STATUS

------------------------------------------------------

/u01/newlocation/users01.dbf             AVAILABLE

12. 同样,可以用下面的方式来验证控制文件是否已经被更新

1)将控制文件 TRACE 出来即通过这个操作产生一个控制文件的拷贝

alter database backup controlfile to trace;

2)trace 出来的文件 在 user_dump_dest 目录下,进行查看

/************************************************************************************/

[oracle@10gr2udump]$ cat radius_ora_3672.trc

/u01/app/oracle/admin/radius/udump/radius_ora_3672.trc

OracleDatabase 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production

Withthe Partitioning, OLAP, Data Mining and Real Application Testing options

ORACLE_HOME= /u01/app/oracle/product/10.2.0/db_1

Systemname:    Linux

Nodename:  10gr2

Release:    2.6.18-371.el5

Version:    #1 SMP Tue Oct 1 08:35:08 EDT 2013

Machine:    x86_64

Instancename: radius

Redothread mounted by this instance: 1

Oracleprocess number: 21

Unixprocess pid: 3672, image: oracle@10gr2 (TNS V1-V3)

 

***ACTION NAME:() 2014-09-05 01:52:51.673

***MODULE NAME:(sqlplus@10gr2 (TNS V1-V3)) 2014-09-05 01:52:51.673

***SERVICE NAME:(SYS$USERS) 2014-09-05 01:52:51.673

***SESSION ID:(148.285) 2014-09-05 01:52:51.673

***2014-09-05 01:52:51.673

--The following are current System-scope REDO Log Archival related

--parameters and can be included in the database initialization file.

--

--LOG_ARCHIVE_DEST=''

--LOG_ARCHIVE_DUPLEX_DEST=''

--

--LOG_ARCHIVE_FORMAT=%t_%s_%r.arc

--

--DB_UNIQUE_NAME="radius"

--

--LOG_ARCHIVE_COnFIG='SEND, RECEIVE, NODG_CONFIG'

--LOG_ARCHIVE_MAX_PROCESSES=2

--STANDBY_FILE_MANAGEMENT=MANUAL

--STANDBY_ARCHIVE_DEST=?/dbs/arch

--FAL_CLIENT=''

--FAL_SERVER=''

--

--LOG_ARCHIVE_DEST_1='LOCATION=/u01/backup/'

--LOG_ARCHIVE_DEST_1='OPTIONAL REOPEN=300 NODELAY'

--LOG_ARCHIVE_DEST_1='ARCH NOAFFIRM NOEXPEDITE NOVERIFY SYNC'

--LOG_ARCHIVE_DEST_1='REGISTER NOALTERNATE NODEPENDENCY'

--LOG_ARCHIVE_DEST_1='NOMAX_FAILURE NOQUOTA_SIZE NOQUOTA_USED NODB_UNIQUE_NAME'

--LOG_ARCHIVE_DEST_1='VALID_FOR=(PRIMARY_ROLE,ONLINE_LOGFILES)'

--LOG_ARCHIVE_DEST_STATE_1=ENABLE

--

--Below are two sets of SQL statements, each of which creates a new

--control file and uses it to open the database. The first set opens

--the database with the NORESETLOGS option and should be used only if

--the current versions of all online logs are available. The second

--set opens the database with the RESETLOGS option and should be used

--if online logs are unavailable.

--The appropriate set of statements can be copied from the trace into

--a script file, edited as necessary, and executed when there is a

--need to re-create the control file.

--

--     Set #1. NORESETLOGS case

--

--The following commands will create a new control file and use it

--to open the database.

--Data used by Recovery Manager will be lost.

--Additional logs may be required for media recovery of offline

--Use this only if the current versions of all online logs are

--available.

--After mounting the created controlfile, the following SQL

--statement will place the database in the appropriate

--protection mode:

--  ALTER DATABASE SET STANDBY DATABASE TOMAXIMIZE PERFORMANCE

STARTUPNOMOUNT

CREATECONTROLFILE REUSE DATABASE "RADIUS" NORESETLOGS  ARCHIVELOG

    MAXLOGFILES 16

    MAXLOGMEMBERS 3

    MAXDATAFILES 100

    MAXINSTANCES 8

    MAXLOGHISTORY 292

LOGFILE

  GROUP 1 '/u01/oradata/radius/redo01.log'  SIZE 50M,

  GROUP 2 '/u01/oradata/radius/redo02.log'  SIZE 50M,

  GROUP 3 '/u01/oradata/radius/redo03.log'  SIZE 50M

--STANDBY LOGFILE

DATAFILE

  '/u01/oradata/radius/system01.dbf',

  '/u01/oradata/radius/undotbs01.dbf',

  '/u01/oradata/radius/sysaux01.dbf',

  '/u01/newlocation/users01.dbf',

  '/u01/oradata/radius/example01.dbf',

CHARACTERSET US7ASCII

;

--Commands to re-create incarnation table

--Below log names MUST be changed to existing filenames on

--disk. Any one log file from each branch can be used to

--re-create incarnation records.

--ALTER DATABASE REGISTER LOGFILE '/u01/backup/1_1_649125521.arc';

--ALTER DATABASE REGISTER LOGFILE '/u01/backup/1_1_857311814.arc';

--Recovery is required if any of the datafiles are restored backups,

--or if the last shutdown was not normal or immediate.

RECOVERDATABASE

--All logs need archiving and a log switch is needed.

ALTERSYSTEM ARCHIVE LOG ALL;

--Database can now be opened normally.

ALTERDATABASE OPEN;

--Commands to add tempfiles to temporary tablespaces.

--Online tempfiles have complete space information.

--Other tempfiles may require adjustment.

ALTERTABLESPACE TEMP ADD TEMPFILE '/u01/oradata/radius/temp01.dbf'

     SIZE 20971520  REUSE AUTOEXTEND ON NEXT 655360  MAXSIZE 32767M;

--End of tempfile additions.

--

--     Set #2. RESETLOGS case

--

--The following commands will create a new control file and use it

--to open the database.

--Data used by Recovery Manager will be lost.

--The contents of online logs will be lost and all backups will

--be invalidated. Use this only if online logs are damaged.

--After mounting the created controlfile, the following SQL

--statement will place the database in the appropriate

--protection mode:

--  ALTER DATABASE SET STANDBY DATABASE TOMAXIMIZE PERFORMANCE

STARTUPNOMOUNT

CREATECONTROLFILE REUSE DATABASE "RADIUS" RESETLOGS  ARCHIVELOG

    MAXLOGFILES 16

    MAXLOGMEMBERS 3

    MAXDATAFILES 100

    MAXINSTANCES 8

    MAXLOGHISTORY 292

LOGFILE

  GROUP 1 '/u01/oradata/radius/redo01.log'  SIZE 50M,

  GROUP 2 '/u01/oradata/radius/redo02.log'  SIZE 50M,

  GROUP 3 '/u01/oradata/radius/redo03.log'  SIZE 50M

--STANDBY LOGFILE

DATAFILE

  '/u01/oradata/radius/system01.dbf',

  '/u01/oradata/radius/undotbs01.dbf',

  '/u01/oradata/radius/sysaux01.dbf',

  '/u01/newlocation/users01.dbf',

  '/u01/oradata/radius/example01.dbf',

CHARACTERSET US7ASCII

;

--Commands to re-create incarnation table

--Below log names MUST be changed to existing filenames on

--disk. Any one log file from each branch can be used to

--re-create incarnation records.

--ALTER DATABASE REGISTER LOGFILE '/u01/backup/1_1_649125521.arc';

--ALTER DATABASE REGISTER LOGFILE '/u01/backup/1_1_857311814.arc';

--Recovery is required if any of the datafiles are restored backups,

--or if the last shutdown was not normal or immediate.

RECOVERDATABASE USING BACKUP CONTROLFILE

--Database can now be opened zeroing the online logs.

ALTERDATABASE OPEN RESETLOGS;

--Commands to add tempfiles to temporary tablespaces.

--Online tempfiles have complete space information.

--Other tempfiles may require adjustment.

ALTERTABLESPACE TEMP ADD TEMPFILE '/u01/oradata/radius/temp01.dbf'

     SIZE 20971520  REUSE AUTOEXTEND ON NEXT 655360  MAXSIZE 32767M;

--End of tempfile additions.

--

/************************************************************************************/

同样,可以通过 v$datafile 视图来查看,因为 v$datafile 视图中的信息来自于控制文件

13. 在操作系统级别,在原来的旧的目录中,将旧的数据文件删除

 

II   数据库关闭的状态下,重命名或者移动数据文件

1. 查看 USERS表空间中,数据文件的位置

SQL>select file_name,tablespace_name,file_id from dba_data_files wheretablespace_name = 'USERS';

FILE_NAME                     TABLESPACE_NAME         FILE_ID

--------------------------------------------------------------------------- -------

/u01/newlocation/users01.dbf             USERS                     4

2. 关闭数据库

shutdown immediate

3.在操作系统级别将数据文件重命名或者移动到新的位置上,或者移动新的位置上并且重命名

4. 启动数据库到 mount状态

startup mount;

【说明】:这个操作会读取控制文件,但是不会将数据文件 mount

5. 在数据库内重新命名数据文件

alter database rename file '/u01/newlocation/users01.dbf' to '/u01/oradata/radius/users01.dbf';

6. 打开数据库

alter database open;

7. 查询 v$dbfile视图,来确认修改已经成功

SQL>select * from v$dbfile order by 1;

     FILE# NAME

---------------------------------------------

     1/u01/oradata/radius/system01.dbf

     2/u01/oradata/radius/undotbs01.dbf

     3/u01/oradata/radius/sysaux01.dbf

     4/u01/oradata/radius/users01.dbf

     5 /u01/oradata/radius/example01.dbf

8. 在操作系统级别,将旧的数据文件从旧的目录位置中删除

 

III  重命名或者移动日志文件

1. 关闭数据库

2. 在操作系统级别,将日志文件重命名或者移动到新的位置上,或者移动新的位置上并且重命名

3. 将数据库启动到 mount状态

startup mount

4. 在数据库级别,重命名日志文件

alter database rename file '/full_path_of_old_location/and_redo_log_name' to'/full_path_of_new_location/and_redo_log_name or new_name';

5. 打开数据库

alter database open;

6. 在操作系统级别,将旧的数据文件从旧的目录位置中删除

 --END--


推荐阅读
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • PeopleSoft安装镜像版本及导入语言包的方法
    本文介绍了PeopleSoft安装镜像的两个版本,分别是VirtualBox虚拟机版本和NativeOS版本,并详细说明了导入语言包的方法。对于Windows版本,可以通过psdmt.exe登录进入,并使用datamover脚本导入语言包。对于Linux版本,同样可以使用命令行方式执行datamover脚本导入语言包。导入语言包后,可以实现多种语言的登录。参考文献提供了相关链接以供深入了解。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • Windows7 64位系统安装PLSQL Developer的步骤和注意事项
    本文介绍了在Windows7 64位系统上安装PLSQL Developer的步骤和注意事项。首先下载并安装PLSQL Developer,注意不要安装在默认目录下。然后下载Windows 32位的oracle instant client,并解压到指定路径。最后,按照自己的喜好对解压后的文件进行命名和压缩。 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 本文介绍了在使用Laravel和sqlsrv连接到SQL Server 2016时,如何在插入查询中使用输出子句,并返回所需的值。同时讨论了使用CreatedOn字段返回最近创建的行的解决方法以及使用Eloquent模型创建后,值正确插入数据库但没有返回uniqueidentifier字段的问题。最后给出了一个示例代码。 ... [详细]
  • Python操作MySQL(pymysql模块)详解及示例代码
    本文介绍了使用Python操作MySQL数据库的方法,详细讲解了pymysql模块的安装和连接MySQL数据库的步骤,并提供了示例代码。内容涵盖了创建表、插入数据、查询数据等操作,帮助读者快速掌握Python操作MySQL的技巧。 ... [详细]
  • Centos7搭建ELK(Elasticsearch、Logstash、Kibana)教程及注意事项
    本文介绍了在Centos7上搭建ELK(Elasticsearch、Logstash、Kibana)的详细步骤,包括下载安装包、安装Elasticsearch、创建用户、修改配置文件等。同时提供了使用华为镜像站下载安装包的方法,并强调了保证版本一致的重要性。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • 超级计算机 26010,全球最强超级计算机搭载的SW26010处理器解析
    全球最强超级计算机神威·太湖之光搭载的申威26010处理器每片处理器包含4个核心,片上的4个核心通过片上网络互联,并通过PCI-E3.0对外连接,每个核心拥有独立的128位DDR3 ... [详细]
author-avatar
手机用户2502854967
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有