在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系统权限
要进行此项授权操作需使用SYSDBA权限(或INTERNAL帐号)连入数据库且初始化参数REMOTE_LOGIN_PASSWORDFILE的设置必须为EXCLUSIVE具体操作步骤如下
创建相应的密码文件
设置初始化参数REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
使用SYSDBA权限登录
CONNECTSYS/internal_user_passswordASSYSDBA
启动数据库实例并打开数据库
创建相应用户帐号对其授权(包括SYSOPER和SYSDBA)
授予权限GRANTSYSDBATOuser_name
收回权限REVOKESYSDBAFROMuser_name
现在这些用户可以以管理员身份登录数据库系统了
四 使用密码文件登录
有了密码文件后用户就可以使用密码文件以SYSOPER/SYSDBA权限登录Oracle数据库实例了注意初始化参数REMOTE_LOGIN_PASSWORDFILE应设置为EXCLUSIVE或SHARED任何用户以SYSOPER/SYSDBA的权限登录后将位于SYS用户的Schema之下以下为两个登录的例子
以管理员身份登录
假设用户scott已被授予SYSDBA权限则他可以使用以下命令登录
CONNECTscott/tigerASSYSDBA
以INTERNAL身份登录
CONNECTINTERNAL/INTERNAL_PASSWORD
五密码文件的维护
查看密码文件中的成员
可以通过查询视图V$PWFILE_USERS来获取拥有SYSOPER/SYSDBA系统权限的用户的信息表中SYSOPER/SYSDBA列的取值TRUE/FALSE表示此用户是否拥有相应的权限这些用户也就是相应地存在于密码文件中的成员
扩展密码文件的用户数量
当向密码文件添加的帐号数目超过创建密码文件时所定的限制(即ORAPWDEXE工具的MAX_USERS参数)时为扩展密码文件的用户数限制需重建密码文件具体步骤如下
(a)查询视图V$PWFILE_USERS记录下拥有SYSOPER/SYSDBA系统权限的用户信息
(b)关闭数据库
(c) 删除密码文件
(d) 用ORAPWDEXE新建一密码文件
(e) 将步骤a中获取的用户添加到密码文件中
修改密码文件的状态
密码文件的状态信息存放于此文件中当它被创建时它的缺省状态为SHARED可以通过改变初始化参数REMOTE_LOGIN_PASSWORDFILE的设置改变密码文件的状态当启动数据库事例时Oracle系统从初始化参数文件中读取REMOTE_LOGIN_PASSWORDFILE参数的设置当加载数据库时系统将此参数与口令文件的状态进行比较如果不同则更新密码文件的状态若计划允许从多台客户机上启动数据库实例由于各客户机上必须有初始化参数文件所以应确保各客户机上的初始化参数文件的一致性以避免意外地改变了密码文件的状态造成数据库登陆的失败
修改密码文件的存储位置
密码文件的存放位置可以根据需要进行移动但作此修改后应相应修改系统注册库有关指向密码文件存放位置的参数或环境变量的设置
删除密码文件
在删除密码文件前大家应当确保当前运行的各数据库实例的初始化参数REMOTE_LOGIN_PASSWORDFILE皆设置为NONE
(注释在删除密码文件后假如需要以管理员身份连入数据库则一定要使用操作系统验证的方法来进行登录)