龙空技术网

oracle数据库访问控制配置(白名单)

葫芦儿的成长记录 29

前言:

而今朋友们对“oracle的tcp”大概比较珍视,大家都需要分析一些“oracle的tcp”的相关内容。那么小编同时在网上网罗了一些对于“oracle的tcp””的相关知识,希望小伙伴们能喜欢,兄弟们快快来了解一下吧!

最近有同事咨询不通过外面的防火墙配置,仅使用数据库能否实现对数据库的访问控制?答案是可以的,通过修改监听相关配置文件是可以实现对客户端地址的过滤。

单机环境

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 stoplsnrctl startlsnrctl status查看监听状态,可通过alter system register快速注册服务。

注意:TCP.INVITED_NODES中需要包括数据库自己的ip地址和主机名,否则监听会启动失败。

[oracle@ora12c admin]$ lsnrctl statusLSNRCTL for Linux: Version 12.2.0.1.0 - Production on 30-AUG-2023 09:24:21Copyright (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 sysdbaSQL*Plus: Release 11.2.0.4.0 Production on Wed Aug 30 08:59:59 2023Copyright (c) 1982, 2013, Oracle.  All rights reserved.ERROR:ORA-12547: TNS:lost contactEnter user-name: ERROR:ORA-01017: invalid username/password; logon deniedEnter user-name: ERROR:ORA-01017: invalid username/password; logon denied
集群环境配置
1、登陆GRID用户,进入以下目录cd /u01/app/19.0.0/grid/network/admin2、同单机模式一样配置sqlnet.ora,每个节点都要配置,需要把RAC的Public IP,Private IP,VIP,Scan IP 都加到 TCP.INVITED_NODES 列表;地址保持在一行。#注意dg环境中从库的地址也需要写入进去#如果一个节点配置的白名单另外一个节点没有配置则通过第二个节点仍然可以连接数据库。3、重启监听#NODE 1:#启动监听后检查监听没问题再重启其他节点;srvctl stop listener -n RAC1srvctl start listener -n RAC1# lsnrctl status  #NODE 2:srvctl stop listener -n RAC2srvctl 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、修改配置后需要重启监听才可生效。

标签: #oracle的tcp #oracle配置ip连接 #oracle替换回车换行 #oracle用户解锁 12560 #oracle bi tools