共计 5503 个字符,预计需要花费 14 分钟才能阅读完成。
在创建 Oracle 数据库时,其中 SYS 登录 Oracle 数据库在 SQL*Plus 工具通过如下 SQL 解锁。
1、通过数据字典 dba_users,查看 Oracle 账户的锁定状态,如下:(v 其中,OPEN 表示账户为解锁状态;EXPIRED 表示账户为过期状态(需要设置口令才能解除此状态);LOCKED 表示账户为锁定状态。)
2、先通过查询有哪些账号被锁
select username,account_status from dba_users;
3、下面使用 ALTER USER 语句为 scott 账户解锁:
ALTER USER scott ACCOUNT UNLOCK;
再使用 ALTER USER 语句为 scott 账户修改密码口令,如下:
ALTER USER scott IDENTIFIED BY tiger;
通过数据字典 dba_users 查看现在 scott 账户的状态,如下:通过查询结果可以看出,scott 账户已经被成功解锁。在使用数据字典 dba_users 时,需要注意其字段的值是区分大小的
相关账号其它策略
一
–1.
– 系统参数配置 connect sys/password@db_link as sysdba
select * from dba_profiles where resource_name like ‘FAILED_LOGIN_ATTEMPTS%’;
–1 DEFAULT FAILED_LOGIN_ATTEMPTS PASSWORD 10
– 连续错误连接 10 次用户被锁定
–2.
– 查看被锁的用户
select LOCK_DATE,username from dba_users where username=’USERNAME’;
LOCK_DATE 为空说明没有锁定,非空为锁定。
—–
SELECT S.USERNAME,
DECODE(L.TYPE, ‘TM’, ‘TABLE LOCK’, ‘TX’, ‘ROW LOCK’, NULL) LOCK_LEVEL,
O.OWNER,
O.OBJECT_NAME,
O.OBJECT_TYPE,
S.SID,
S.SERIAL#,
S.TERMINAL,
S.MACHINE,
S.PROGRAM,
S.OSUSER
FROM V$SESSION S, V$LOCK L, DBA_OBJECTS O
WHERE S.SID = L.SID
AND O.OBJECT_ID = L.ID1
AND S.USERNAME IS NOT NULL;
–3.
– 解锁方法
ALTER USER USER_NAME ACCOUNT UNLOCK;
– 值的注意,在升级过程中,被锁的用户,有可能不值一个
– 重新升级
—– 设置系统的默认登录次数
alter profile DEFAULT limit FAILED_LOGIN_ATTEMPTS 10;
alter profile DEFAULT limit FAILED_LOGIN_ATTEMPTS UNLIMITED;
————
数据管理员为这个用户单独设置了登录次数则要查找这个用户对应的 profile,然后修改. 可以查看用户的创建语名找到对应的设置。
Oracle 系统中的 profile 可以用来对用户所能使用的数据库资源进行限制,使用 Create Profile 命令创建一个 Profile,用它来实现对数据库资源的限制使用,如果把该 profile 分配给用户,则该用户所能使用的数据库资源都在该 profile 的限制之内。
二、条件:
创建 profile 必须要有 CREATE PROFILE 的系统权限。
为用户指定资源限制,必须:
1.动态地使用 alter system 或使用初始化参数 resource_limit 使资源限制生效。该改变对密码资源无效,密码资源总是可用。
SQL> show parameter resource_limit
NAME TYPE VALUE
———————————— ———– ——————————
resource_limit boolean FALSE
SQL> alter system set resource_limit=true;
系统已更改。
SQL> show parameter resource_limit;
NAME TYPE VALUE
———————————— ———– ——————————
resource_limit boolean TRUE
SQL>
2.使用 create profile 创建一个定义对数据库资源进行限制的 profile。
3.使用 create user 或 alter user 命令把 profile 分配给用户。
三、语法:
CREATE PROFILE profile
LIMIT {resource_parameters | password_parameters} [resource_parameters | password_parameters]… ;
<resource_parameters>
{{SESSIONS_PER_USER | CPU_PER_SESSION | CPU_PER_CALL | CONNECT_TIME | IDLE_TIME | LOGICAL_READS_PER_SESSION | LOGICAL_READS_PER_CALL | COMPOSITE_LIMIT} {integer | UNLIMITED | DEFAULT}
| PRIVATE_SGA {integer [ K | M] | UNLIMITED | DEFAULT }}
< password_parameters >
{{FAILED_LOGIN_ATTEMPTS | PASSWORD_LIFE_TIME | PASSWORD_REUSE_TIME | PASSWORD_REUSE_MAX | PASSWORD_LOCK_TIME | PASSWORD_GRACE_TIME} {expr | UNLIMITED | DEFAULT}
| PASSWORD_VERIFY_FUNCTION {function | NULL | DEFAULT}}
四、语法解释:
profile:配置文件的名称。Oracle 数据库以以下方式强迫资源限制:
1.如果用户超过了 connect_time 或 idle_time 的会话资源限制,数据库就回滚当前事务,并结束会话。用户再次执行命令,数据库则返回一个错误,
2.如果用户试图执行超过其他的会话资源限制的操作,数据库放弃操作,回滚当前事务并立即返回错误。用户之后可以提交或回滚当前事务,必须结束会话。
提示:可以将一条分成多个段,如 1 小时 (1/24 天) 来限制时间,可以为用户指定资源限制,但是数据库只有在参数生效后才会执行限制。
Unlimited:分配该 profile 的用户对资源使用无限制,当使用密码参数时,unlimited 意味着没有对参数加限制。
Default:指定为 default 意味着忽略对 profile 中的一些资源限制,Default profile 初始定义对资源不限制,可以通过 alter profile 命令来改变。
Resource_parameter部分:
Session_per_user:指定限制用户的并发会话的数目。
Cpu_per_session:指定会话的 CPU 时间限制,单位为百分之一秒。
Cpu_per_call:指定一次调用(解析、执行和提取)的 CPU 时间限制,单位为百分之一秒。
Connect_time:指定会话的总的连接时间,以分钟为单位。
Idle_time:指定会话允许连续不活动的总的时间,以分钟为单位,超过该时间,会话将断开。但是长时间运行查询和其他操作的不受此限制。
Logical_reads_per_session:指定一个会话允许读的数据块的数目,包括从内存和磁盘读的所有数据块。
Logical_read_per_call:指定一次执行 SQL(解析、执行和提取)调用所允许读的数据块的最大数目。
Private_sga:指定一个会话可以在共享池(SGA)中所允许分配的最大空间,以字节为单位。(该限制只在使用共享服务器结构时才有效,会话在 SGA 中的私有空间包括私有的 SQL 和 PL/SQL,但不包括共享的 SQL 和 PL/SQL)。
Composite_limit:指定一个会话的总的资源消耗,以 service units 单位表示。Oracle 数据库以有利的方式计算 cpu_per_session,connect_time,logical_reads_per_session 和 private-sga 总的 service units
Password_parameter部分:
Failed_login_attempts:指定在帐户被锁定之前所允许尝试登陆的的最大次数。
Password_life_time:指定同一密码所允许使用的天数。如果同时指定了 password_grace_time 参数,如果在 grace period 内没有改变密码,则密码会失效,连接数据库被拒绝。如果没有设置 password_grace_time 参数,默认值 unlimited 将引 发一个数据库警告,但是允许用户继续连接。
Password_reuse_time 和 password_reuse_max:这两个参数必须互相关联设置,password_reuse_time 指定了密码不能重用前的天数,而 password_reuse_max 则指定了当前密码被重用之前密码改变的次数。两个参数都必须被设置为整数。
1.如果为这两个参数指定了整数,则用户不能重用密码直到密码被改变了 password_reuse_max 指定的次数以后在 password_reuse_time 指定的时间内。
如:password_reuse_time=30,password_reuse_max=10,用户可以在 30 天以后重用该密码,要求密码必须被改变超过 10 次。
2.如果指定了其中的一个为整数,而另一个为 unlimited,则用户永远不能重用一个密码。
3.如果指定了其中的一个为 default,Oracle 数据库使用定义在 profile 中的默认值,默认情况下,所有的参数在 profile 中都被设置为 unlimited,如果没有改变 profile 默认值,数据库对该值总是默认为 unlimited。
4.如果两个参数都设置为 unlimited,则数据库忽略他们。
Password_lock_time:指定登陆尝试失败次数到达后帐户的缩定时间,以天为单位。
Password_grace_time:指定宽限天数,数据库发出警告到登陆失效前的天数。如果数据库密码在这中间没有被修改,则过期会失效。
Password_verify_function:该字段允许将复杂的 PL/SQL 密码验证脚本做 为参 数传递到 create profile 语句。Oracle 数据库提供了一个默认的脚本,但是自己可以创建自己的验证规则或使用第三方软件验证。对 Function 名称,指定的是密码验证规则的名称,指定为 Null 则意味着不使用密码验证功能。如果为密码参数指定表达式,则该表达式可以是任意格 式,除了数据库标量子查询。
五、举例:
1.创建一个 profile:
create profile new_profile limit password_reuse_max 10 password_reuse_time 30;
2.设置 profile 资源限制:
create profile app_user limit sessions_per_user unlimited cpu_per_session unlimited cpu_per_call 3000 connect_time 45 logical_reads_per_session default logical_reads_per_call 1000 private_sga 15k composite_limit 5000000;
总的 resource cost 不超过五百万 service units。计算总的 resource cost 的公式由 alter resource cost 语句来指定。
3.设置密码限制 profile:
create profile app_users2 limit failed_login_attempts 5 password_life_time 60 password_reuse_time 60 password_reuse_max 5 password_verify_function verify_function password_lock_time 1/24 password_grace_time 10;
4.将配置文件分配给用户:
SQL> alter user dinya profile app_user;
用户已更改。
SQL> alter user dinya profile default;
用户已更改。
更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址:http://www.linuxidc.com/Linux/2018-01/150044.htm