欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > windows >内容正文

windows

oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数

发布时间:2025/3/19 windows 79 豆豆
生活随笔 收集整理的这篇文章主要介绍了 oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

本帖最后由 bjddd192 于 2013-12-14 07:26 编辑

CREATE OR REPLACE TRIGGER TRG_LOGON_AUDIT

-----------------------------------------------------------------

--说    明: 限制某个IP到数据库实例的连接数。如果超过限制会出错或报警

--建立时间: 2013-10-25 12:10:14

-----------------------------------------------------------------

AFTER LOGON ON DATABASE

DECLARE

V_SESSIONS                         NUMBER;

V_SESSIONS_LIMITED         NUMBER := 2;

V_IP_ADDRESS                         VARCHAR2(15);

BEGIN

dbms_application_info.set_client_info(sys_context('userenv','ip_address'));

SELECT COUNT(*)

INTO V_SESSIONS

FROM V$SESSION

WHERE CLIENT_INFO = Ora_client_ip_address;

IF (V_SESSIONS > V_SESSIONS_LIMITED) THEN

RAISE_APPLICATION_ERROR(-20001, 'IP:' || V_IP_ADDRESS || '已达最大连接数:'||V_SESSIONS);

END IF;

END TRG_LOGON_AUDIT;

/

我参考网上的例子写了一个系统触发器,去限制操作系统用户登录数据库,比如每个人只能连2个,但实际测试时发现用户还是可以连,只是触发器的报警在告警日志中可以查看到

D:\oracle\product\10.2.0\admin\orcl\bdump

Errors in file d:\oracle\product\10.2.0\admin\orcl\udump\orcl_ora_1564.trc:ORA-00604: 递归 SQL 级别 1 出现错误ORA-20003: IP:192.168.244.148已达最大连接数:4ORA-06512: 在 line 20

我想问是是如何让它不写告警日志,直接把错误返回客户端不让登录呢?初学没多久,请大侠指点下,谢谢。

以下这个只能限制到Oracle用户:

SQL>alter system set resource_limit=true;

系统已更改。

SQL>create profile res_limit limit sessions_per_user 50;

配置文件已创建

SQL>alter profile res_limit limit sessions_per_user 3;

配置文件已更改

SQL>alter user yanglei profile res_limit;

用户已更改。

总结

以上是生活随笔为你收集整理的oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。