oracle 19c 在 windows 上默认不启用 ipv6 支持,即使系统已配置双栈,数据库监听器和集群资源仍只绑定 ipv4 —— 这是绝大多数“ipv6 不生效”问题的根源。
为什么 Oracle 19c Windows 版监听器不自动监听 IPv6
Oracle 安装程序在 Windows 上会读取 hosts 文件和网卡状态,但默认跳过 IPv6 地址解析逻辑;listener.ora 和 tnsnames.ora 中若未显式声明 IPv6 地址格式(如 [::1] 或 [2001:db8::1]),监听器启动后只会注册 IPv4 协议栈。这不是 bug,而是 Oracle 对 Windows 网络栈的保守适配策略。
Windows 的 getaddrinfo() 行为与 Linux 不同,Oracle 依赖该函数做地址解析,而默认调用未设 AI_ADDRCONFIG 标志,导致 IPv6 地址被忽略srvctl 管理的 RAC 资源(如 SCAN、VIP)在 Windows 下不支持 IPv6 配置 —— 这是硬限制,非配置问题单实例场景下,仅能手动修改监听器配置实现双栈,且必须确保 Windows 网卡已启用 IPv6 并分配有效地址(不能仅靠 ::1)
手动配置 listener.ora 启用双栈监听
核心是让监听器同时 bind 到 IPv4 和 IPv6 地址,且使用标准端口(如 1521),避免协议分裂。
编辑 %ORACLE_HOME%\network\admin\listener.ora,将默认的 (ADDRESS = (PROTOCOL = TCP)(HOST = myhost)(PORT = 1521)) 替换为两个独立 ADDRESS 条目:LISTENER = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 0.0.0.0)(PORT = 1521)) (ADDRESS = (PROTOCOL = TCP)(HOST = [::])(PORT = 1521)) ) )0.0.0.0 表示监听所有 IPv4 接口,[::] 表示监听所有 IPv6 接口(注意方括号不可省略)必须重启监听器:lsnrctl stop && lsnrctl start;执行 lsnrctl status 应看到两行 “Listening Endpoints Summary”,分别含 1521 和 1521,协议均为 TCP,Host 字段显示 0.0.0.0 和 [::]若出现 TNS-01150: The address of the specified listener name is incorrect,检查 HOST 值是否用了未分配的 IPv6 地址(如 [2001:db8::2] 但网卡没配)
tnsnames.ora 中客户端连接如何指定双栈目标
客户端(如 SQL*Plus、JDBC)需明确告知 Oracle 使用哪个协议栈连接,否则可能 fallback 到 IPv4 或失败。
不要用主机名直接解析(HOST = myhost),因 Windows hosts 文件不支持 IPv6 别名,DNS 解析行为不可控对 IPv4 连接,保持原样:(HOST = 192.168.1.100)对 IPv6 连接,必须用方括号包裹完整地址:(HOST = [2001:db8:1::100]) —— 缺少括号会导致 ORA-12154若希望应用自动选择可用栈,可配置两个别名:ORCL_IPV4 = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521)) (CONNECT_DATA = (SERVICE_NAME = ORCL)))ORCL_IPV6 = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = [2001:db8:1::100])(PORT = 1521)) (CONNECT_DATA = (SERVICE_NAME = ORCL)))JDBC URL 示例:jdbc:oracle:thin:@[2001:db8:1::100]:1521/ORCL(同样不可省略括号)
Windows 系统层必须验证的三项配置
Oracle 只是上层应用,底层网络不通,任何配置都无效。
确认网卡已启用 IPv6:运行 ipconfig /all,输出中必须有 IPv6 Address 行,且不是 fe80::(链路本地)—— 至少需一个全局单播地址(如 2001:db8::100)或唯一本地地址(fd00::/8)检查防火墙:Windows Defender 防火墙默认阻止 IPv6 入站;需新增入站规则,协议选 Any 或 TCP,端口 1521,作用域选 Local subnet 或 Any IP address,并勾选 Allow the connection for private networks禁用 IPv6 自动配置干扰:注册表路径 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip6\Parameters,新建 DWORD 值 DisabledComponents,设为 0x00(启用全部)或 0x20(禁用隧道但保留原生 IPv6);设为 0xff 会彻底禁用 IPv6,导致配置失效
最关键的遗漏点是:很多人配完 listener.ora 就以为完成了,却没意识到 Windows 防火墙对 IPv6 是独立控制的,且默认拒绝所有入站 —— 这比监听器配置错误更常导致“连得上 IPv4,连不上 IPv6”的假象。

评论(0)