首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何通过lsnrctl进行安全设置

如何通过lsnrctl进行安全设置

热心网友
44
转载
2026-04-29

通过 lsnrctl 的监听器安全设置指南

如何通过lsnrctl进行安全设置

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

数据库监听器是连接客户端与数据库实例的关键枢纽,其安全性直接关系到整个数据库的安危。今天,我们就来深入聊聊,如何通过 lsnrctl 这个核心工具,为你的监听器构建一套从基础到进阶的立体防护体系。

一 基础防护:设置监听口令与操作限制

安全加固的第一步,往往是从最基础的访问控制开始。对于监听器而言,首要任务就是为管理操作加上一把“锁”。

  • 进入监听器控制台并设置/修改密码:在命令行执行 lsnrctl 进入交互界面后,核心操作流程是:使用 change_password 设置一个强口令,随后用 set password 输入口令完成验证,最后执行 sa ve_config 将变更持久化到配置文件。这里有个关键细节需要注意:口令校验主要对 stopsa ve_config 这类管理操作生效,而对 start 命令不生效——这其实是个巧妙的设计,目的是防止恶意用户通过停止正在运行的监听器来制造拒绝服务攻击。设置完成后,你会在 listener.ora 文件中看到自动生成的类似 PASSWORDS_LISTENER = <密文> 的条目。具体操作示例如下:

    LSNRCTL> change_password
    Old password:
    New password:
    Reenter new password:
    LSNRCTL> set password
    Password:
    LSNRCTL> sa ve_config
  • 启用管理限制,禁止在线修改:光有口令还不够,我们还需要限制运行时的配置变更能力。在 listener.ora 文件的监听段末尾,添加一行 ADMIN_RESTRICTIONS_ = on(例如 ADMIN_RESTRICTIONS_LISTENER = on)。这个开关一旦开启,运行中的监听器就会拒绝通过 lsnrctl 执行 set 等修改类命令。任何配置变更都必须先停止监听,并将此参数改为 off 后才能进行。这相当于给配置加了一道“物理锁”,能显著降低被远程实时篡改的风险。配置示例如下:

    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = your_host)(PORT = 1521))
        )
      )
    ADMIN_RESTRICTIONS_LISTENER = on
  • 远程操作风险控制:在没有设置口令的情况下,攻击者完全可以在远端直接执行 lsnrctl stop 来关闭监听,从而造成服务中断。而完成了上述口令与 ADMIN_RESTRICTIONS 的双重设置后,任何来自远程的管理命令执行都需要提供正确的口令,否则操作一律失败。这就从根本上堵住了未授权管理的大门。

二 传输与网络层加固

基础访问控制搞定后,下一步就该聚焦网络边界了。监听器暴露在网络上,就好比房子的门窗,必须确保只对可信的人开放。

  • 限制监听地址与端口:在 listener.ora 配置中,务必仅绑定必要的网络接口。比如,指定具体的主机名或内网IP地址,坚决避免使用 0.0.0.0 这种“通配”地址将监听器暴露到公网。同时,端口也尽量使用非默认端口,如果必须用1521,则更需配合其他安全措施。一个正确的绑定示例如下:

    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.20)(PORT = 1521))
        )
      )
  • 主机防火墙精细放行:操作系统层面的防火墙是另一道重要防线。策略应该精细到只允许受信任的特定网段访问监听端口。以 Ubuntu 的 UFW 为例,可以这样设置仅允许 192.168.1.0/24 网段访问1521端口:

    sudo ufw allow from 192.168.1.0/24 to any port 1521

    在 Debian/Ubuntu 这类系统上,将本地防火墙规则与监听器的绑定地址策略结合起来,可以最大程度地缩小网络暴露面。

  • 加密传输(可选增强):对于安全性要求极高的环境,可以考虑为监听器启用 SSL/TLS 加密。这需要在 listener.ora 中进行配置,示例如下:

    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCPS)(HOST = your_host)(PORT = 1521))
        )
      )
    SSL_CLIENT_AUTHENTICATION = FALSE
    SSL_VERSION = 1.2

    同时,别忘了在客户端的 sqlnet.ora 文件中设置相应的加密和校验策略(例如 SQLNET.ENCRYPTION_SERVER = REQUIRED)。配置完成后,重启监听器使所有设置生效。

三 命令与文件权限最小化

纵深防御的理念告诉我们,即使外层被突破,内层也要能守住。因此,对监听器相关的命令和文件实施最小权限原则至关重要。

  • 以最小权限运行:监听器进程本身应该以 oracle 这类专用的低权限系统账户运行。尽量避免直接使用 root 账户启动监听,这样可以有效限制一旦进程被入侵后可能造成的提权影响范围。

  • 限制 lsnrctl 可执行文件访问lsnrctl 这个管理工具本身也需要保护。应确保只有受控的用户或组才有权执行它。可以通过以下命令设置(请根据实际安装路径调整):

    sudo chown root:root /u01/app/oracle/product/19.0.0/dbhome_1/bin/lsnrctl
    sudo chmod 700 /u01/app/oracle/product/19.0.0/dbhome_1/bin/lsnrctl
  • 精细化 sudo 授权(可选):如果某些管理操作确实需要提权,可以通过系统的 /etc/sudoers 文件(务必使用 visudo 命令编辑)进行精细化授权。例如,仅授权特定用户无需密码即可执行 lsnrctl,避免授予无限制的 root 权限:

    oracle ALL=(ALL) NOPASSWD: /u01/app/oracle/product/19.0.0/dbhome_1/bin/lsnrctl
  • 启用系统安全模块:在支持 SELinux 或 AppArmor 的 Linux 发行版上,可以充分利用这些强制访问控制机制。为 lsnrctl 及整个 Oracle 目录制定最小权限的访问策略,能够进一步约束进程的行为,将潜在的攻击面压缩到极致。

四 审计监控与维护

安全配置并非一劳永逸,持续的监控、审计和更新才是长治久安之道。

  • 启用详细日志与跟踪:为了便于事后审计和故障排查,建议在 listener.ora 中提升日志级别并指定跟踪文件。例如:

    LOG_LEVEL_LISTENER = 16
    TRACE_FILE_LISTENER = listener_trace.log

    养成定期检查 $ORACLE_HOME/network/log 目录下日志和跟踪文件的习惯,重点关注其中的异常连接尝试、频繁的监听器启停事件以及非授权的配置变更记录。

  • 变更留痕与备份:任何对 listener.ora 配置文件的修改,都必须遵循“先备份,后变更”的流程。变更后,立即使用 lsnrctl status 命令并结合日志来确认配置已正确生效。此外,定期为 Oracle 数据库及监听器软件安装最新的安全补丁,是修复已知漏洞、抵御公开威胁的最有效手段。

五 应急与常见问题

最后,我们来看看两个在实际运维中可能遇到的典型问题及其处理方法。

  • 忘记监听口令的处理:如果不慎遗忘了监听器口令,处理方法是直接编辑 listener.ora 文件,找到并删除(或注释掉)包含 PASSWORDS_ 的那一行,然后重启监听器,口令保护即被清除。之后,再按照第一部分描述的步骤重新设置一个强口令并启用 ADMIN_RESTRICTIONS。当然,在执行此操作前,务必评估对生产环境的影响,并安排在合适的维护窗口进行。

  • 远程 stop 被拒绝:如果在远程执行 lsnrctl stop 时被拒绝,这恰恰说明之前设置的口令保护正在正常发挥作用。正确的操作流程是,先在 lsnrctl 交互环境中执行 set password 输入正确口令,完成身份验证后,再执行 stopsa ve_config 等管理命令。

说到底,监听器的安全是一个系统工程,它贯穿于配置、网络、权限和运维的每一个环节。遵循上述步骤,层层设防,才能为你的数据库守住这扇至关重要的“前门”。

来源:https://www.yisu.com/ask/33706434.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

ulimit命令如何控制I/O操作数
编程语言
ulimit命令如何控制I/O操作数

ulimit命令如何控制I O操作数? 许多系统管理员和开发者在进行服务器调优或程序性能管理时,会考虑使用 ulimit 命令来设定资源限制。该命令功能强大,能够有效管理 shell 进程及其子进程的文件描述符数量、最大进程数等关键系统资源。然而,这里存在一个普遍的认知偏差:ulimit 命令本身并

热心网友
04.29
ulimit如何调整网络带宽限制
编程语言
ulimit如何调整网络带宽限制

Linux服务器网络带宽限制与调整方法详解 许多服务器管理员在优化系统性能时,会首先想到使用 ulimit 命令来调整资源限制。确实,ulimit 是管理用户进程资源(如文件描述符数量、CPU时间、进程数)的核心工具。但如果您的主要目标是控制网络传输速度或进行带宽限速,那么需要明确一点:ulimit

热心网友
04.29
cmatrix命令的原理是什么
编程语言
cmatrix命令的原理是什么

cmatrix命令的原理是什么 你是否曾在终端中见过酷似电影《黑客帝国》的绿色字符雨特效?这种极具科技感的视觉呈现,正是由cmatrix命令行工具实现的。其核心原理并不复杂,主要依赖于一套历史悠久且功能强大的“ANSI转义序列”终端控制协议。简而言之,该工具通过向终端发送一系列特定的控制代码,精准操

热心网友
04.29
C++在Linux中如何进行图形界面编程
编程语言
C++在Linux中如何进行图形界面编程

在Linux中进行C++图形界面编程 你是否正在寻找在Linux环境下使用C++开发图形用户界面的解决方案?好消息是,可供选择的工具库非常多样。无论是功能完备的重量级框架,还是追求极致性能的轻量级方案,都能满足不同项目的开发需求。本文将为您详细介绍几款主流的C++ GUI开发库,并解析其核心特点。

热心网友
04.29
C++在Linux下如何进行网络协议编程
编程语言
C++在Linux下如何进行网络协议编程

Linux C++网络编程实战指南:从零构建TCP通信程序 你是否正在寻找在Linux环境下使用C++实现网络通信的完整教程?本文将为你详细解析如何利用套接字(Socket)API构建一个完整的TCP服务器与客户端通信程序。通过这个经典的C++网络编程示例,你将清晰掌握连接建立、数据收发、错误处理等

热心网友
04.29

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

MongoDB 3.6旧版本如何平滑迁移GridFS数据_使用mongodump与mongorestore
数据库
MongoDB 3.6旧版本如何平滑迁移GridFS数据_使用mongodump与mongorestore

MongoDB 3 6旧版本如何平滑迁移GridFS数据 在MongoDB 3 6版本中,使用mongodump进行数据备份时,默认会忽略GridFS存储所使用的fs files和fs chunks集合,因为它们被系统视为内部命名空间。为确保GridFS文件数据的完整迁移,必须显式指定导出这两个集合

热心网友
04.29
Redis如何批量删除特定前缀的Key_使用Lua脚本避免阻塞主线程
数据库
Redis如何批量删除特定前缀的Key_使用Lua脚本避免阻塞主线程

生产环境禁用 KEYS+DEL,因其会阻塞 Redis 主线程;应使用带游标和分批的 SCAN+DEL Lua 脚本或 Ja va 中通过 RedisConnection 执行 SCAN 迭代删除,避免连接泄漏。 直接使用 KEYS 配合 DEL 来批量删除特定前缀的 Key,听起来很直接,对吧?但

热心网友
04.29
Redis为什么会出现内存泄漏的假象_排查Lua脚本中未设置过期的临时变量
数据库
Redis为什么会出现内存泄漏的假象_排查Lua脚本中未设置过期的临时变量

Redis为什么会出现内存泄漏的假象?排查Lua脚本中未设置过期的临时变量 Redis内存持续上涨可能源于Lua脚本中未设置过期时间的临时键,如set、hset、zadd写入后遗漏expire,导致“孤儿键”累积;需用redis-cli --scan结合object freq和ttl定位,并按业务语

热心网友
04.29
如何用SQL实现多级分组的排名统计_窗口函数扩展
数据库
如何用SQL实现多级分组的排名统计_窗口函数扩展

多级分组排名应选rank()或dense_rank()而非row_number():rank()跳过重复名次,dense_rank()连续编号;必须配合PARTITION BY和ORDER BY,且WHERE筛选需用子查询避免破坏分组。 rank() 和 dense_rank() 在多级分组中行为差

热心网友
04.29
Redis如何实现基于发布订阅的配置热更新_发布配置变更通知触发服务重载
数据库
Redis如何实现基于发布订阅的配置热更新_发布配置变更通知触发服务重载

Redis如何实现基于发布订阅的配置热更新 Redis Pub Sub 能否可靠用于配置热更新? 直接拿来用?恐怕不行。Redis 的 PUBLISH SUBSCRIBE 本质上是一种“即发即弃”的模型:消息不持久、没有确认机制、订阅者离线期间的消息会彻底丢失。想象一下,你的服务因为重启或者网络短暂

热心网友
04.29