网站首页 > 数据库 / 正文
最近有同事咨询不通过外面的防火墙配置,仅使用数据库能否实现对数据库的访问控制?答案是可以的,通过修改监听相关配置文件是可以实现对客户端地址的过滤。
单机环境
1、进入监听目录,修改sqlnet.ora文件
/u01/app/oracle/product/12.2.0/dbhome_1/network/admin
添加如下参数
[oracle@ora12c admin]$ cat sqlnet.ora
# sqlnet.ora Network Configuration File: /u01/app/oracle/product/12.2.0/dbhome_1/network/admin/sqlnet.ora
# Generated by Oracle configuration tools.
NAMES.DIRECTORY_PATH= (TNSNAMES, EZCONNECT)
TCP.VALIDNODE_CHECKING=yes
# allowlist
#允许访问数据库的地址如下,注意务必添加数据库本身的地址和主机名(监听的地址是哪个)否则监听启动失败
TCP.INVITED_NODES=(127.0.0.1,localhost,ora12c,数据库服务器地址,客户端1ip,客户端2ip)
地址需要在一行写入不要换行写入。
# blocklist
#禁止访问数据库的如下
#TCP.EXCLUDED_NODES=(10.10.10.10,ip2,ip3)
允许和禁止可以选择一个,白名单机制即如果配置了允许的那么不在列表中的自动为禁止。
如果两者同时存在,允许列表的优先级高于拒绝列表
2、重启监听
lsnrctl stop
lsnrctl start
lsnrctl status查看监听状态,可通过alter system register快速注册服务。
注意:TCP.INVITED_NODES中需要包括数据库自己的ip地址和主机名,否则监听会启动失败。
[oracle@ora12c admin]$ lsnrctl status
LSNRCTL for Linux: Version 12.2.0.1.0 - Production on 30-AUG-2023 09:24:21
Copyright (c) 1991, 2016, Oracle. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=ora12c)(PORT=1521)))
TNS-12547: TNS:lost contact
TNS-12560: TNS:protocol adapter error
TNS-00517: Lost contact
Linux Error: 104: Connection reset by peer
如上提示就表示,TCP.INVITED_NODES中没有把本地的地址或主机名写进去,导致监听启动失败
,添加相应ip修改完列表后,再次执行
$lsnrctl stop
$lsnrctl start
测试效果
当非法的客户端进行访问的时候,会直接出现ORA-12547的错误。
[oracle@ ~]$ sqlplus sys/oracle@xxxxxxx:1521/oradb as sysdba
SQL*Plus: Release 11.2.0.4.0 Production on Wed Aug 30 08:59:59 2023
Copyright (c) 1982, 2013, Oracle. All rights reserved.
ERROR:
ORA-12547: TNS:lost contact
Enter user-name:
ERROR:
ORA-01017: invalid username/password; logon denied
Enter user-name:
ERROR:
ORA-01017: invalid username/password; logon denied
集群环境配置
1、登陆GRID用户,进入以下目录
cd /u01/app/19.0.0/grid/network/admin
2、同单机模式一样配置sqlnet.ora,每个节点都要配置,
需要把RAC的Public IP,Private IP,VIP,Scan IP 都加到 TCP.INVITED_NODES 列表;
地址保持在一行。
#注意dg环境中从库的地址也需要写入进去
#如果一个节点配置的白名单另外一个节点没有配置则通过第二个节点仍然可以连接数据库。
3、重启监听
#NODE 1:
#启动监听后检查监听没问题再重启其他节点;
srvctl stop listener -n RAC1
srvctl start listener -n RAC1
# lsnrctl status
#NODE 2:
srvctl stop listener -n RAC2
srvctl start listener -n RAC2
# lsnrctl status
其他注意
注意,如果“邀请节点”列表中没有数据库服务器的主机名或IP地址,则PMON将不会向侦听器注册。
需要在TNS侦听器使用的sqlnet.ora文件中设置参数,因为这是通过侦听器的访问限制
对值的任何更改都需要停止并重新启动TNS侦听器。
所有主机名必须是可解析的,否则TNS侦听器将无法启动
邀请列表优先于排除列表
所有条目必须在一行上(最好通过Net Manager添加条目)
SCAN和TCP.INVITED_NODES将要求将SCAN VIP和Node Vips添加到GRID Infrastructure SQLNET.ORA文件中。
注1: 由于是侦听器检查INVITED或EXCLUDED节点,因此应将RAC环境中的sqlnet.ora文件更改更改为GRID_HOME / network / admin / sqlnet.ora
注2: 所有侦听器(SCAN和VIP)必须对INVITED或EXCLUDED节点列表进行任何更改后,将完全重新启动(不重新加载),
tcp.invited_nodes 需要满足如下条件才可成功启动监听:
1、需要设置参数 TCP.VALIDNODE_CHECKING 为YES才能激活该特性;
2、tcp.invited_nodes的值中一定要包括本机地址(127.0.0.1 / 192.0.20.51)或localhost,因为监听需要通过本机ip去访问监听,一旦禁止lsnrct将不能启动或停止监听;
3、此方式只适合tcp/ip协议;
4、此方式是通过监听限制白名单的;
5、针对的是ip地址而不是其他(如用户名等);
6、修改配置后需要重启监听才可生效。
Tags:oracle 记录
猜你喜欢
- 2024-11-26 SpringBoot整合oceanbase,实现oracle无缝切换到oceanbase
- 2024-11-26 oracle固定执行计划-SPM(二)
- 2024-11-26 oracle影响数据库打开速度的因素-前滚和回滚
- 2024-11-26 Oracle 19c Concepts(2):
- 2024-11-26 Oracle安全补丁大爆发:一月发布248个破纪录
- 2024-11-26 Oracle EMCC13C学习-纳管主机(3)
- 2024-11-26 两种方式中断会话连接oracle
- 2024-11-26 Oracle AWR解析-Report Summary
- 2024-11-26 Oracle EMCC13C学习-纳管RAC集群数据库
- 2024-11-26 oracle固定执行计划-SPM实验(一)