To prove what you have said when you were young! ——Alexy Young

Follow Your Heart

PM/ACP/PRINCE2……

   :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

一、ORACLE密码文件说明

  oracle的密码文件是oracle数据库中拥有管理权限的(即拥有sysdba或者sysoper权限的)的用户登陆oracle数据库的其中一种方式,即这些用户可以通过oracle的密码文件来登陆数据库。如何创建呢?下面就如何创建和管理ORACLE密码文件进行如下探讨。

1、密码文件创建

标准说法是使用orapwd来创建数据库密码文件,一般的命令格式如下:

[oracle@ocmserver ~]$ orapwd
Usage: orapwd file=<fname> password=<password> entries=<users> force=<y/n> 

  where
    file - name of password file (mand),
    password - password for SYS (mand),
    entries - maximum number of distinct DBA and     force - whether to overwrite existing file (opt),
OPERs (opt), 
  There are no spaces around the equal-to (=) character.

举例如下:

[oracle@ocmserver dbs]$ orapwd file=ocpserver password=oracle force=y
[oracle@ocmserver dbs]$ sqlplus sys/oracle as sysdba

SQL*Plus: Release 10.2.0.1.0 - Production on Wed Jul 3 21:34:37 2013

Copyright (c) 1982, 2005, Oracle.  All rights reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options

SQL> show user;
USER is "SYS"
SQL> 

2、设置远程登录密码文件

  • REMOTE_LOGIN_ PASSWORDFILE
  • SQLNET.AUTHENTICATION_SERVICES

remote_login_passwordfile可通过2中方法查看

1)show parameter remote_login_pa

2)grep remote_login_passwordfile init<sid>.ora

SQL> show parameter remote_login_pa

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
remote_login_passwordfile string EXCLUSIVE
SQL> ! grep 'remote_login_passwordfile' /opt/oracle/product/dbs/initocpserver.ora
remote_login_passwordfile=EXCLUSIVE

SQL>

那么修改当然就有了很多方法,直接修改参数文件并重启,或者alert system set remote_login_passwordfile='' scope='' sid=''

remote_login_passwordfile参数有如下选项

remote_login_passwordfile=none|shared|exclusive

NONE:指示Oracle系统不使用密码文件,特权用户的登录通过操作系统进行身份验证;
EXCLUSIVE:指示只有一个数据库实例可以使用此密码文件。只有在此设置下的密码文件可以包含有除INTERNAL/SYS以外的用户信息,即允许将系统权限SYSOPER/SYSDBA授予除INTERNAL/SYS以外的其他用户。
SHARED:指示可有多个数据库实例可以使用此密码文件。在此设置下只有INTERNAL/SYS帐号能被密码文件识别,即使文件中存有其他用户的信息,也不允许他们以SYSOPER/SYSDBA的权限登录。此设置为缺省值。
  在REMOTE_LOGIN_PASSWORDFILE参数设置为EXCLUSIVE、SHARED情况下,Oracle系统搜索密码文件的次序为:在系统注册库中查找ORA_SID_PWFILE参数值(它为密码文件的全路径名);若未找到,则查找ORA_PWFILE参数值;若仍未找到,则使用缺省值ORACLE_HOME\DATABASE\PWDSID.ORA;其中的SID代表相应的Oracle数据库系统标识符。

SQLNET.AUTHENTICATION_SERVICES参数在sqlnet.ora里面有说明:

三、向密码文件中增加、删除用户

当初始化参数REMOTE_LOGIN_PASSWORDFILE设置为EXCLUSIVE时,系统允许除INTERNAL/SYS以外的其他用户以管理员身份从远端或本机登录到Oracle数据库系统,执行数据库管理工作;这些用户名必须存在于密码文件中,系统才能识别他们。由于不管是在创建数据库实例时自动创建的密码文件,还是使用工具ORAPWD.EXE手工创建的密码文件,都只包含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之下,以下为两个登录的例子:
  1. 以管理员身份登录:
  假设用户scott已被授予SYSDBA权限,则他可以使用以下命令登录:
  CONNECTscott/tiger AS SYSDBA
  2. 以INTERNAL身份登录:
  CONNECT INTERNAL/INTERNAL_PASSWORD

五、实验证明

六、参考

七、小结

用户密码验证对ORACLE用户非常重要,而ORACLE提供2中方式进行身份验证。一种为OS认证,一种为DB认证。

 

posted on 2013-07-03 21:52  Alexy Young  阅读(844)  评论(0编辑  收藏  举报

Alexy Young CHASEDREAM