oracle.exe文件丢失,oracle密码文件丢失的恢复

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执行命令生成的。密码文件只记录了密码的信息。他的丢失与生成均与重做日志和归档日志无关,直接执行命令生成即可立即生效。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值