76 DBMS_FS
The DBMS_FS
package for performing operations on an Oracle file system (make, mount, unmount and destroy operations) in an Oracle database.
This chapter contains the following topics:
76.1 DBMS_FS Overview
The DBMS_FS
package contains Oracle file system (OFS) procedures that you can use to create, mount, unmount, and destroy an Oracle file system.
Starting 19c release, the file systems are supported by PDB. Oracle Database supports maximum 5 file systems per PDB and 1000 file systems in total.
The DBMS_FS
package enables applications to access database objects from a universal client such as an NFS server. This feature interfaces with Oracle SecureFiles to provide the file system access.
See Also:
Oracle Database SecureFiles and Large Objects Developer's Guide for a detailed description of managing an NFS server in Oracle Database
76.2 DBMS_FS Security Model
You must have the SYSDBA
administrative privilege to use the DBMS_FS
package.
The operations that you perform using the DBMS_FS
package are equivalent to the file system operations that are performed in an operating system by the root user. Access to the individual file system that is created and mounted by this package is enforced using Access Control Lists (ACLs) and the permissions on the mounted directories to the operating system user.
76.3 Summary of DBMS_FS Subprograms
This table lists the DBMS_FS
subprograms and briefly describes them.
Table 76-1 DBMS_FS Subprograms
Subprogram | Description |
---|---|
Destroys an Oracle file system, using the |
|
Creates a file system of type specified by |
|
Mounts an Oracle file system on the specified mount point |
|
Unmounts an Oracle file system on the specified mount point |
76.3.1 DESTROY_ORACLE_FS Procedure
This procedure destroys an Oracle file system and then frees the resources that were associated with it. Run the dbms_fs.destroy_oracle_fs()
procedure to destroy file systems that are no longer in use.
Syntax
DBMS_FS.DESTROY_ORACLE_FS ( fstype IN VARCHAR2, fsname IN VARCHAR2);
Parameters
Table 76-2 DBMS_FS Parameters
Parameter | Description |
---|---|
|
File system type. Oracle File System (OFS) and Database File System (DBFS) are supported. |
|
Name of the file system |
Usage Notes
-
You can find information about the currently mounted file systems by querying the
V$OFSMOUNT
dynamic view. -
For more information about the file system types, see the
fstype
description in MAKE_ORACLE_FS Procedure. -
Before you run the
DBMS_FS.DESTROY_ORACLE_FS
procedure, you must unmount the file system by using theDBMS_FS.UNMOUNT_ORACLE_FS
procedure. If you run this procedure on a file system that is still in use, it results in an error. -
After you run
DBMS_FS.DESTROY_ORACLE_FS
, Oracle Database destroys the file system and frees the associated resources.
Example
The following sample code shows how to destroy a DBFS file system, dbfs_fs1
.
BEGIN DBMS_FS.DESTROY_ORACLE_FS ( fstype => 'dbfs', fsname => 'dbfs_fs1'); END; /
76.3.2 MAKE_ORACLE_FS Procedure
This procedure creates a new file system of type DBFS
or OFS
, on top of an existing Oracle tablespace or other database object.
Syntax
DBMS_FS.MAKE_ORACLE_FS ( fstype IN VARCHAR2, fsname IN VARCHAR2, fsoptions IN VARCHAR2);
Parameters
Table 76-3 DBMS_FS Parameters
Parameter | Description |
---|---|
|
File system type. Enter one of the following values:
|
|
Name of the file system. Enter a string no longer than 256 characters, using alphanumeric characters. |
|
Specify an existing tablespace to use for the Oracle file system, using the following format: "tablespace=tablespace_name" |
Usage Notes
-
If you want to create a database file system (DBFS), then you must run the
dbfs_create_filesystem.sql
script, which in turn calls thedbfs_create_filesystem_advanced.sql
script. By default, this script is in the$ORACLE_HOME/rdbms/admin
directory. When you run this script, provide the name of an existing tablespace and a name for the file system that will be stored in the database. The size of the file system will be the same as the table size. For example, to create a file system in thedbfs_ts
tablespace, in the file systemdbfs_tab
:@/$ORACLE_HOME/rdbms/admin/dbfs_create_filesystem.sql dbfs_ts dbfs_tab
After you run this script, you can use the other procedures in the
DBMS_FS
package to mount, unmount, and destroy the file system.Note:
Staring Oracle Database19.3.1.0
release, theDBMS_FS.MAKE_ORACLE_FS
is used to create aDBFS
filesystem; hence no auxiliary SQL script is needed to create aDBFS
filesystem. -
Running the
DBMS_FS.MAKE_ORACLE_FS
procedure on the database instance is equivalent to running themkfs
command by root in an operating system. -
The tablespace that you specified in the
fsoptions
parameter must already exist before you execute theDBMS_FS.MAKE_ORACLE_FS
procedure. To find existing tablespaces, query theDBA_TABLESPACES
data dictionary view. -
The size of the file system is the same size as this tablespace.
Example
The following example shows how to create a DBFS file system named dbfs_fs1
in the tablespace dbfs_fs1_tbspc
.
BEGIN DBMS_FS.MAKE_ORACLE_FS ( fstype => 'dbfs', fsname => 'dbfs_fs1', fsoptions => 'TABLESPACE=dbfs_fs1_tbspc'); END; /
76.3.3 MOUNT_ORACLE_FS Procedure
Use the dbms_fs.mount_oracle_fs()
procedure to mount an Oracle file system or OFS managed file system on the specified mount point.
Before you begin, complete the following checks to ensure that:
- You have created the file system using the
dbms_fs.make_oracle_fs()
procedure. - The mount point that you specify exists in the local node.
- The Oracle user has access permissions.
- The mount path is empty, which means that the directory specified by the mount point does not have any files.
Oracle supports an extensive list of mount options that you can use to have better control on resources and achieve good performance. The file system is mounted and is visible through a mounted path on the compute node. In case of RAC, mount the file system in each RAC cluster node independently.
Since OFSD is a non-fatal background process, it gets automatically restarted after the death of a process. File systems that are mounted at the time of the death of the OFSD process are automatically remounted after starting a new OFSD process. This ensures continuous availability of the mounted file systems even in the case of an error.
To improve the throughput, OFSD has its own local cache for writes and reads. The write cache uses 8 (1 MB) buffers per file connection, and it can use up to 256 MB per file system. You can modify this value through the mount option, wcache_size
. A read-ahead algorithm is implemented for read operation and it uses 2 (1 MB) per file connection and it can use up to 256 MB per file system. Use the mount option, rcache_size
, to modify this value.
The read-write cache is maintained per node, so this provides local cache consistency. In an RAC environment, consistency is guaranteed only after the flush()
or close()
operation is performed on the file. When two different processes on two different RAC nodes modify a single file and write to the same offset, then the first process that performs the close()
operation on the file will have its data written into the file.
Syntax
DBMS_FS.MOUNT_ORACLE_FS ( fstype IN VARCHAR2, fsname IN VARCHAR2, mount_point IN VARCHAR2, mount_options IN VARCHAR2);
Parameters
Table 76-4 MOUNT_ORACLE_FS Procedure Parameters
Parameter | Description |
---|---|
|
File system type. Oracle File System (OFS) and Database File System (DBFS) are supported. |
|
Name of the file system. Enter a string no longer than 256 characters, using alpha numeric characters. |
|
Local directory where the file system should be mounted. This directory must already exist. Enter an absolute path. The maximum number of mount points that you can create is 5 mount points per PDB and 1000 mount points per instance. |
|
Comma-separated mount options, listed in Table 76-5. |
Usage Notes
Table 76-5 Supported Mount Options for the MOUNT_ORACLE_FS procedure
Mount Option | Usage Description |
---|---|
default_permissions |
Enables permission check and restrict access based on file mode. This option is useful with the allow_other mount option. |
allow_other
|
Allows other users apart from the operating system user that did the mount can access the files. This will be used in conjunction with permission checks in determining the file access. This option requires setting the user_allow_other parameter in the /etc/fuse.conf configuration file on Linux.
|
max_read
|
Maximum size of the read operation. No maximum size is set by default. |
max_write
|
Maximum write size in a single request. The default is 128K. |
direct_io |
Indicates to the operating system kernel not use file system cache. |
ro |
Mounts the file system in read-only mode. Files cannot be modified. |
rw |
Mounts the file system as read-write. This is the default. |
nosuid
|
Specifies that the file system cannot contain set userid files. |
suid |
Specifies that the file system can contain set userid files. This is the default. |
exec |
Allows executing a file under the mount path. This option is enabled by default. |
noexec |
Prohibits executing a file under the mount path. Use this option to disallow any file to be executed in the file system. |
atime |
Maintains information about the time when the file was accessed. This option is enabled by default. |
noatime |
Does not maintain information about the time when the was file accessed. When you enable this option, it increases throughput as the access time is not updated for every read operation. |
max_readahead=N |
Sets the maximum size for the read-ahead operations to the specified bytes. The default value depends on the versions of the kernel and FUSE in your operating system. |
sync_read |
Permits only synchronous reads. If you use this option, it disables read-ahead caching for OFS. |
async_read |
Permits asynchronous reads. All read and write operations in the file system as performed asynchronously. This is the default option for FUSE versions 7.6 or later. |
dirsync |
Makes all directory operations synchronous. FUSE utilizes this option. |
big_writes |
Permits writes larger than 4KB. This is the default option for FUSE versions 7.6 or later. |
no_big_writes |
Does not allow writes larger than 4KB. This is not a recommended option for OFS. |
xattr_enabled |
Enables the use of extended attributes. Specify this option only if you want to use extended attributes. |
kernel_cache_mode |
Makes the Linux kernel cache behave like a writeback cache when you enter |
kernel_cache_attr_time=N |
Sets the Linux kernel attribute cache timeout to N seconds. The default value is infinity. Oracle recommends that you set low values for RAC setup. |
wcache_size=N |
Sets the OFS write cache size to N bytes. The default value is 256 MB. |
rcache_size=N |
Sets the OFS read cache size to N bytes. The default value is 256 MB. |
posix_locks |
Implements the POSIX file locks in OFS. This is not supported by OFS. If you want to use the file-locking mechanism, use the |
noposix_locks |
Implements POSIX file locks in Linux kernel. This is the default option. |
Note:
ro
/rw
nosuid
/suid
exec
/noexec
atime
/noatime
big_writes
/no_big_writes
sync_read
/async_read
posix_locks
/noposix_locks
Usage Notes
-
This procedure makes the files system visible in the local database instance.
-
For more information about the file system types, see the
fstype
description in MAKE_ORACLE_FS Procedure. -
You can find information about currently mounted file systems by querying the
V$OFSMOUNT
dynamic view. -
Run the
DBMS_FS.MOUNT_ORACLE_FS
procedure on a file system that has already been created withDBMS_FS.MAKE_ORACLE_FS
in the local computer node where the Oracle database instance is running. You cannot run this procedure on file systems that were created outside of Oracle Database. -
You cannot update the mount options after mounting the file system. If you want to change the mount options later, you'll have to unmount the file system, and then remount it.
Example: Mounts a DBFS file system
Mounts a DBFS file system at /oracle/dbfs/testfs
.
BEGIN DBMS_FS.MOUNT_ORACLE_FS ( fstype => 'dbfs', fsname => 'dbfs_fs1', mount_point => '/oracle/dbfs/testfs', mount_options => 'default_permissions, allow_other'); END;
76.3.4 UNMOUNT_ORACLE_FS Procedure
This procedure unmounts an Oracle file system on the specified mount point.
File systems that are mounted in a PDB are automatically unmounted when the PDB is closed. You can also use dbms_fs.unmount_oracle_fs()
to explicitly unmount an Oracle file system that you have mounted through OFS.
Syntax
DBMS_FS.UNMOUNT_ORACLE_FS ( fsname IN VARCHAR2, mount_point IN VARCHAR2, unmount_options IN VARCHAR2);
Table 76-6 UNMOUNT_ORACLE_FS Procedure Parameters
Parameter | Description |
---|---|
|
Name of the file system. |
|
Local directory where the file system had been mounted. Enter an absolute path. |
|
Optionally, enter |
Usage Notes
-
Before you unmount the file system, ensure that all applications that use this file system are shut down. Also ensure that no processes reference the mounting file system.
-
You can find information about the currently mounted file systems by querying the
V$OFSMOUNT
dynamic view. -
For more information about the file system types, see the
fstype
description in MAKE_ORACLE_FS Procedure. -
When an Oracle instance is shut down in normal immediate mode, then all the mounted file systems are automatically unmounted.
-
If a file system is mounted with the
MOUNT_ORACLE_FS
procedure with thepersist
option, it will be automatically mounted again when the database instance starts or the PDB is plugged. If this file system is unmounted by executingDBMS_FS.UNMOUNT_ORACLE_FS
, it will remain unmounted even if thepersist
option was used to mount it. -
If you perform a
SHUTDOWN ABORT
, then the file system may still show as mounted but it may not be accessible. In this case, you can unmount the system manually by calling theunmount
command at the operating system level or thefusermount
procedure on Linux systems. - Do not use
fusermount -u
to unmount a running file system as it causes inconsistency in Oracle views, such asv$ofsmount
. -
You can export the local mount point of an Oracle file system to point to the remote system, and then NFS mount the file system from the remote system by using the operating system
mount
command. TheDBMS_FS.MOUNT_ORACLE_FS
procedure is similar tomount
commands that are used for other local file systems. -
For better security, Oracle recommends that you use access control lists (ACLs) and Kerberos to control access to sensitive data.
-
Do not attempt to unmount the file system from the operating system level. Doing so can leave the Oracle Database-created file system internal tables in an inconsistent state.
Example
The following sample code unmounts a DBFS mounted file system at /oracle/dbfs/testfs
.
BEGIN DBMS_FS.UNMOUNT_ORACLE_FS ( fsname => 'dbfs_fs1', mount_point => '/oracle/dbfs/testfs', mount_options => 'force'); END;