网站首页 > 技术文章 正文
最近有同事咨询不通过外面的防火墙配置,仅使用数据库能否实现对数据库的访问控制?答案是可以的,通过修改监听相关配置文件是可以实现对客户端地址的过滤。
单机环境
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、修改配置后需要重启监听才可生效。
猜你喜欢
- 2024-11-04 Dockerfile 命令详解 dockerfile常用命令
- 2024-11-04 运维日记|那些年你可能会踩的坑—xtts篇
- 2024-11-04 深入浅出!十三张图带你从源码了解SpringBoot启动流程!实战篇
- 2024-11-04 linux操作命令随笔 linux系统的操作命令
- 2024-11-04 Jenkins安装配置,项目发布、管理详解,史上最清晰,值得收藏!
- 2024-11-04 0034 使用table表格标签进行网页排版
- 2024-11-04 Java课程设计报告+源码-万年历的设计与实现
- 2024-11-04 Java 8之后的那些新特性(二):文本块 Text Blocks
- 2024-11-04 springboot快速入门 springboot超详细教程
- 2024-11-04 11——26Sqoop 11/16-24
你 发表评论:
欢迎- 620℃几个Oracle空值处理函数 oracle处理null值的函数
- 612℃Oracle分析函数之Lag和Lead()使用
- 601℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 597℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 593℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 585℃【数据统计分析】详解Oracle分组函数之CUBE
- 574℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 563℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)