Oralce OMF 功能详解

2023-10-10 22:18
文章标签 详解 功能 oralce omf

本文主要是介绍Oralce OMF 功能详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    OMF,全称是Oracle_Managed Files,Oracle文件管理,使用OMF可以简化管理员的管理工作,不用指定文件的名字、大小、路径,其名字,大小,

路径由oracle 自动分配。在删除不再使用的日志、数据、控制文件时,OMF也可以自动删除其对应的OS文件。

 

OMF支持下列文件的自动管理:

    表空间

    日志文件(联机)

    控制文件

前提条件:需要为这些类型文件设定相关参数。

 

.数据文件的OMF管理

  数据文件管理参数:db_create_file_dest

  db_create_file_destOracle创建数据文件、临时文件时,在未明确指定路径的情况下的缺省路径,当db_create_online_log_dest_n未指定时,

                       也作为联机日志文件和控制文件的缺省路径。

 

  假定需要创建表空间s及数据文件

 

    SQL> CREATE TABLESPACE s;  /*收到了错误信息*/

       create tablespace s

                       *

       ERROR at line 1:

       ORA-02199: missing DATAFILE/TEMPFILE clause

 

    SQL> show parameter db_create_file   /*查看db_create_file_dest参数*/

 

       NAME                                 TYPE        VALUE

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

       db_create_file_dest                  string

 

    --设定db_create_file_dest参数

    SQL> ALTER SYSTEM SET db_create_file_dest = '/u01/app/oracle/oradata/orcl';

 

       System altered.

 

    --设定参数后,创建成功

    SQL> CREATE TABLESPACE s; 

 

       Tablespace created.

 

    SQL> SELECT NAME FROM v$datafile;  /*可以看到ORCL/datafile/o1_mf_s_5vrl1t7h_.dbfOralce自动创建的数据文件*/

 

       NAME

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

       /u01/app/oracle/oradata/orcl/system01.dbf

       /u01/app/oracle/oradata/orcl/undotbs01.dbf

       /u01/app/oracle/oradata/orcl/sysaux01.dbf

       /u01/app/oracle/oradata/orcl/users01.dbf

       /u01/app/oracle/oradata/orcl/example01.dbf

       /u01/app/oracle/oradata/orcl/Test.dbf

       /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf

 

    /*查看物理文件,缺省为MB*/

    SQL> ho ls -lh /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf 

       -rw------- 1 oracle oinstall 101M Apr  7 16:54 /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf

 

    SQL> CREATE TABLESPACE t DATAFILE SIZE 10m;  /*也可指定数据文件的大小为MB*/

 

       Tablespace created.

 

    SQL> SELECT NAME FROM v$datafile;

 

       NAME

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

       /u01/app/oracle/oradata/orcl/system01.dbf

       /u01/app/oracle/oradata/orcl/undotbs01.dbf

       /u01/app/oracle/oradata/orcl/sysaux01.dbf

       /u01/app/oracle/oradata/orcl/users01.dbf

       /u01/app/oracle/oradata/orcl/example01.dbf

       /u01/app/oracle/oradata/orcl/Test.dbf

       /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf

       /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_t_5vrlgqtl_.dbf

 

    SQL> ho ls -lh /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_t_5vrlgqtl_.dbf

       -rw------- 1 oracle oinstall 11M Apr  7 17:01 /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_t_5vrlgqtl_.dbf

 

    --删除表空间时,对于使用了OMF生成的数据文件将随着表空间的删除一起被删除

    SQL> DROP TABLESPACE t;

 

    Tablespace dropped.

 

    --查看物理文件,已经不存在

    SQL> ho ls -lh /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_t_5vrlgqtl_.dbf 

       ls: /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_t_5vrlgqtl_.dbf: No such file or directory

 

    --对于未采用OMF来创建的表空间,在删除表空间之后,其数据文件并没有删除,v$datafile视图中被删除

    --下面是未使用OMF创建的x表空间及数据文件

    SQL> CREATE TABLESPACE x DATAFILE '/u01/app/oracle/oradata/orcl/x.dbf' SIZE 10m;

 

       Tablespace created.

 

    SQL> SELECT NAME FROM v$datafile;     

 

       NAME

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

       /u01/app/oracle/oradata/orcl/system01.dbf

       /u01/app/oracle/oradata/orcl/undotbs01.dbf

       /u01/app/oracle/oradata/orcl/sysaux01.dbf

       /u01/app/oracle/oradata/orcl/users01.dbf

       /u01/app/oracle/oradata/orcl/example01.dbf

       /u01/app/oracle/oradata/orcl/Test.dbf

       /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf

       /u01/app/oracle/oradata/orcl/x.dbf

 

    SQL> DROP TABLESPACE x;

 

       Tablespace dropped.

 

    SQL> SELECT NAME FROM v$datafile; /*视图中已不存在x.dbf的数据文件*/

 

       NAME

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

       /u01/app/oracle/oradata/orcl/system01.dbf

       /u01/app/oracle/oradata/orcl/undotbs01.dbf

       /u01/app/oracle/oradata/orcl/sysaux01.dbf

       /u01/app/oracle/oradata/orcl/users01.dbf

       /u01/app/oracle/oradata/orcl/example01.dbf

       /u01/app/oracle/oradata/orcl/Test.dbf

       /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s_5vrl1t7h_.dbf

 

    SQL> ho ls /u01/app/oracle/oradata/orcl/x.dbf   /*操作系统中依然存在*/

       /u01/app/oracle/oradata/orcl/x.dbf

 

    --注意:使用OMF的时候会将物理文件删除,应特别注意使用

    --使用下面的方法重建x表空间,然后使用including contents and datafiles 彻底删除表空间及物理文件

    SQL> CREATE TABLESPACE X DATAFILE '/u01/app/oracle/oradata/orcl/x.dbf' REUSE;  

 

       Tablespace created.

 

    SQL> DROP TABLESPACE x INCLUDING CONTENTS AND DATAFILES;

 

       Tablespace dropped.

 

    SQL> ho ls /u01/app/oracle/oradata/orcl/x.dbf

       ls: /u01/app/oracle/oradata/orcl/x.dbf: No such file or directory

 

总结:使用OMF管理文件的方法

  1.使用ALTER SYSTEM SET db_create_file_dest = '<path>'设置路径

  2.查看刚刚的设置SHOW PARAMETER db_create_file_dest;

  3.创建表空间及数据文件CREATE TABLESPACE tablespace_name

  4.单独创建表空间CREATE TABLESPACE <> DATAFILE '<path>' SIZE <>;

  5.也可以创建undotemporary tablespace CREATE UNDO TABLESPACE tablespace_name ;CREATE TEMPORARY TABLESPACE tablespace_name;

  6.删除表空间DROP TABLESPACE tablespace_name ;OMF情况下则删除物理文件,等效于未使用OMF创建,使用INCLUDING CONTENTS AND DATAFILES 删除方式

 

 

.日志文件的OMF管理

  日志文件管理参数:db_create_online_log_dest_n

  db_create_online_log_dest_n:Oracle创建联机日志文件和控制文件时,在未明确指定路径的情况下的缺省路径

 

--查看日志文件的参数,下面是未作设置的db_create_online参数

    SQL> SHOW PARAMETER db_create_online

 

       NAME                                 TYPE        VALUE

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

       db_create_online_log_dest_1          string

       db_create_online_log_dest_2          string

       db_create_online_log_dest_3          string

       db_create_online_log_dest_4          string

       db_create_online_log_dest_5          string

 

    --从上面可以看出系统预留了一个日志组个成员来形成OMF,一般情况下我们仅仅需要个成员即可。因为在此设定个参数文件

    --下面是未设定的情况下创建日志文件,则默认为在数据文件路径及闪回区各放一个文件,因为上述两个路径都是OMF路径,如下:

 

    SQL> SELECT MEMBER FROM v$logfile;

 

       MEMBER

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

       /u01/app/oracle/oradata/orcl/redo03.log

       /u01/app/oracle/oradata/orcl/redo02.log

       /u01/app/oracle/oradata/orcl/redo01.log

       /u01/app/oracle/oradata/orcl/ORCL/onlinelog/o1_mf_4_5vtgzjyz_.log

       /u01/app/oracle/flash_recovery_area/ORCL/onlinelog/o1_mf_4_5vtgzlhb_.log

 

    SQL> SHOW PARAMETER db_create_file_dest

 

       NAME                                 TYPE        VALUE

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

       db_create_file_dest                  string      /u01/app/oracle/oradata/orcl

 

       SQL> show parameter db_recovery_file_dest

 

       NAME                                 TYPE        VALUE

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

       db_recovery_file_dest                string      /u01/app/oracle/flash_recovery

                                                  _area

       db_recovery_file_dest_size           big integer 2G

 

    --将日志文件存放到指定的disk1,disk2下面

    SQL> ho mkdir /u01/app/oracle/disk1

 

    SQL> ho mkdir /u01/app/oracle/disk2

 

    SQL> ALTER SYSTEM SET db_create_online_log_dest_1 = '/u01/app/oracle/disk1';

 

       System altered.

 

    SQL> ALTER SYSTEM SET db_create_online_log_dest_2 = '/u01/app/oracle/disk2';

 

       System altered.

 

    SQL> ALTER DATABASE ADD logfile;

 

       Database altered.

 

    SQL> SELECT * FROM v$logfile; /*可以看到新的日志文件放到disk1,disk2下面*/

 

       GROUP# STATUS  TYPE    MEMBER                                   IS_

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

            3         ONLINE  /u01/app/oracle/oradata/orcl/redo03.log  NO

            2         ONLINE  /u01/app/oracle/oradata/orcl/redo02.log  NO

            1         ONLINE  /u01/app/oracle/oradata/orcl/redo01.log  NO

            4         ONLINE  /u01/app/oracle/oradata/orcl/ORCL/online NO

                            log/o1_mf_4_5vtgzjyz_.log

 

            4         ONLINE  /u01/app/oracle/flash_recovery_area/ORCL YES

                            /onlinelog/o1_mf_4_5vtgzlhb_.log

 

            5         ONLINE  /u01/app/oracle/disk1/ORCL/onlinelog/o1_ NO

                            mf_5_5vtlpxo0_.log

 

       GROUP# STATUS  TYPE    MEMBER                                   IS_

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

 

            5         ONLINE  /u01/app/oracle/disk2/ORCL/onlinelog/o1_ NO

                            mf_5_5vtlpz4d_.log

 

                            SQL> alter database drop logfile group 5;

 

    Database altered.

 

    /*删除日志文件组*/

    SQL> ALTER DATABASE DROP logfile GROUP 4;

 

       Database altered.

 

    SQL> SELECT group#,member FROM v$logfile;

 

       GROUP# MEMBER

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

            3 /u01/app/oracle/oradata/orcl/redo03.log

            2 /u01/app/oracle/oradata/orcl/redo02.log

            1 /u01/app/oracle/oradata/orcl/redo01.log

            

    SQL> ho ls /u01/app/oracle/disk1/ORCL/onlinelog/o1_mf_5_5vtlpxo0_.log;

       ls: /u01/app/oracle/disk1/ORCL/onlinelog/o1_mf_5_5vtlpxo0_.log: No such file or directory

        

总结:

  1.当定义了db_recovery_file_dest db_create_file_dest路径,且没有定义db_create_online_log_dest_n的时候,

    OMF将日志文件存放在db_recovery_file_destdb_create_file_dest路径下,而且日志组下为个成员

  2.当定义了db_create_online_log_dest_1则将日志文件存放到db_create_online_log_dest_1

    db_create_file_dest路径下,且日志组下为个成员

  3.当定义了db_create_online_log_dest_1db_create_online_log_dest_2则存放到

    db_create_online_log_dest_1db_create_online_log_dest_2

  4.当定义了多个db_create_online_log_dest_n,则为每个组n个日志成员,且多路复用

  5.增加日志文件的方法;

    alter database add logfile;

    alter database add logfile [group n];

    alter database add logfile member '<dir>' to group [n]

    /*add logfile member这个方法仅使用未使用OMF的日志文件,对于已经运用了OMF的日志组,无法使用该功能添加日志文件*/

  6.删除日志文件组时,对于OMF的日志文件组,其对应的物理文件同时被删除

    alter database drop logfile group [n]

 

 

.使用OMF管理控制文件

  使用OMF管理控制文件同管理日志文件类似,主要涉及到的也是db_create_online_log_dest_n参数

  即控制文件默认存放在db_create_online_log_dest_n下,当定义了一个db_create_online_log_dest_n

  则生成一个控制文件,当定义了多了则生成多个控制文件。

  前提条件:去掉control_files参数

  alter system reset control_files scope = spfile sid = '*';

 

  以下是预留的OMF路径:

    SQL> SHOW PARAMETER db_create

 

       NAME                                 TYPE        VALUE

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

       db_create_file_dest                  string      /u01/app/oracle/oradata/orcl

       db_create_online_log_dest_1          string      /u01/app/oracle/disk1

       db_create_online_log_dest_2          string      /u01/app/oracle/disk2

       db_create_online_log_dest_3          string

       db_create_online_log_dest_4          string

       db_create_online_log_dest_5          string

    SQL> show parameter db_recovery_file

 

       NAME                                 TYPE        VALUE

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

       db_recovery_file_dest                string      /u01/app/oracle/flash_recovery

                                               _area

       db_recovery_file_dest_size           big integer 2G

 

总结

    参数                                         适用范围

    db_create_file_dest_size          datafilecreate tablespace<>

    db_create_online_log_dest_n       logfile ,controlfile

    db_recovery_file_dest             rman, archivelog,onlinelog

 

.更多

   VmWare6.5.2下安装RHEL 5.4(配置Oracle安装环境)  

 

   Linux (RHEL 5.4)下安装Oracle 10g R2

 

   使用Uniread实现SQLplus翻页功能

  

   Oracle 相关

   Using Oracle-Managed Files

 

  

 

这篇关于Oralce OMF 功能详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/183460

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

LabVIEW FIFO详解

在LabVIEW的FPGA开发中,FIFO(先入先出队列)是常用的数据传输机制。通过配置FIFO的属性,工程师可以在FPGA和主机之间,或不同FPGA VIs之间进行高效的数据传输。根据具体需求,FIFO有多种类型与实现方式,包括目标范围内FIFO(Target-Scoped)、DMA FIFO以及点对点流(Peer-to-Peer)。 FIFO类型 **目标范围FIFO(Target-Sc