AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1033844
Accepted
Xim
Xim
Asked: 2020-09-15 07:14:46 +0800 CST2020-09-15 07:14:46 +0800 CST 2020-09-15 07:14:46 +0800 CST

Azure Windows 虚拟机上的 Oracle 数据库的连接问题 (ORA-03135)

  • 772

我们在 Azure Windows VM 上运行 Oracle 19c 数据库。我们的配置如下:

  • Azure Windows 虚拟机
    • 标准 B4ms(4 vcpus,16 GiB 内存)
    • “空闲超时”为 30 分钟(允许的最大值)的公共 IP 地址。
    • 甲骨文数据库 19c

从 VM 运行时,不会断开“空闲 SQL 会话”,但从公共 IP 地址访问时,会在 30 分钟后断开“空闲 SQL 连接”。

ORA-03135: connection lost contact

我们希望我们的“空闲 SQL 连接”是持久的,这是我们迄今为止所尝试的:

  1. 将 sqlnet.ora 文件编辑如下(客户端和服务器):
SQLNET.EXPIRE_TIME = 1000000
SQLNET.INBOUND_CONNECT_TIMEOUT = 1000000
  1. 编辑 tnsnames.ora 文件如下(客户端和服务器):
(ENABLE=BROKEN)

目前我正在尝试实现 Oracle keep-alive 包,但我没有成功。

有什么方向或想法吗?谢谢

[更新]我找到了一个解决方案,这就是我为了修复它所做的:

  1. 将“sqlnet.ora”恢复正常(客户端和服务器)
  2. 在“tnsnames.ora”文件上配置(ENABLE=BROKEN)(仅在客户端上)
  3. 使用以下参数在 Regedit 上设置 TCP KeepAlive(仅在客户端)(https://docs.microsoft.com/en-us/sql/connect/jdbc/connecting-to-an-azure-sql-database?view =sql-server-ver15 )
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters]
"KeepAliveTime"=dword:00007530
"KeepAliveInterval"=dword:000003e8
"TcpMaxDataRetransmissions"=dword:00000010
  1. 重启客户端
firewall hyper-v oracle azure
  • 1 1 个回答
  • 1795 Views

1 个回答

  • Voted
  1. Best Answer
    ibre5041
    2020-09-15T08:06:46+08:002020-09-15T08:06:46+08:00

    您需要在客户端机器上更改一两个内核可调参数。使 TCP keepalive (ENABLE=BROKEN) 有用。默认情况下,Linux 内核在 2 小时后发送第一个 TCP keepalive 探测:

    Linux内核:

    # cat /proc/sys/net/ipv4/tcp_keepalive_time
    7200
    Delay before the 1st probe is sent - after 2 hours !!!
    
    # cat /proc/sys/net/ipv4/tcp_keepalive_intvl
    75
    Interval between probes.
    
    # cat /proc/sys/net/ipv4/tcp_keepalive_probes
    9
    The number of "lost" probes indicating that the connection is dead.
    

    当将 keepavlive 时间和 keepalive 间隔设置为 5 秒(仅用于测试。30 秒对于 prod 来说应该绰绰有余),那么您应该在 TCP 转储中看到类似这样的内容:

    [~]# tcpdump -pni ens224 -v "tcp port 1521 and ( tcp[tcpflags] & tcp-ack != 0 and ( (ip[2:2] - ((ip[0]&0xf)<<2) ) - ((tcp[12]&0xf0)>>2) ) == 0 )"
    tcpdump: listening on ens224, link-type EN10MB (Ethernet), capture size 262144 bytes
    14:56:49.994675 IP (tos 0x0, ttl 64, id 12096, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.200.37196 > 192.168.8.212.ncube-lm: Flags [.], cksum 0x9313 (incorrect -> 0x4b94), ack 2263270845, win 359, options [nop,nop,TS val 78140944 ecr 7133273], length 0
    14:56:49.994829 IP (tos 0x0, ttl 64, id 55327, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.212.ncube-lm > 192.168.8.200.37196: Flags [.], cksum 0xadcf (correct), ack 1, win 207, options [nop,nop,TS val 7138281 ecr 78110940], length 0
    14:56:55.002668 IP (tos 0x0, ttl 64, id 12097, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.200.37196 > 192.168.8.212.ncube-lm: Flags [.], cksum 0x9313 (incorrect -> 0x2474), ack 1, win 359, options [nop,nop,TS val 78145952 ecr 7138281], length 0
    14:56:55.002809 IP (tos 0x0, ttl 64, id 55328, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.212.ncube-lm > 192.168.8.200.37196: Flags [.], cksum 0x9a3f (correct), ack 1, win 207, options [nop,nop,TS val 7143289 ecr 78110940], length 0
    14:57:00.010680 IP (tos 0x0, ttl 64, id 12098, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.200.37196 > 192.168.8.212.ncube-lm: Flags [.], cksum 0x9313 (incorrect -> 0xfd53), ack 1, win 359, options [nop,nop,TS val 78150960 ecr 7143289], length 0
    14:57:00.011296 IP (tos 0x0, ttl 64, id 55329, offset 0, flags [DF], proto TCP (6), length 52)
        192.168.8.212.ncube-lm > 192.168.8.200.37196: Flags [.], cksum 0x86af (correct), ack 1, win 207, options [nop,nop,TS val 7148297 ecr 78110940], length 0
    
    6 packets captured
    6 packets received by filter
    0 packets dropped by kernel
    
    • 1

相关问题

  • 用 D-LINK DFL-CPG310 防火墙替换 Cisco Pix 防火墙

  • MSMQ 防火墙端口

  • IP-KVM(在我的例子中是 ADDER Ipeps):轻松防火墙穿越

  • 远程连接 sql server 不工作,但如果防火墙禁用它呢?

  • 服务器 2003 R2 上的 Cisco VPN 客户端

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve