当前位置: 首页 > news >正文

滚雪球学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的作用:
  1. 监听客户端连接请求:Listener接收客户端发送的连接请求,包括应用程序或SQL*Plus工具的连接。
  2. 路由到数据库实例:Listener根据客户端提供的连接信息(通常是服务名称或SID),将请求转发到相应的数据库实例。
  3. 负载均衡与故障转移:在多节点环境中,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.1001521端口,还监听了本地进程间通信(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)))

在此配置中,我们为不同的数据库实例(orcl1orcl2)分别定义了独立的Listener,这两个Listener分别监听不同的端口号,确保连接负载得到有效分担。

2. 启动多个Listener

每个Listener需要独立启动。以下命令分别启动LISTENER1LISTENER2

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.100192.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是什么二、基本语法规范三、引入方式(一)内部样式表(二)行内样式表(三)外部样式 四、代码风格(一)样式格式(二)样式大小写&#xf…...

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候,难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵,或者买了二手 iPhone 却被原来的 iCloud 账号锁住,这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

【机器视觉】单目测距——运动结构恢复

ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛&#xf…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练

前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序

一、开发环境准备 ​​工具安装​​: 下载安装DevEco Studio 4.0(支持HarmonyOS 5)配置HarmonyOS SDK 5.0确保Node.js版本≥14 ​​项目初始化​​: ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...

MySQL 8.0 OCP 英文题库解析(十三)

Oracle 为庆祝 MySQL 30 周年,截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始,将英文题库免费公布出来,并进行解析,帮助大家在一个月之内轻松通过OCP认证。 本期公布试题111~120 试题1…...

安卓基础(aar)

重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...

无人机侦测与反制技术的进展与应用

国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...

LLMs 系列实操科普(1)

写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...

【JavaSE】多线程基础学习笔记

多线程基础 -线程相关概念 程序(Program) 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序,比如我们使用QQ,就启动了一个进程,操作系统就会为该进程分配内存…...