解决 Oracle 监听外网 IP 及腾讯云防火墙配置
腾讯云注册的服务器,在服务器里使用nmap -Pn 127.0.0.1 -p 1521 ,显示是打开的,但在把IP地址改为外网的IP地址就显示为关闭,这个是什么原因,下面为外网IP,
使用127.0.0.1,那个状态由closed 变为open,变为正常,以下是处理办法。
这种情况的核心原因是 Oracle 监听器仅监听了本地回环地址(<127.0.0.1>),没有监听服务器的外网 IP 地址,导致外部(包括外网 IP 自身)无法通过外网网 IP 访问 1521 端口。具体分析如下:
1. 监听器的"监听地址"限制
Oracle 监听器(Listener)启动时会绑定特定的 IP 地址,默认可能只绑定 127.0.0.1(本地回环地址),这意味着:
-
只有通过
127.0.0.1:1521访问时,监听器才会响应(所以nmap 127.0.0.1 -p 1521显示open)。 -
当使用服务器的外网 IP(或内网 IP)访问
外网IP:1521时,由于监听器没有绑定该 IP,端口处于"无服务监听"状态,因此 nmap 扫描显示closed。
2. 验证监听器的监听地址
在服务器本地执行 lsnrctl status 命令,查看监听器的"监听地址"信息,例如:
Plain
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=127.0.0.1)(PORT=1521))) # 仅监听本地回环
如果 HOST 字段是 127.0.0.1,则确认监听器未绑定外网 IP。
3. 解决方法:让监听器监听外网 IP
需修改监听器配置文件(listener.ora),让其绑定服务器的外网 IP 或所有 IP(0.0.0.0):
步骤 1:找到 listener.ora 文件
-
路径通常为:
$ORACLE_HOME/network/admin/listener.ora(Linux/Unix)或%ORACLE_HOME%\network\admin\listener.ora(Windows)。 -
若找不到,可通过
lsnrctl status命令的输出查看配置文件路径。
步骤 2:修改监听器配置
打开 listener.ora,找到监听器的 ADDRESS 配置,将 HOST 改为服务器的外网 IP 或 0.0.0.0(表示监听所有可用 IP):
TOML
# 原配置(可能只监听127.0.0.1)
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
)
)
# 修改后(监听所有IP)
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 0.0.0.0)(PORT = 1521)) # HOST改为0.0.0.0
)
)
步骤 3:重启监听器
Bash
# 停止监听器
lsnrctl stop
# 启动监听器(使配置生效)
lsnrctl start
步骤 4:验证
再次执行 lsnrctl status,确认监听地址变为 0.0.0.0 或外网 IP,例如:
Plain
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=0.0.0.0)(PORT=1521))) # 监听所有IP
此时再用外网 IP 扫描 nmap -Pn 外网IP -p 1521,应该会显示 open。
额外注意:腾讯云防火墙规则
即使监听器配置正确,仍需确保腾讯云轻量云的 防火墙规则已允许 1521 端口的入站访问 (来源设为 0.0.0.0/0,协议 TCP),否则端口可能被云厂商防火墙拦截(显示 filtered 而非 closed,但需提前确认)。
通过以上步骤,即可解决"本地能访问、外网 IP 扫描显示关闭"的问题。
辅助说明:
nmap 命令,需要下载一下安装后才能正常使用。
如果提示 "找不到 nmap 命令",说明你的系统中没有安装 nmap 工具,需要先安装它。以下是不同系统的安装方法:
1. Windows 系统
- 下载安装包:访问 nmap 官网(https://nmap.org/download.html),选择适合 Windows 的版本(如
nmap-7.94-setup.exe)。 - 安装:双击安装包,按提示完成安装(建议勾选 "Add Nmap to the system PATH for all users",方便在命令行直接使用
nmap命令)。 - 验证:安装完成后,打开 CMD 或 PowerShell,输入
nmap --version,若显示版本信息则安装成功。
2. Linux 系统(以 Ubuntu/Debian 为例)
打开终端,执行以下命令:
bash
sudo apt update # 更新软件源
sudo apt install nmap # 安装nmap
验证:输入nmap --version,显示版本信息即成功。
3. macOS 系统
-
方法 1(使用 Homebrew):
先安装 Homebrew(若未安装,终端执行
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"),再安装 nmap:
bashbrew install nmap方法 2(直接下载安装包):从 nmap 官网下载 macOS 版本,按提示安装。
安装完成后,再执行nmap -Pn 目标IP -p 端口即可进行端口扫描。