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 / 问题 / 8340
Accepted
Mikeage
Mikeage
Asked: 2009-05-15 11:15:14 +0800 CST2009-05-15 11:15:14 +0800 CST 2009-05-15 11:15:14 +0800 CST

使用 Squid / iptables 的透明代理

  • 772

我试图通过将所有前往端口 80 的传出数据包重新路由到 squid 代理来强制一台 PC 使用远程透明 squid 代理,尽管我在使用确切的 iptables 命令行时遇到了一些困难。

http://tldp.org/HOWTO/TransparentProxy-6.html上的 mini-HOWTO为两个“极端”情况提供了一些很好的链接:一个三(或更多)机器设置,它有一个客户端、路由器和代理,和一个单一的机器设置,所有三个都在同一台机器上。

在我的设置中,我有一台机器(称为 foo),IP 为 192.168.1.100。通常,它通过 192.168.1.1 的路由器连接到 Internet,该路由器执行 NAT 并具有公共 IP。在这种情况下,foo 还通过 OpenVPN 隧道(foo 的隧道地址为 10.8.0.5/6)连接到运行 squid 的名为 bar(远程地址 10.8.0.1)的机器。我想使用 iptables 将所有从 foo 发往端口 80 的传出数据包路由到端口 3128 上 bar 的 squid 代理。

我一直无法弄清楚要使用哪个链和目标;我所有的尝试要么是非法的(-A OUTPUT 没有 -t nat 和 --to-destination),要么只是没有做任何好事(-A PREROUTING、OUTPUT、POSTROUTING 等的各种组合)。

编辑:我认为我得到的最接近的是:

iptables -t nat -A OUTPUT -p tcp --dport 80 -j DNAT --to 10.8.0.1:3128

现在,没有端口 80 的流量可以到达任何地方,但至少它正在得到处理。使用 -A PREROUTING 失败...可能是因为数据包来自本地而不是通过机器路由?

squid iptables
  • 3 3 个回答
  • 14150 Views

3 个回答

  • Voted
  1. Best Answer
    Zoredache
    2009-05-15T11:54:13+08:002009-05-15T11:54:13+08:00

    如果我对您的理解正确,您想要做的事情不会简单地通过配置 iptables 来处理。REDIR 目标只能用于定位在本地系统上运行的进程。我相信尝试使用 DNAT 目标将其转发到远程 squid 盒会删除远程 squid 盒正确处理请求所需的一些信息

    如果你允许我猜一下。我认为您正在尝试将默认网关保留为主机上的 192.168.1.1,然后通过 vpn 发送端口 80 流量,对吗?

    远程 squid 需要一些配置才能真正充当透明代理。如果您可以在 squid 主机上设置正确的 iptables 重定向,并且远程主机在网络路径中,那么可以使用一些高级路由来通过 vpn 转发所有端口 80 请求。

    PS如果我正确理解您的需求,请添加评论,我可以更新我的答案,提供有关如何设置路由的更多详细信息。

    • 3
  2. Christian
    2009-05-15T14:58:58+08:002009-05-15T14:58:58+08:00

    转到 foo 并执行此操作:telnet 10.8.0.1 3128

    它有效吗?在这种情况下,您的 vpn 可以正常工作!

    你能做一个

    GET / HTTP/1.1
    Host: www.heise.de
    

    它会显示一个页面吗?然后将 squid 配置为透明代理!

    在这种情况下,您链接中的简单规则应该有效:

    iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j DNAT --to 10.8.0.1:3128
    iptables -t nat -A POSTROUTING -o eth0 -s local-network -d 10.8.0.1 -j SNAT --to iptables-box
    

    (foo 是您正在处理的 iptables-box)

    这行得通吗?

    • 1
  3. hgevs
    2009-11-15T23:15:58+08:002009-11-15T23:15:58+08:00

    在这里你可以看到一篇关于 squid 和 iptables 的透明代理的简短文章 http://www.linuxconfig.net/2009/11/14/creating-transparent-proxy-with-squid-and-iptables.html

    • 0

相关问题

  • 对于小型家庭网络,运行 Squid 有什么意义?[关闭]

  • 使用 iptables 和 dhcpd 进行端口转发

  • Varnish 与其他反向代理

  • 如何配置外部 CentOS 服务器作为 HTTP 代理/中继?

  • 根据 Apache 日志数据自动修改 iptables 以阻止行为不良的客户端

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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