oracle密码文件丢失的恢复
Oracle数据库的口令文件PWDSID.ora(本机参考文件为PWDORCL.ora)是由orapwd.exe 生成的。当密码文件意外丢失后,会出现登陆报错问题。
(本机参考目录C:\app\Administrator\product\11.2.0\dbhome_1\bin\orapwd.exe)
现在我们模拟一下恢复环境。Shutdown 数据库,然后删除密码文件。重启数据库。
提示如下:
C:\Documentsand Settings\Administrator>sqlplus /nolog
SQL>conn / as sysdba;
已连接。
SQL> connsys/1 as sysdba;
已连接。
SQL> connsys/oracle as sysdba;
已连接。
SQL>select * from global_name;
GLOBAL_NAME
--------------------------------------------------------------------------------
ORCL
发现即使没有密码文件,sys账户依然可以以任何密码或者无密码登陆数据库。问题出在哪呢?其实问题出在数据库默认配置下是开启了OS认证,即默认允许操作系统认证,上述登陆使用的即是操作系统认证。
要做相关实验,需要先关闭OS认证,方法是修改C:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN\sqlnet.ora
将其配置中的SQLNET.AUTHENTICATION_SERVICES= (NTS)修改为SQLNET.AUTHENTICATION_SERVICES=(NONE)即可。
此时在登陆数据库时会提示:
SQL> conn sys/oracle as sysdba;
ERROR:
ORA-01031: insufficient privileges
我们知道密码文件是由orapwd.exe程序生成的,那么重新生成一个即可。方法如下:
C:\app\Administrator\product\11.2.0\dbhome_1\bin\orapwd.exefile=C:\app\Administrator\product\11.2.0\dbhome_1\database\PWDorcl.ora password=oracleforce=y
执行上面的命令,重新建立一个sys账户口令为oracle的密码文件。
重新连接数据库测试:
SQL> connsys/1 as sysdba;
ERROR:
ORA-01017:invalid username/password; logon denied
警告: 您不再连接到 ORACLE。
SQL> connsys/oracle as sysdba;
已连接。
SQL>select * from global_name;
GLOBAL_NAME
--------------------------------------------------------------------------------
ORCL
由此可发现,只有sys/oracle才可以正常登陆数据库。
小结:
1.本测试的前提是先关闭OS认证,不然测试必将失败。在风险评估对oracle数据库的检查中也要求关闭OS认证,因为默认开启的OS认证,不能实现系统管理员和数据库管理员的权限分离。系统管理员不应该具有数据库的SYSDBA角色的这一超级权限。
2.明白密码文件生成的原理。它是由bin目录下的orapwd.exe执行命令生成的。密码文件只记录了密码的信息。他的丢失与生成均与重做日志和归档日志无关,直接执行命令生成即可立即生效。