滚雪球学Oracle[2.3讲]:Oracle Listener配置与管理
全文目录:
- 前言
- 一、Oracle Listener的基础概念
- 1.1 什么是Oracle Listener?
- Listener的作用:
- 1.2 Oracle Listener的配置文件
- 示例`listener.ora`配置文件:
- 1.3 启动与管理Listener
- 二、多Listener配置与负载分担
- 2.1 多Listener的应用场景
- 多Listener的优势:
- 2.2 多Listener的配置步骤
- 1. 修改`listener.ora`文件配置多个Listener
- 2. 启动多个Listener
- 2.3 负载均衡配置
- `tnsnames.ora`负载均衡示例:
- 三、Listener日志分析与性能优化
- 3.1 Listener日志的作用
- 常见日志内容:
- 3.2 常见日志分析技巧
- 1. 统计连接请求频率
- 2. 排查异常连接
- 3. 识别频繁连接的客户端
- 3.3 Listener性能优化策略
- 1. 设置连接超时时间
- 2. 配置空闲连接检测
- 3. 监控网络资源
- 四、远程数据库连接的配置与安全策略
- 4.1 远程数据库连接的配置
- 1. 修改Listener配置
- 2. 防火墙配置
- 4.2 远程连接的安全策略
- 1. 启用加密通信
- 2. IP白名单
- 3. 强认证机制
- 五、总结与下期预告
前言
在上一篇文章【Oracle数据库软件的安装详解】中,我们介绍了如何通过静默安装、响应文件自动化安装和多版本Oracle数据库共存的方式来高效部署Oracle数据库。对于企业级数据库环境,这些方法提升了安装和维护的效率。
本期内容将从数据库的安装阶段过渡到数据库与客户端通信的配置,重点讲解Oracle Listener的配置与管理。Oracle Listener是数据库的网络监听器,负责接受客户端连接请求并将其转发给相应的数据库实例。一个优化配置的Listener不仅能提高数据库的访问效率,还能保障远程访问的安全性。
本文将涵盖如何配置多个Listener以分担连接负载,如何通过日志分析提升Listener性能,并介绍远程数据库连接的安全策略,以确保数据库在网络环境中的安全性。最后,我们会为下期内容【数据库初始化配置】做出预告,帮助大家进一步优化数据库的运行环境。
一、Oracle Listener的基础概念
1.1 什么是Oracle Listener?
Oracle Listener是数据库实例与客户端之间的网络中介,负责监听来自客户端的连接请求,并将其转发给指定的数据库实例。Listener作为数据库的"守门人",确保客户端能够根据TNS配置文件连接到数据库实例。
Listener的作用:
- 监听客户端连接请求:Listener接收客户端发送的连接请求,包括应用程序或SQL*Plus工具的连接。
- 路由到数据库实例:Listener根据客户端提供的连接信息(通常是服务名称或SID),将请求转发到相应的数据库实例。
- 负载均衡与故障转移:在多节点环境中,Listener还可以执行连接的负载均衡或故障转移,确保系统的高可用性。
1.2 Oracle Listener的配置文件
Listener的配置文件位于Oracle安装目录的$ORACLE_HOME/network/admin
路径下,通常是listener.ora
文件。此文件定义了Listener的名称、监听的端口和协议,以及可连接的数据库实例。
示例listener.ora
配置文件:
LISTENER =(DESCRIPTION_LIST =(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))))SID_LIST_LISTENER =(SID_LIST =(SID_DESC =(GLOBAL_DBNAME = orcl)(ORACLE_HOME = /u01/app/oracle/product/19.0.0/dbhome_1)(SID_NAME = orcl)))
在这个示例中,Listener通过TCP协议监听主机192.168.1.100
的1521
端口,还监听了本地进程间通信(IPC)。SID_LIST
定义了Listener所支持的数据库实例(即orcl
实例)。
1.3 启动与管理Listener
通过Oracle提供的lsnrctl
工具,数据库管理员可以启动、停止和管理Listener。常见的管理命令如下:
-
启动Listener:
lsnrctl start
-
查看Listener状态:
lsnrctl status
-
停止Listener:
lsnrctl stop
这些命令允许管理员对Listener进行实时管理和监控,确保其正常工作并处理客户端的连接请求。
二、多Listener配置与负载分担
2.1 多Listener的应用场景
在高并发、多实例的数据库环境中,单个Listener可能会成为性能瓶颈。为了提高系统的吞吐量,可以在同一服务器上配置多个Listener,每个Listener负责不同的端口或实例,分担连接负载。同时,配置多个Listener还能为不同的业务系统提供更灵活的管理方式,确保每个应用程序连接到合适的Listener。
多Listener的优势:
- 负载分担:多个Listener可以分担大量连接请求,提升数据库的响应速度。
- 独立管理:不同Listener可以为不同的数据库实例或应用程序服务,避免彼此之间的干扰。
- 提高可靠性:当一个Listener发生故障时,其他Listener可以继续提供服务,确保数据库的高可用性。
2.2 多Listener的配置步骤
1. 修改listener.ora
文件配置多个Listener
在listener.ora
中,我们可以定义多个Listener,每个Listener监听不同的端口和IP地址。例如,以下配置定义了两个Listener,LISTENER1
监听端口1521,LISTENER2
监听端口1522。
LISTENER1 =(DESCRIPTION_LIST =(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))))LISTENER2 =(DESCRIPTION_LIST =(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1522))))SID_LIST_LISTENER1 =(SID_LIST =(SID_DESC =(GLOBAL_DBNAME = orcl1)(ORACLE_HOME = /u01/app/oracle/product/19.0.0/dbhome_1)(SID_NAME = orcl1)))SID_LIST_LISTENER2 =(SID_LIST =(SID_DESC =(GLOBAL_DBNAME = orcl2)(ORACLE_HOME = /u01/app/oracle/product/19.0.0/dbhome_1)(SID_NAME = orcl2)))
在此配置中,我们为不同的数据库实例(orcl1
和orcl2
)分别定义了独立的Listener,这两个Listener分别监听不同的端口号,确保连接负载得到有效分担。
2. 启动多个Listener
每个Listener需要独立启动。以下命令分别启动LISTENER1
和LISTENER2
:
lsnrctl start LISTENER1
lsnrctl start LISTENER2
启动后,可以通过以下命令查看每个Listener的状态:
lsnrctl status LISTENER1
lsnrctl status LISTENER2
2.3 负载均衡配置
Oracle的Listener还支持负载均衡,允许客户端的连接请求根据数据库实例的负载情况自动分配到合适的实例。通过在tnsnames.ora
文件中配置负载均衡,可以平衡数据库集群中的连接请求。
tnsnames.ora
负载均衡示例:
ORCL_LB =(DESCRIPTION =(ADDRESS_LIST =(LOAD_BALANCE = ON)(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.101)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = orcl)))
在这个配置中,客户端的连接请求会根据系统的负载情况,在两个主机(192.168.1.100
和192.168.1.101
)之间自动分配,实现了有效的负载均衡。
三、Listener日志分析与性能优化
3.1 Listener日志的作用
Oracle Listener会记录客户端的连接请求、状态信息以及异常情况,这些信息保存在Listener日志中,通常位于$ORACLE_HOME/network/log/listener.log
文件中。通过分析日志文件,数据库管理员可以发现系统的运行瓶颈、排查连接问题,并发现异常连接的来源。
常见日志内容:
- 连接请求:记录每个客户端的连接请求,包括请求时间、IP地址、使用的协议等。
- 连接状态:记录连接的成功或失败状态,以及失败的原因。
- 异常连接:记录由于网络超时、认证失败等原因导致的连接异常。
3.2 常见日志分析技巧
1. 统计连接请求频率
通过分析Listener日志中每分钟的连接请求数量,可以评估系统的负载,确定是否需要增加Listener以分担负载。
grep "establish" $ORACLE_HOME/network/log/listener.log | wc -l
2. 排查异常连接
通过查找日志中的错误代码,可以识别连接失败的具体原因。例如,以下命令查找TNS-12514
错误(表示监听器未识别服务名称):
grep "TNS-12514" $ORACLE_HOME/network/log/listener.log
3. 识别频繁连接的客户端
通过分析日志中客户端的IP地址,可以识别出哪个客户端频繁连接,从而帮助管理员进行性能优化。
awk '{print $NF}' $ORACLE_HOME/network/log/listener.log |sort | uniq -c | sort -nr
3.3 Listener性能优化策略
1. 设置连接超时时间
通过在sqlnet.ora
文件中配置SQLNET.INBOUND_CONNECT_TIMEOUT
参数,控制客户端连接的超时时间,确保在网络状况不佳时自动释放资源,避免系统资源被无效连接占用。
SQLNET.INBOUND_CONNECT_TIMEOUT = 60
2. 配置空闲连接检测
通过SQLNET.EXPIRE_TIME
参数,定期检测空闲连接并将其关闭,防止无效的连接长时间占用系统资源。
SQLNET.EXPIRE_TIME = 10
3. 监控网络资源
定期使用netstat
或其他监控工具检查Listener的网络连接状态,确保Listener没有遭遇网络瓶颈。如果系统的网络连接频繁超时或响应缓慢,可能需要增加更多的Listener或进行硬件扩展。
四、远程数据库连接的配置与安全策略
4.1 远程数据库连接的配置
在分布式系统或跨网络的环境中,客户端需要通过远程连接的方式访问Oracle数据库。为了支持远程连接,必须确保Listener正确配置并开放对应的端口。
1. 修改Listener配置
为Listener指定公网IP地址,并确保监听外部请求。例如:
LISTENER =(DESCRIPTION_LIST =(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = your_public_ip)(PORT = 1521))))
2. 防火墙配置
确保服务器的防火墙允许1521
端口(或自定义端口)开放,以便外部网络可以访问Listener。
4.2 远程连接的安全策略
由于远程连接暴露数据库在公网上,必须采取有效的安全策略来防止未经授权的访问。以下是常见的安全措施:
1. 启用加密通信
通过在sqlnet.ora
中启用加密,确保客户端与数据库之间的通信内容无法被第三方窃听。
SQLNET.ENCRYPTION_SERVER = REQUIRED
SQLNET.ENCRYPTION_TYPES_SERVER = (AES256)
2. IP白名单
使用防火墙或网络策略限制可以访问数据库的IP地址,只允许可信任的IP地址连接数据库,防止未经授权的访问。
3. 强认证机制
为数据库启用强认证机制,例如SSL或Kerberos,确保客户端在连接数据库时需要进行身份验证,以提高系统的安全性。
五、总结与下期预告
本期文章详细讲解了Oracle Listener的配置与管理。我们探讨了如何配置多个Listener实现负载均衡,通过日志分析提升Listener性能,以及如何配置远程数据库连接的安全策略。Listener作为数据库通信的重要组件,通过合理的配置可以大幅提升系统的访问效率和安全性。
在下一期内容中,我们将深入探讨【数据库初始化配置】,帮助大家了解在数据库安装完成后,如何进行参数优化和初始配置,以确保数据库实例的最佳性能和稳定性。
相关文章:

滚雪球学Oracle[2.3讲]:Oracle Listener配置与管理
全文目录: 前言一、Oracle Listener的基础概念1.1 什么是Oracle Listener?Listener的作用: 1.2 Oracle Listener的配置文件示例listener.ora配置文件: 1.3 启动与管理Listener 二、多Listener配置与负载分担2.1 多Listener的应用场…...

免费送源码:Javaspringboot++MySQL springboot 社区互助服务管理系统小程序 计算机毕业设计原创定制
摘 要 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受居民的喜爱,社区互助服务管理系统小程序被居民普遍使用,为…...

成都睿明智科技有限公司抖音电商新蓝海的领航者
在当今这个数字化浪潮汹涌的时代,电商行业正以惊人的速度迭代升级,而抖音电商作为新兴势力,更是凭借其庞大的用户基数、精准的算法推荐和高度互动的社区氛围,成为了众多商家竞相追逐的蓝海市场。在这片充满机遇与挑战的海洋中&…...

不可错过!CMU最新《生成式人工智能大模型》课程:从文本、图像到多模态大模型
1. 课程简介 从生成图像和文本到生成音乐和艺术,生成模型一直是人工智能的关键挑战之一。本课程将探讨推动生成模型和基础模型(Foundation Models)最近进展的机器学习和人工智能技术。学生将学习、开发并应用最先进的算法,使机器…...

重庆数字孪生工业互联网可视化技术,赋能新型工业化智能制造工厂
重庆作为西南地区的重要工业基地,正积极探索和实践数字孪生、工业互联网及可视化技术在智能制造领域的深度融合,致力于打造新型工业化智能制造工厂,为制造业的高质量发展注入强劲动力。 在重庆的智能制造工厂中,数字孪生技术被广…...

Qt QPushButton clicked信号浅析
前言 Qt 的 QPushButton clicked 信号原型: void clicked(bool checked false);通常,使用 Qt 的 QPushButton clicked 点击信号时,会以如下方式使用: connect(ui->pushButton, &QPushButton::clicked, this, [](){qDeb…...

Python时间戳转日期
在Python中,你可以使用datetime模块将时间戳转换为日期。时间戳通常是一个表示自1970年1月1日(UTC)以来的秒数的浮点数或整数。 以下是一个简单的示例,展示了如何将时间戳转换为日期和时间: import datetime# 示例时…...

对 LLM 工具使用进行统一
我们为 LLM 确立了一个跨模型的 统一工具调用 API。有了它,你就可以在不同的模型上使用相同的代码,在 [Mistral] 或 [Llama]) 等模型间自由切换,而无需或很少需要根据模型更改工具调用相关的代码。此外,我们还在 transformers 中新…...

webpack/vite的区别
Webpack和Vite都是前端开发中常用的构建工具,它们在多个方面存在显著的区别。以下是对这两个构建工具的详细比较: 一、基础概念与定位 Webpack Webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler)。它允许开发…...

【笔记】信度检验
一、信度 信度是指测量结果的一致性和稳定性。 1.一致性(Consistency) 一致性指的是测量工具内部各个部分或项目之间的协调一致程度。高一致性意味着测量工具的不同部分都在测量同一个概念或特质。 例子:智力测试 假设我们有一个包含100…...

使用Python实现无人机路径规划的灰狼优化算法
目录 使用 Python 实现无人机路径规划的灰狼优化算法引言1. 灰狼优化算法概述1.1 定义1.2 算法原理1.3 灰狼的狩猎策略1.4 算法步骤 2. Python 中的灰狼优化算法实现2.1 安装必要的库2.2 定义类2.2.1 灰狼类2.2.2 群体类2.2.3 路径规划类 2.3 示例程序 3. 灰狼优化算法的优缺点…...

理解递归和回溯
文章目录 什么是递归回溯 什么是递归 回溯 //使用递归回溯来给小球找路//说明//1. map 表示地图//2. i,j 表示从地图的哪个位置开始出发 (1,1)//3. 如果小球能到 map[6][5] 位置,则说明通路找到.//4. 约定: 当map[i][j] 为 0 表示该点没有走过 当为 1 表…...

知识图谱入门——3:工具分类与对比(知识建模工具:Protégé、 知识抽取工具:DeepDive、知识存储工具:Neo4j)
在知识图谱构建的过程中,针对不同的任务和需求,我们可以使用多种工具。为了帮助你快速选择合适的工具,本文将常用工具按类别进行分类介绍,并对比其优缺点,方便你在不同场景中做出最佳选择。 文章目录 1. 知识建模工具…...

使用指标进行量化交易时,有哪些需要注意的风险点呢
炒股自动化:申请官方API接口,散户也可以 python炒股自动化(0),申请券商API接口 python炒股自动化(1),量化交易接口区别 Python炒股自动化(2):获取…...

数据结构阶段测试2的一点小补充
数据结构阶段测试2的一点小补充 1.已知⼩根堆为8,15,10,21,34,16,12,删除关键字8之后需重建堆,最后的叶⼦ 节点为() A. 34 B. 21 C. 16 D. 12 解题思路 向下调整算法删除堆顶元素 💡 答案:C 删除堆顶元素的思路: …...

量化交易里面的挂单成交率大概是多少呢
炒股自动化:申请官方API接口,散户也可以 python炒股自动化(0),申请券商API接口 python炒股自动化(1),量化交易接口区别 Python炒股自动化(2):获取…...

【Android 14源码分析】Activity启动流程-3
忽然有一天,我想要做一件事:去代码中去验证那些曾经被“灌输”的理论。 – 服装…...

Javascript客户端时间与服务器时间
在Java代码中使用new Date(),获取的是本机时间; 但是在Javascript 中使用new Date(),获取的却是访问该页面的客户端时间。 这样,就可能会出现一个问题:我的电脑时间比正常时间要快,我访问一个页面&#x…...

系统架构设计师教程 第11章 11.4 边缘计算概述 笔记
11.4 边缘计算概述 ★★☆☆☆ 11.4.1 边缘计算概念 边缘计算将数据的处理、应用程序的运行甚至一些功能服务的实现,由 网络中心下放到网络边缘的节点上。在网络边缘侧的智能网关上就近采集并且处理数据,不需要上传原生数据。 11.4.2 边缘计算的定义 1…...

CSS全解析
文章目录 CSS全解析一、CSS是什么二、基本语法规范三、引入方式(一)内部样式表(二)行内样式表(三)外部样式 四、代码风格(一)样式格式(二)样式大小写…...

一款基于 Java 的可视化 HTTP API 接口快速开发框架,干掉 CRUD,效率爆炸(带私活源码)
平常我们经常需要编写 API,但其实常常只是一些简单的增删改查,写这些代码非常枯燥无趣。 今天给大家带来的是一款基于 Java 的可视化 HTTP API 接口快速开发框架,通过 UI 界面编写接口,无需定义 Controller、Service、Dao 等 Jav…...

CSS3渐变
一、线性渐变 通过background-image: linear-gradient(...)设置线性渐变 语法: linear-gradient(direction,color1,color2, . . ) direction:渐变方向,默认从上到下,可选值: 简单选取: ① to right&…...

Emissive CEO Fabien Barati谈《消失的法老》背后的故事:XR大空间体验的创新与未来
在最近的一次播客访谈中,虚拟现实之声(Voices of VR)的主持人Kent Bye与Emissive公司的联合创始人兼CEO Fabien Barati进行了深入交流。Emissive是全球顶级的VR大空间体验制作商之一,以其沉浸式探险项目如《永恒的巴黎圣母院》和《胡夫地平线》而闻名。以下是这次访谈的核心…...

mysql设置表的某一个字段每天定时清零
推荐学习文档 golang应用级os框架,欢迎stargolang应用级os框架使用案例,欢迎star案例:基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识,这里有免费的golang学习笔…...

实例分割、语义分割和 SAM(Segment Anything Model)
实例分割、语义分割和 SAM(Segment Anything Model) 都是图像处理中的重要技术,它们的目标是通过分割图像中的不同对象或区域来帮助识别和分析图像,但它们的工作方式和适用场景各有不同。 1. 语义分割(Semantic Segme…...

深度学习项目----用LSTM模型预测股价(包含LSTM网络简介,代码数据均可下载)
前言 前几天在看论文,打算复现,论文用到了LSTM,故这一篇文章是小编学LSTM模型的学习笔记;LSTM感觉很复杂,但是结合代码构建神经网络,又感觉还行;本次学习的案例数据来源于GitHub,在…...

《精通开关电源设计》笔记一
重点 效率 纹波 环路响应 尺寸,从静态到动态的研究方法,假设开关电源稳态运行,以电感为中心,根据半导体器件(mos管或二极管)分段分析电路的状态,工具有电路原理和能量守恒 影响效率的主要是开关损耗,所以…...

QLoRA代码实战
QLoRA原理参考: BiliBili:4bit量化与QLoRA模型训练 zhihu:QLoRA(Quantized LoRA)详解 下载llama3-8b模型 from modelscope import snapshot_download model_dir snapshot_download(LLM-Research/Meta-Llama-3-8B-In…...

pyqt QGraphicsView 以鼠标为中心进行缩放
注意几个关键点: 1. 初始化 class CustomGraphicsView(QGraphicsView):def __init__(self, parentNone):super(CustomGraphicsView, self).__init__(parent)self.scene QGraphicsScene()self.setScene(self.scene)self.setGeometry(0, 0, 1024, 600)# 以下初始化…...

FPGA-Vivado-IP核-逻辑分析仪(ILA)
ILA IP核 背景介绍 在用FPGA做工程项目时,当Verilog代码写好,我们需要对代码里面的一些关键信号进行上板验证查看。首先,我们可以把需要查看的这些关键信号引出来,接好线通过示波器进行实时监测,但这会用到大量的线材…...