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认证。

  • 相关阅读:
    Android事件详解——拖放事件DragEvent
    Android 用户界面---拖放(Drag and Drop)(三)
    Android 用户界面---拖放(Drag and Drop)(二)
    Android 用户界面---拖放(Drag and Drop)(一)
    Android开发者指南-用户界面-拖放-Drag and Drop[原创译文]
    Android L动画入门
    基本介绍LINUX远程PC软件:PUTTY、SecureCRT、X-Manager
    js字的数目的计算方法(与word计算公式为)
    动机,努力工作,提高能力,提高战斗力,要注意保暖,维护创业热情。
    pig询问top k,每个返回hour和ad_network_id最大的两个记录(SUBSTRING,order,COUNT_STAR,limit)
  • 原文地址:https://www.cnblogs.com/alexy/p/createdb5.html
Copyright © 2011-2022 走看看