在Oracle系统中用户使用特权用户身份(INTERNAL/SYSDBA/SYSOPER)登录Oracle有两种身份验证方法
使用与操作系统集成的身份验证
使用Oracle数据库的密码文件进行身份验证
因此管理好密码文件对于控制授权用户从远端或本机登录Oracle数据库系统执行数据库管理工作具有重要的意义
Oracle数据库的密码文件存放有超级用户INTERNAL/SYS的口令及其他特权用户的用户名/口令它一般存放在ORACLE_HOME\DATABASE目录下
一 密码文件的创建
在使用Oracle Instance Manager创建一数据库实例的时侯在ORACLE_HOME\DATABASE目录下还自动创建了一个与之对应的密码文件文件名为PWDSIDORA其中SID代表相应的Oracle数据库系统标识符此密码文件是进行初始数据库管理工作的基础在此之后管理员也可以根据需要使用工具ORAPWDEXE手工创建密码文件命令格式如下
C:\ >ORAPWDFILE=< FILENAME >PASSWORD
=< PASSWORD > ENTRIES=< MAX_USERS >
各命令参数的含义为
FILENAME密码文件名;
PASSWORD设置INTERNAL/SYS帐号的口令;
MAX_USERS密码文件中可以存放的最大用户数对应于允许以SYSDBA/SYSOPER权限登录数据库的最大用户数由于在以后的维护中若用户数超出了此限制则需要重建密码文件所以此参数可以根据需要设置得大一些
有了密码文件之后需要设置初始化参数REMOTE_LOGIN_PASSWORDFILE来控制密码文件的使用状态
二 设置初始化参数REMOTE_LOGIN_PASSWORDFILE
在Oracle数据库实例的初始化参数文件中此参数控制着密码文件的使用及其状态它可以有以下几个选项
NONE指示Oracle系统不使用密码文件特权用户的登录通过操作系统进行身份验证;
EXCLUSIVE指示只有一个数据库实例可以使用此密码文件只有在此设置下的密码文件可以包含有除INTERNAL/SYS以外的用户信息即允许将系统权限SYSOPER/SYSDBA授予除INTERNAL/SYS以外的其他用户
SHARED指示可有多个数据库实例可以使用此密码文件在此设置下只有INTERNAL/SYS帐号能被密码文件识别即使文件中存有其他用户的信息也不允许他们以SYSOPER/SYSDBA的权限登录此设置为缺省值
在REMOTE_LOGIN_PASSWORDFILE参数设置为EXCLUSIVESHARED情况下Oracle系统搜索密码文件的次序为在系统注册库中查找ORA_SID_PWFILE参数值(它为密码文件的全路径名);若未找到则查找ORA_PWFILE参数值;若仍未找到则使用缺省值ORACLE_HOME\DATABASE\PWDSIDORA;其中的SID代表相应的Oracle数据库系统标识符
三 向密码文件中增加删除用户
当初始化参数REMOTE_LOGIN_PASSWORDFILE设置为EXCLUSIVE时系统允许除INTERNAL/SYS以外的其他用户以管理员身份从远端或本机登录到Oracle数据库系统执行数据库管理工作;这些用户名必须存在于密码文件中系统才能识别他们由于不管是在创建数据库实例时自动创建的密码文件还是使用工具ORAPWDEXE手工创建的密码文件都只包含INTERNAL/SYS用户的信息;为此在实际操作中可能需要向密码文件添加或删除其他用户帐号
由于仅被授予SYSOPER/SYSDBA系统权限的用户才存在于密码文件中所以当向某一用户授予或收回SYSOPER/SYSDBA系统权限时他们的帐号也将相应地被加入到密码文件或从密码文件中删除由此向密码文件中增加或删除某一用户实际上也就是对某一用户授予或收回SYSOPER/SYSDBA系统权限
[] []