zoukankan      html  css  js  c++  java
  • 手动创建数据库实例全攻略5:密码文件

    一、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_HOMEDATABASEPWDSID.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认证。

  • 相关阅读:
    jQuery ajax传多个参数
    PHP 上传图片和安全处理
    PHP CI框架email类发送邮件
    2016-4-7
    jquery 轮播图
    CI控制器的继承问题
    2016-4-1
    2016-3-31 总结
    php内置函数call_user_func()
    discuz-目录
  • 原文地址:https://www.cnblogs.com/alexy/p/createdb5.html
Copyright © 2011-2022 走看看