ORACLE用户自动被锁解决方法

--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;

用户已更改。


from:http://www.oralife.cn/html/2007/198_oracle_profile_lv.html

--End--

<think>首先,用户的问题是关于如何解决Oracle数据库用户住的问题。用户提到了引用[1]、[2]、[3],这些引用提供了关于表级定和记录定的信息,但用户明确说“用户住”,所以我需要区分用户定与对象定。 在Oracle数据库中,“用户住”可能指的是用户账户被定(例如,由于多次登录失败导致密码定),或者是用户会话被阻塞(如事务)。用户引用的内容提到了表定和记录定,但用户的问题焦点是用户级别的定。 回顾引用: - 引用[1]:讨论表被的问题,解需要权限用户操作。 - 引用[2]:解释类型(排它和共享),以及记录被解决方法。 - 引用[3]:类似引用[1],查询被的对象。 用户的问题是:“我想查找解决Oracle数据库用户住问题的方法”。所以,我需要先确认什么是“用户住”。在Oracle中,常见的场景: - 账户定:用户的账户被定(例如,ALTER USER username ACCOUNT LOCK)。 - 会话阻塞:用户的会话被其他会话阻塞,导致事务定。 用户引用的内容偏向于对象定(如表或记录),但用户指定了“用户”,所以我应该优先考虑账户定。 系统级指令: - 所有行内数学表达式用 $...$(但在这个上下文中可能不相关)。 - 独立公式用 $$...$$ 并单独成段(可能不适用)。 - LaTeX语法正确(确保数学格式正确)。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识,例如 [^1]。 此外,用户说:“上述引用仅供参考,并不是用户真正的需求”,所以我不能直接复制引用内容,而应基于理解解决问题。 结构化回答: 1. **理解问题**:解释“用户住”的可能含义。 2. **解决方法**: - 如果是账户定(如密码错误导致),如何解用户。 - 如果是会话定或阻塞,如何检查和解决。 3. **参考引用**:既然用户提供了引用,我可以引用它们来解释相关概念,但要自然地整合。 4. **生成相关问题**:在末尾生成相关问题。 关键步骤: - **账户解**:使用ALTER USER命令解用户。 - 例如:ALTER USER username ACCOUNT UNLOCK; - **检查和解决会话定**:查询v$locked_object和dba_objects来找出定情况。 - 如引用[1]和[3]所示:select * from v$locked_object; 然后KILL SESSION。 - **预防措施**:如设置合理的密码策略。 回答结构: - 开头澄清问题。 - 步骤1:检查是否是账户定。 - 步骤2:如果是会话定,查询定信息。 - 步骤3:解操作。 - 结尾添加相关问题。 生成相关问题: - 例如: 1. 如何防止Oracle用户账户被定? 2. 如何监控Oracle数据库中的定情况? 3. Oracle类型的详细解释是什么? 确保语言中文。 </think>### 解决Oracle数据库用户住问题的方法Oracle数据库中,“用户住”可能涉及两种常见场景:用户的账户被定(例如,密码错误次数过多导致系统自动定),或用户的会话被阻塞(如事务冲突)。以下是基于Oracle数据库管理的标准方法,逐步解决用户定问题。我将结合您的引用内容进行解释,确保方法可靠且易于操作。 #### 1. **区分定类型** - **账户定**:指用户账号本身被定,无法登录数据库。这通常是由安全策略(如多次登录失败)触发的。 - 例如,如果一个用户尝试登录失败次数超过限制,系统会执行 `ALTER USER username ACCOUNT LOCK` 命令定账号[^2]。 - **会话定**:指用户的会话被其他会话阻塞,导致事务无法继续(如记录或表被)。这与引用[1]和[3]中提到的对象定相关,但会影响用户的操作[^1][^3]。 - Oracle区分类型:排它(X)和共享(S)。账户定涉及用户管理,而会话定涉及事务并发控制[^2]。 首先,确认定类型: - 尝试登录数据库:如果提示“账户被定”,则属于账户定。 - 如果登录成功但操作卡顿(如DML语句无法执行),则可能是会话定。 #### 2. **解决账户定问题** 如果用户账户被定,使用有DBA权限的用户(如SYS或SYSTEM)执行解操作。步骤如下: - **步骤1:查询定账户** 连接到数据库(使用SQL*Plus或SQL Developer),运行以下SQL查询: ```sql SELECT username, account_status FROM dba_users WHERE account_status LIKE '%LOCKED%'; ``` 这将列出所有被定的账户(例如,状态显示为"LOCKED"或"EXPIRED & LOCKED")。 - **步骤2:解账户** 使用ALTER USER命令解: ```sql ALTER USER 用户名 ACCOUNT UNLOCK; ``` 例如:`ALTER USER scott ACCOUNT UNLOCK;` 解后,用户即可正常登录。 - **预防措施**: - 设置合理的密码策略(如 `FAILED_LOGIN_ATTEMPTS`),避免频繁定。 - 定期检查用户状态:`SELECT username, lock_date FROM dba_users;` #### 3. **解决会话定问题** 如果用户会话被阻塞(例如,事务冲突导致记录或表被),需要找出并终止阻塞会话。这基于引用[1]和[3]的查询方法[^1][^3]。 - **步骤1:查询被对象和会话** 运行以下SQL(需要DBA权限): ```sql SELECT b.owner, b.object_name, a.session_id, a.locked_mode FROM v$locked_object a, dba_objects b WHERE b.object_id = a.object_id; ``` 这将显示被定的对象(如表或记录)、定模式(如X表示排它)、以及阻塞会话的ID[^3]。 - **步骤2:识别阻塞会话** 查看会话详细信息: ```sql SELECT sid, serial#, username, status FROM v$session WHERE sid IN (SELECT session_id FROM v$locked_object); ``` 注意 `locked_mode` 值:6 表示排它(X),3 表示共享(S)。共享允许读取但阻止修改,排它完全阻止访问[^2]。 - **步骤3:终止阻塞会话** 使用ALTER SYSTEM KILL SESSION命令: ```sql ALTER SYSTEM KILL SESSION 'sid,serial#'; ``` 例如:`ALTER SYSTEM KILL SESSION '123,4567';` 这将释放定,允许用户继续操作。 - **注意事项**: - 终止会话可能导致事务回滚,确保在业务低峰期操作。 - 监控定:定期运行 `SELECT count(*) FROM v$locked_object;` 检查定数量[^1]。 #### 4. **常见预防和优化建议** - **账户定**:调整用户配置文件(Profile),如 `ALTER PROFILE default LIMIT FAILED_LOGIN_ATTEMPTS 10;` 限制登录失败尝试次数。 - **会话定**:优化事务设计(如减少长事务)、使用NOWAIT选项避免阻塞。 - 参考Oracle官方文档或工具(如Enterprise Manager)进行实时监控。 如果您提供更多细节(如具体错误消息或场景),我可以进一步优化方案。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值