建立了一个ACFS文件系统,mount后改为oracle用户的权限,但重启后仍是root权限。导致我每次重启后都需要手工设置。
这两个文档,一个还原了问题,一个提供了解决方法。
为让权限可以在重启后重新保持,需要通过srvctl来设置。
需要使用root用户:
export ORACLE_HOME=/u01/app/oracle/product/19.0.0.0/dbhome_1
srvctl modify filesystem -d /dev/asm/datavol01-139 -mountowner oracle -mountgroup oinstall -mountperm 755
这里有几点需要说明。
$ df -t acfs
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/asm/commonstore-37 5242880 313628 4929252 6% /opt/oracle/dcs/commonstore
/dev/asm/datavol01-37 52428800 39713180 12715620 76% /u01/data/acfs
SQL> select count(*) from lineorder_acfs;
select count(*) from lineorder_acfs
*
ERROR at line 1:
ORA-29913: error in executing ODCIEXTTABLEOPEN callout
ORA-29400: data cartridge error
KUP-04040: file lineorder.tbl in ACFSDIR not found
我并不想通过重启来验证。因此umount再mount是简便的方法。
# export ORACLE_HOME=/u01/app/oracle/product/19.0.0.0/dbhome_1
# srvctl stop filesystem -device /dev/asm/datavol01-37
# srvctl start filesystem -device /dev/asm/datavol01-37
$ ls -ld /u01/data/acfs
drwxr-xr-x 4 root root 32768 Nov 9 17:58 /u01/data/acfs
下面是另一种重新mount的方法:
/bin/umount /u01/data/acfs
mount -t acfs /dev/asm/datavol01-139 /u01/data/acfs
以下是部分查看ACFS的命令:
$ crsctl status resource|grep acfs
NAME=ora.data.commonstore.acfs
TYPE=ora.acfs.type
NAME=ora.data.datavol01.acfs
TYPE=ora.acfs.type
$ srvctl status filesystem
ACFS file system /opt/oracle/dcs/commonstore is mounted on nodes btsi02
ACFS file system /u01/data/acfs is mounted on nodes btsi02