sysdba登录 ORA-01017:用户名密码出错 故障排查实例

网友投稿 383 2022-08-24

sysdba登录 ORA-01017:用户名密码出错 故障排查实例

早上接到一个朋友的急call,说是数据库的sys登录不了系统叻。普通用户连接可以登录,只要是as sysdba就提示ORA-01017:用户名密码出错。  很显然这是一个典型的sysdba登录的问题。  首先要他查看了sqlnet文件。SQLNET.AUTHENTICATION_SERVICES= (NONE) 启动密码文件验证了,  接着查看$ORACLE_HOME/dbs/下有没有orapw$ORACLE_SID的文件,确定有。  接着查看remote_login_passwordfile的值,我估计这时他的值一定是NONE,而不是EXCLUSIVE  不过怎么来确定这个推断了。remote_login_passwordfile是init的参数,我们可以通过show parameters remote_login_passwordfile来查看,也可以直接查看spfile文件,spfile虽然是二进制文件,不过里面的内容是看到文本的  more $ORACLE_HOME/dbs/spfile$SID.ora.  最后发现确实remote_login_passwordfile=none。  现在问题大致上应该确定了,就是remote_login_passwordfile的设置问题了。开始着手解决,先屏蔽掉sqlnet.ora里SQLNET.AUTHENTICATION_SERVICES= (NONE)使得本机的 sqlplus “/ as sysdba” 可以进去  SQL>startup mount  SQL>show parameters remote_login_passwordfile;  这时出来的值是none,修改值为exclusive  SQL>alter system set remote_login_passwordfile=EXCLUSIVE scope=spfile;  SQL>shutdown immediate  SQL>startup  SQL>select * from v$pwfile_users;  看有没有结果出来,一切OK。  现在登录,远程和本机都已经OK叻。  朋友这时候才想起来,前几天自己在设置sysdba远程的时候,试到这里就放下来了,而后一直都没有用远程登录,知道今天用远程登录才发现出现这个问题。  这个问题还有一个很快的方式,自己找到init.ora里remote_login_passwordfile那行,在后面加上EXCLUSIVE。然后从pfile启动就可以了。  SQL>startup pfile=’$ORACLE_BASE/admin/$ORACLE_SID/pfile/init.ora’;

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:走近Oracle数据字典(二)--动态性能视图
下一篇:浙江将重点整治网络直播营销十方面违法行为!(加强网络直播营销活动监管)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~