Friday, August 2, 2024

Oracle Database File Mapping for Oracle ASM Files

 Oracle Database File Mapping for Oracle ASM Files

(12c..23c)

Database Box

Alireza Kamrani : 08/03/2024

For an understanding of I/O performance, you must have detailed knowledge of the storage hierarchy in which files reside. 

Oracle Database provides a set of dynamic performance views to show a complete mapping of a file to intermediate layers of logical volumes to actual physical devices. 

Using these dynamic views, you can locate the exact disk on which any block of a file resides.

Oracle Database communicates with a background process called FMON to manage the mapping information. 


Oracle provides the PL/SQL DBMS_STORAGE_MAP package to invoke mapping operations that populate the mapping views.


Oracle Database file mapping does not require third party libraries when mapping Oracle ASM files. 

In addition, Oracle Database supports Oracle ASM file mapping on all operating system platforms.


All the examples in this section are run on the Oracle Database instance.

This section contains the following topics:

  • Enabling File Mapping With Oracle ASM Files
  • Using File Mapping Views With Oracle ASM Files
  • Using the DBMS_STORAGE_MAP Package With Oracle ASM Files



DBMS_STORAGE_MAP Overview

This terminology and descriptions will help you understand the DBMS_STORAGE_MAP API.

  • Mapping libraries
    Mapping libraries help you map the components of I/O processing stack elements. Examples of I/O processing components include files, logical volumes, and storage array I/O targets. The mapping libraries are identified in filemap.ora. 
  • Mapping files
    A mapping file is a mapping structure that describes a file. It provides a set of attributes, including file size, number of extents that the file is composed of, and file type.
  • Mapping elements and sub-elements
    A mapping element is the abstract mapping structure that describes a storage component within the I/O stack. Examples of elements include mirrors, stripes, partitions, raid5, concatenated elements, and disks—structures that are the mapping building blocks. A mapping sub-element describes the link between an element and the next elements in the I/O mapping stack
  • Mapping file extents
    A mapping file extent describes a contiguous chunk of blocks residing on one element. This includes the device offset, the extent size, the file offset, the type (data or parity), and the name of the element where the extent resides. In the case of a raw device or volume, the file is composed of only one file extent component. A mapping file extent is different from Oracle extents.


Enabling File Mapping With Oracle ASM Files

To enable file mapping, set the FILE_MAPPING initialization parameter to TRUE. 

The database instance does not have to be shut down to set this parameter. 

You can set the parameter using the following ALTER SYSTEM statement:


SQL>ALTER SYSTEM SET FILE_MAPPING = TRUE;


Run the appropriate DBMS_STORAGE_MAP mapping procedure. 


In a cold startup scenario, the Oracle Database has just started and no mapping operation has been invoked yet. 


You can execute the DBMS_STORAGE_MAP.MAP_ALL procedure to build the mapping information for the entire I/O subsystem associated with the database. 

For example, the following command builds mapping information and provides for 10000 extents: 


SQL> EXECUTE DBMS_STORAGE_MAP.MAP_ALL(10000);


In a warm start scenario where the mapping information has already been built, you have the option to invoke the DBMS_STORAGE_MAP.MAP_SAVE procedure to save the mapping information in the data dictionary. 


This procedure is invoked in DBMS_STORAGE_MAP.MAP_ALL() by default. 


This forces all of the mapping information in the SGA to be flushed to disk. 


The DBMS_STORAGE_MAP.MAP_SAVE procedure is invoked in DBMS_STORAGE_MAP.MAP_ALL() by default.


After you restart the database, use DBMS_STORAGE_MAP.RESTORE() to restore the mapping information into the SGA. 


If needed, DBMS_STORAGE_MAP.MAP_ALL() can be called to refresh the mapping information.


Using File Mapping Views With Oracle ASM Files

Mapping information generated by DBMS_STORAGE_MAP package is captured in dynamic performance views. 


These views include V$MAP_COMP_LIST, V$MAP_ELEMENT, V$MAP_EXT_ELEMENT, V$MAP_FILE, V$MAP_FILE_EXTENT, V$MAP_FILE_IO_STACK, V$MAP_LIBRARY, and V$MAP_SUBELEMENT. 


For example, you can view file mappings with V$MAP_FILE.


SQL> SELECT FILE_MAP_IDX, SUBSTR(FILE_NAME,1,45), FILE_TYPE, FILE_STRUCTURE FROM V$MAP_FILE;


FILE_MAP_IDX SUBSTR(FILE_NAME,1,45)                        FILE_TYPE   FILE_STRU

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

+DATA/ORCL/DATAFILE/system.258.841314      DATAFILE    ASMFILE          

+DATA/ORCL/DATAFILE/sysaux.257.841311      DATAFILE    ASMFILE          

+DATA/ORCL/DATAFILE/undotbs1.260.8413    DATAFILE    ASMFILE          

+DATA/ORCL/DATAFILE/example.266.841314     DATAFILE    ASMFILE         

+DATA/ORCL/DATAFILE/users.259.841314       DATAFILE    ASMFILE  

+DATA/ORCL/ONLINELOG/group_3.264.84131    LOGFILE     ASMFILE

+FRA/ORCL/ONLINELOG/group_3.259.84131     LOGFILE     ASMFILE

+DATA/ORCL/ONLINELOG/group_2.263.84131    LOGFILE     ASMFILE

+FRA/ORCL/ONLINELOG/group_2.258.84131     LOGFILE     ASMFILE

+DATA/ORCL/ONLINELOG/group_1.262.8413    LOGFILE     ASMFILE

10 

+FRA/ORCL/ONLINELOG/group_1.257.84131     LOGFILE     ASMFILE

11 

+DATA/ORCL/TEMPFILE/temp.265.841314217        TEMPFILE    ASMFILE

12 

+DATA/ORCL/CONTROLFILE/current.261.891  CONTROLFILE ASMFILE

13 

+FRA/ORCL/CONTROLFILE/current.256.678   CONTROLFILE ASMFILE


Using the DBMS_STORAGE_MAP Package With Oracle ASM Files

You can use the procedures in the DBMS_STORAGE_MAP PL/SQL package to control mapping operations. 


For example, you can use the DBMS_STORAGE_MAP.MAP_OBJECT procedure to build mapping information for the database object that is specified by object name, owner, and type. 

After the DBMS_STORAGE_MAP.MAP_OBJECT procedure is run, then you can create a query to display the mapping information contained in the MAP_OBJECT view.


SQL> EXECUTE DBMS_STORAGE_MAP.MAP_OBJECT('EMPLOYEES','HR','TABLE');


SQL> SELECT io.OBJECT_NAME o_name, io.OBJECT_OWNER o_owner, io.OBJECT_TYPE o_type,

  mf.FILE_NAME, me.ELEM_NAME, io.DEPTH,

(SUM(io.CU_SIZE * (io.NUM_CU - DECODE(io.PARITY_PERIOD, 0, 0, 

TRUNC(io.NUM_CU / io.PARITY_PERIOD)))) / 2) o_size

   FROM MAP_OBJECT io, V$MAP_ELEMENT me, V$MAP_FILE mf

   WHERE io.OBJECT_NAME =  'EMPLOYEES'

   AND   io.OBJECT_OWNER = 'HR'

   AND   io.OBJECT_TYPE =  'TABLE'

   AND   me.ELEM_IDX = io.ELEM_IDX

   AND   mf.FILE_MAP_IDX = io.FILE_MAP_IDX

   GROUP BY io.ELEM_IDX, io.FILE_MAP_IDX, me.ELEM_NAME, mf.FILE_NAME, io.DEPTH,

         io.OBJECT_NAME, io.OBJECT_OWNER, io.OBJECT_TYPE

   ORDER BY io.DEPTH;

 

O_NAME    O_OWNER O_TYPE FILE_NAME                                 ELEM_NAME        DEPTH O_SIZE

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

EMPLOYEES    HR      TABLE  

+DATA/ORCL/DATAFILE/example.266.841 

+/devices/diskd2     0     64

EMPLOYEES     HR      TABLE  

+DATA/ORCL/DATAFILE/example.266.841 

+/devices/diske2     0     64


Oracle ACFS Support for Oracle Database File Mapping Views

Oracle ACFS supports Oracle Database file mapping views to the Oracle ASM device level.

Note:This feature is available starting with Oracle Database 12c Release 1 (12.1.0.2).

The following database mapping views are supported by Oracle ACFS: 

  • V$MAP_FILE
  • V$MAP_FILE_EXTENT
  • V$MAP_ELEMENT
  • V$MAP_FILE_IO_STACK

These V$MAP views are only refreshed by executing the procedure DBMS_STORAGE_MAP.MAP_ALL. The Oracle ACFS file mapping interface does not utilize the external fmputl process or its supporting libraries.

Note:

  • Oracle ACFS does not provide support for Oracle Database file mapping on Windows.
  • Oracle ACFS does not provide support for the V$MAP_SUBELEMENT view.

Before running any queries on the V$MAP views, ensure that the FILE_MAPPING initialization is set to TRUE, then run the DBMS_STORAGE_MAP.MAP_ALL procedure to build the mapping information for the entire I/O subsystem associated with the database. 

For example, connect as SYSDBA to the database instance and run the following:


SQL> ALTER SYSTEM SET file_mapping=true;


SQL> EXEC DBMS_STORAGE_MAP.MAP_ALL(10000);


The SQL statements in Example A to Example D are run from the Oracle Database instance. 


Example A Viewing Oracle ASM information with V$MAP_ELEMENT

This example displays information from the V$MAP_ELEMENT view.


SQL> SELECT ELEM_NAME, ELEM_IDX, ELEM_TYPE, ELEM_SIZE, ELEM_DESCR 

FROM V$MAP_ELEMENT;


ELEM_NAME      ELEM_IDX ELEM_TYPE   ELEM_SIZE ELEM_DESCR

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

+/dev/xvdd1   ASMDISK 117184512 TEST_0001

+/dev/xvdc1   ASMDISK 117184512 TEST_0000 


Example B Viewing Oracle ACFS Data File Information with V$MAP_FILE

This example displays information from the V$MAP_FILE view.


SQL> SELECT FILE_NAME, FILE_MAP_IDX, FILE_TYPE, FILE_STRUCTURE, FILE_SIZE, 

      FILE_NEXTS FROM V$MAP_FILE WHERE REGEXP_LIKE(FILE_NAME, '*users01.dbf');


FILE_NAME     FILE_MAP_IDX     FILE_TYPE FILE_STRU      FILE_SIZE     FILE_NEXTS

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

/dbdata1/orcl/users01.dbf   4      DATAFILE    FILE   10256    41


Example C Viewing Element and File Offset Information with V$MAP_FILE_EXTENT

This example displays the element offset versus file offset information for each extent with V$MAP_FILE_EXTENT, specifying FILE_MAP_IDX equal to 4, which is the file map index of the /dbdata/orcl/users01.dbf file.


SQL> SELECT FILE_MAP_IDX, EXT_NUM, EXT_ELEM_OFF, EXT_SIZE, EXT_FILE_OFF, 

EXT_TYPE, ELEM_IDX FROM V$MAP_FILE_EXTENT WHERE FILE_MAP_IDX=4; 


FILE_MAP_IDX    EXT_NUM  EXT_ELEM_OFF   EXT_SIZE  EXT_FILE_OFF  EXT_TY  ELEM_IDX

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

  58105664  192 0   DATA   0

  58154752  256 192 DATA   1

  58089472  256 448 DATA   0

...

 39 58140928  256 9920 DATA  1         40 58108160  88  10176 DATA 0

41 rows selected. 


Example D Viewing Extent Information With V$MAP_FILE_IO_STACK

This example displays information from V$MAP_FILE_IO_STACK specifying FILE_MAP_IDXequal to 4. 


The V$MAP_FILE_IO_STACK view is similar to V$MAP_FILE_EXTENT, but the display groups contiguous extents which are on the same device or element and of the same size.


SQL> SELECT FILE_MAP_IDX, ELEM_IDX, CU_SIZE,STRIDE, NUM_CU,ELEM_OFFSET, 

FILE_OFFSET FROM V$MAP_FILE_IO_STACK WHERE FILE_MAP_IDX=4;


FILE_MAP_IDX   ELEM_IDX    CU_SIZE     STRIDE     NUM_CU ELEM_OFFSET FILE_OFFSET

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

4   0   256  1024  10  58089472  448

4   0   192   0    1   58105664  0

4   0   256  1024  9   58105856  960

4   0   88    0    1   58108160  10176

4   1   256  1024 10   58138624  704

4   1   256  1024 10   58154752  192

6 rows selected. 



DBMS_STORAGE_MAP Operational Notes

Invoking the MAP_ELEMENT, MAP_FILE, and MAP_ALLfunctions when mapping information already exists will refresh the mapping, if configuration IDs are supported. 

If configuration IDs are not supported, invoking these functions again will rebuild the mapping.


MAP_FILE Function

This function builds mapping information for the file identified by filename. Use this function if the mapping of one particular file has changed. The Oracle database server does not have to rebuild the entire mapping.

SQL>

DBMS_STORAGE_MAP.MAP_FILE(

   filename           IN VARCHAR2, 

   filetype           IN VARCHAR2,

   cascade            IN BOOLEAN,

 max_num_fileextent IN NUMBER DEFAULT 100,

dictionary_update  IN BOOLEAN DEFAULT TRUE);


Parameters:

Parameter

Description

filename

The file for which mapping information is built.

filetype

Defines the type of the file to be mapped. It can be "DATAFILE", "SPFILE", "TEMPFILE", "CONTROLFILE", "LOGFILE", or "ARCHIVEFILE".

cascade

Should be TRUE only if a storage reconfiguration occurred. For all other instances, such as file resizing (either through an ALTER SYSTEM command or DML operations on extended files), cascade can be set to FALSE because the mapping changes are limited to the file extents only.

If TRUE, mapping DAGs are also built for the elements where the file resides.

max_num_fileextent

Defines the maximum number of file extents to be mapped. This limits the amount of memory used when mapping file extents. The default value is 100; max_num_fileextent is an overloaded argument.

dictionary_update

If TRUE, mapping information in the data dictionary is updated to reflect the changes. The default value is TRUE; dictionary_update is an overloaded argument.

Usage Notes

This function may not obtain the latest mapping information if the file being mapped, or any one of the elements within its I/O stack (if cascade is TRUE), is owned by a library that must be explicitly synchronized.


MAP_OBJECT Function

This function builds the mapping information for the Oracle object identified by the object name, owner, and type. 

SQL>

DBMS_STORAGE_MAP.MAP_OBJECT(

   objname  IN  VARCHAR2,

   owner    IN  VARCHAR2,

   objtype  IN  VARCHAR2);


Parameters:

Parameter

Description

objname

The name of the object.

owner

The owner of the object.

objtype

The type of the object.


MAP_ALL Function

This function builds the entire mapping information for all types of Oracle files (except archive logs), including all directed acyclic graph (DAG) elements. It obtains the latest mapping information because it explicitly synchronizes all mapping libraries.

SQL>

DBMS_STORAGE_MAP.MAP_ALL(

max_num_fileext IN NUMBER DEFAULT 100,

dictionary_update IN BOOLEAN DEFAULT TRUE);


Parameters:

Parameter

Description

max_num_fileext

Defines the maximum number of file extents to be mapped. This limits the amount of memory used when mapping file extents. The default value is 100; max_num_fileextent is an overloaded argument.

dictionary_update

If TRUE, mapping information in the data dictionary is updated to reflect the changes. The default value is TRUE; dictionary_update is an overloaded argument.

Usage Notes

You must explicitly call MAP_ALL in a cold startup scenario.

MAP_ELEMENT Function

This function builds mapping information for the element identified by elemname. It may not obtain the latest mapping information if the element being mapped, or any one of the elements within its I/O stack (if cascade is TRUE), is owned by a library that must be explicitly synchronized.

SQL>

DBMS_STORAGE_MAP.MAP_ELEMENT(

   elemname          IN VARCHAR2,

   cascade           IN BOOLEAN,

   dictionary_update IN BOOLEAN DEFAULT TRUE);


Parameters:

Parameter

Description

elemname

The element for which mapping information is built.

cascade

If TRUE, all elements within the elemname I/O stack DAG are mapped.

dictionary_update

If TRUE, mapping information in the data dictionary is updated to reflect the changes. The default value is TRUE; dictionary_update is an overloaded argument.


RESTORE Function

This function loads the entire mapping information from the data dictionary into the shared memory of the instance. 

You can invoke RESTORE only after a SAVE operation. You must explicitly call RESTORE in a warm startup scenario.


SQL>DBMS_STORAGE_MAP.RESTORE;


SAVE Function

This function saves information needed to regenerate the entire mapping into the data dictionary.

SQL>DBMS_STORAGE_MAP.SAVE;


LOCK_MAP Procedure

This procedure locks the mapping information in the shared memory of the instance. 

This is useful when you need a consistent snapshot of the V$MAP tables. Without locking the mapping information, V$MAP_ELEMENT and V$MAP_SUBELEMENT, for example, may be inconsistent.


SQL>DBMS_STORAGE_MAP.LOCK_MAP;


UNLOCK_MAP Procedure

This procedure unlocks the mapping information in the shared memory of the instance.

SQL>DBMS_STORAGE_MAP.UNLOCK_MAP;


More info:

https://docs.oracle.com/en/database/oracle/oracle-database/12.2/ostmg/asm-files-directories-templates.html


https://docs.oracle.com/en/database/oracle/oracle-database/23/ostmg/asm-files-directories-templates.html#OSTMG94200


Sincerely,

Alireza Kamrani.

No comments:

Post a Comment

Apply multiple Oracle patches Simultaneously

Apply multiple Oracle patches Simultaneously ♠️ Alireza Kamrani ♠️         16 Jan 2025 Step 1. Download all patches and unzip them in a co...