如何给mysql的实例名创建密码_手动创建数据库实例全攻略5:密码文件

一、ORACLE密码文件说明

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

1、密码文件创建

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

[oracle@ocmserver ~]$ orapwd

Usage: orapwd file= password= entries= force=

wherefile-name of password file (mand),

password- password forSYS (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 assysdba

SQL*Plus: Release 10.2.0.1.0 - Production on Wed Jul 3 21:34:37 2013Copyright (c)1982, 2005, Oracle. All rights reserved.

Connected to:

Oracle Database 10g Enterprise Edition Release10.2.0.1.0 -Production

With the Partitioning, OLAP and Data Mining options

SQL>show user;

USERis "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.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认证。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值