15.管理profile(笔记)

15.管理profile


Proflie是口令限制,资源限制的命名集合.建立oracle数据库时,oracle会自动建立名为DEFAULT的PROFILE,初始化的DEFAULT没有进行任何口令和资源限制.使用PROFILE有以下一些主要事项.


1,建立PROFILE时,如果只设置了部分口令或资源限制选项,其他选项会自动使用默认值(DEFAULT的相应选项)

2,建立用户时,如果不指定PROFILE选项,oracle会自动将DEFAULT分配给相应的数据库用户.

3,一个用户只能分配一个PROFILE.如果要同时管理用户的口令和资源,那么在建立PROFILE时应该同时指定口令和资源选项.

4,使用PROFILE管理口令时,口令管理选项总是处于被激活状态,但如果使用PROFILE管理资源,必须要激活资源限制.


帐户锁定

帐户锁定用于控制用户联系登陆失败的最大次数.

FAILED_LOGIN_ATTEMPTS:用于指定联系登陆的最大失败次数.

PASSWORD_LOCK_TIME:用于指定帐户被锁定的天数.

为了控制帐户锁定,必须首先执行CREATE PROFILE命令建立PROFILE,然后使用ALTER USER命令将profile分配给用户.

CREATE PROFILE lock_accout LIMIT

FAILED_LOGIN_ATTEMPTS 3

PASSWORD_LOCK_TIME 10;


ALTER USER devep PROFILE lock_account;


如果建立PROFILE时没有提供PASSWORD_LOCK_TIME选项,将自动使用默认值(UNLIMITED),在这种情况下,需要DBA手工解锁.

ALTER USER devep UNLOCK;


口令有效期和终止期

PASSWORD_LIFE_TIME:用于指定口令有效期

PASSWORD_GRACE_TIME:用于指定口令宽限期.

为了强制用户定期改变口令,二者必须同时设置.

CREATE PROFILE password_life_ime LIMIT

PASSWORD_LIFE_TIME 10

PASSWORD_GRACE_TIME 2;


ALTER USER devep PROFILE password_life_time;


口令历史

PASSWORD_REUSE_TIME:用于指定口令可重用时间.

PASSWORD_REUSE_MAX;用于指定在重用口令之前口令需要改变的次数.

需要主要,使用口令历史选项时,只能使用其中的一个选项.并将另一个选项设置为UNLIMITED.


CREATE PROFILE password_history LIMIT

PASSWORD_LIFE_TIME 10 PASSWORD_GRACE_TIME 2

PASSWORD_REUSE_TIME 10 PASSWORD_REUSE_MAX UNLIMITED;


口令复杂性校验.

口令复杂性校验是指使用PL/SQL函数确保用户口令的有效性,从而加强用户使用复杂口令.

1,使用系统口令校验函数VERIFY_FUNCTION

安装oracle数据库时,oracle提供了sql脚本UTLPWDMG.SQL,改脚本用于建立系统口令校验函数VERIFY_FUNCTION,改口令校验函数实现了以下口令规则.

口令不能少于4个字符

口令不能与用户名相同.

口令至少包含一个字符,一个数字和一个特殊字符($,_,#,!等)

需要主要,当建立系统口令校验函数VERIFY_FUNCTION时,必须以SYS用户运行SQL脚本utlpwdmg.sql.

SQL>@%oracle_home%rdbmsadminutlpwdmg.sql

建立系统口令校验函数VERIFY_FUNCTION,还会修改DEFAULT的其他口令管理选项.

建立了VERIFY_FUNCTION函数后,如果在修改用户口令时口令不能满足改函数的规则,将显示错误信息.


2,使用自定义口令校验函数.(略)

3,禁用口令校验

如果要禁用口令校验函数,可以将PASSWORD_VERIFY_FUNCTION选项设置为NULL.

ALTER PROFILE password_history LIMIT

PASSWORD_VERIFY_FUNCTION NULL;


ALTER USER devep IDENTIFIED BY devep;

使用PROFILE管理资源

使用PROFILE管理资源时,必须激活资源限制.

ALTER SYSTEM SET resource_limit=TRUE;

1,限制会话资源是指限制会话在连接期间所占用的总计资源.当超过会话资源限制时,oracle不好对SQL语句进行任何处理并返回错误信息.

CPU_PER_SESSION:用于指定每个会话可以占用的最大CPU时间.

LOGICAL_READS_PER_SESSON:用于指定会话的最大逻辑读取次数.

PRIVATE_SGA:用于指定会话在共享池中可以分配的最大总计私有空间.需要注意,该选项只使用与共享服务器模式.

COMPOSITE_LIMIT:用于指定会话的总计资源消耗(单位:服务单元).oracle会根据CPU_PER_SESSION,CONNECT_TIME,LOGICAL_READS_PER_SESSION以及PRIVATE_SGA的求权结果取得总计服务单元.

下面以限制帐户DEVEP会话占用CPU时间不超过50秒,逻辑读取次数不超过100次为例,说明使用PROFILE限制会话资源的方法.为了控制会话资源,首先应执行CREATE PROFILE命令建立PROFILE,然后使用ALTER USER 命令将PROFILE分配给用户DEVEP.

CREATE PROFILE session_limit LIMIT

CPU_PER_SESSION 5000 LOGICAL_READS_PER_SESSION 100;


ALTER USER devep PROFILE session_limit;


限制调用资源

CPU_PER_CALL:限制每次调用(解析,执行或提取数据)可占用的最大CPU时间(单位:百分之一秒)

LOGICAL_READS_PER_CALL:用于限制每次调用的最大逻辑I/O次数.


限制其他资源

SESSIONS_PER_USER:用于指定每个用户的最大并发会话个数.

CONNECT_TIME:用于指定会话的最大连接时间.

IDLE_TIME:用于指定会话的最大空闲时间.


修改和删除PROFILE

修改PROFILE是使用ALTER PROFILE命令完成的.

删除PROFILE是使用DROP PROFILE命令完成的.

DROP PROFILE call_limit;

如果PROFILE已经分配给某个用户,那么当删除该PROFILE时必须带有CASCADE选项.


显示PROFILE信息.

1,显示用户的PROFILE

通过查询数据字典视图dba_users,可以显示用户所使用的PROFILE

SELECT profile FROM dba_users WHERE username=’DEVEP’;

Username 用于标识数据库用户名,profile用于标识用户使用的PROFILE


2,显示PROFILE的口令和资源限制选项.

Dba_profiles,可以显示PROFILE的口令限制,资源限制信息.

SELECT resource_name,limit FROM dba_profiles

WHERE profile=’SESSION_LIMIT’ AND resource_type=’KERNEL’;

Resource_name用于标识PROFILE选项名,LIMIT用于标识PROFIEL选项值,profile 用于标识PROFILE名,resource_type用于标识PROFILE选项的类型(PASSWORD:口令选项,KERNEL:资源选项).

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/312079/viewspace-245241/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/312079/viewspace-245241/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值