Nginx反向代理Oracle

把 Oracle 搬到指尖:Nginx 反向代理实战笔记

场景速写

医院内网与互联网物理隔离,我的笔记本只有一个网口:

• 插光纤 → 外网

• 连 Wi-Fi → 内网

于是日常变成:光纤插本机 → TeamViewer 连隔壁的跳板机 → 再连 Oracle。

有没有更优雅的姿势?
把跳板机上的 Oracle "映射" 出来,直接在本机连!


思路:Nginx 做 TCP 反向代理

Oracle 监听 1521 → 跳板机监听 1522 → 本机直连 跳板机 IP:1522

配置极简,但默认参数会"掉线",需要微调。


最终配置(已美化)

nginx 复制代码
worker_processes auto;

events {
    worker_connections 1024;
}

# ========== TCP 反向代理 ==========
stream {
    upstream oracle_backend {
        server 192.168.8.11:1521;
        keepalive 32;              # 连接池保活
    }

    server {
        listen 1522 reuseport;     # 多核并发
        proxy_pass oracle_backend;
        proxy_timeout 1h;          # 防止空闲断线
        proxy_connect_timeout 10s;
        proxy_socket_keepalive on; # TCP keepalive

        access_log /var/log/nginx/oracle_tcp.log proxy;
    }

    # 日志格式
    log_format proxy '$remote_addr:$remote_port -> $upstream_addr '
                     '[$time_local] $bytes_sent/$bytes_received '
                     '$session_time';
}

三步验证

  1. 语法检查

    bash 复制代码
    nginx -t && systemctl reload nginx
  2. 端口测试

    bash 复制代码
    telnet 跳板机IP 1522   # 出现 Connected 即 OK
  3. 长连接验证

    用 SQL Developer 连上后静置 30 min,未掉线即成功。


掉线根因 & 对策

表格

复制

现象 根因 对策
几分钟后断开 Nginx 默认 proxy_timeout 10m 改成 1h
防火墙踢掉空闲连接 网络设备超时 开启 TCP keepalive,或让网管放宽策略

效果对比

表格

复制

方式 延迟 掉线 操作路径
TeamViewer 偶发 本机 → 跳板机 → Oracle
Nginx 代理 本机 → Oracle

彩蛋:一条命令查看实时会话数

bash 复制代码
watch -n1 'ss -ant | grep :1522'

至此,再也不用"远程远程机"了。

祝各位工程师早日摆脱 TeamViewer 的束缚,愉快写 SQL!

相关推荐
不能放弃治疗3 小时前
单 Agent 实现模式
后端
IT_陈寒5 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
fliter5 小时前
最后一块拼图:用 bitvec 构造 IPv4 包,真正做出自己的 Ping
后端
fliter6 小时前
用 Rust 解析并生成 ICMP 包:checksum、nom 与 cookie-factory
后端
蝎子莱莱爱打怪6 小时前
XZLL-IM干货系列 03|消息 ID 设计:一个 UUID 搞不定的事,我用两个 ID 解决了
后端·面试·开源
fliter6 小时前
从 panic 到 Result:用 Rust 重新整理一个 ping 项目的错误处理
后端
森蓝情丶7 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
JensCS猿7 小时前
从 Spring Boot 回看 SSM 框架:手动挡与自动挡的驾驶哲学
后端
爱勇宝7 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员