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 / 问题 / 585264
Accepted
GetFree
GetFree
Asked: 2014-03-29 17:13:12 +0800 CST2014-03-29 17:13:12 +0800 CST 2014-03-29 17:13:12 +0800 CST

将传出的 SOCKS 服务器流量绑定到特定 IP

  • 772

在办公室,我们可以通过 SOCKS 服务器访问网络,该服务器使用以下命令启动:
ssh localhost -f -N -D *:8888.

此服务器有 2 个 IP(但只有一个网卡):
eth0 xx.yy.zz.1
eth0:1 xx.yy.zz.2

所以浏览器被配置为使用 socks 代理xx.yy.zz.2:8888

当我检查网站看到的 IP 是什么时,它给了我xx.yy.zz.1(服务器的默认 IP)。
但我希望它是另一个(xx.yy.zz.2)。

如何将传出连接绑定到第二个 IP?

编辑:
这可以用 iptables 解决吗?
可能有一种方法可以判断哪些数据包来自给定的 SSH 隧道,然后修改它们的目标 IP?

EDIT2:
我想到的另一个想法是,是否有某种包装命令强制另一个命令绑定到给定的 IP?

linux
  • 1 1 个回答
  • 5470 Views

1 个回答

  • Voted
  1. Best Answer
    BatchyX
    2014-04-03T11:57:45+08:002014-04-03T11:57:45+08:00

    SSH 协议无法让客户端在进行动态端口转发时告诉服务器绑定到某个地址,所以不,您不能告诉您的 SSH 客户端这样做。您也不能告诉 OpenSSH 服务器这样做。它将盲目地用于getaddrinfo连接到您的远程主机。

    修复的唯一方法是配置您的服务器,使其执行您想要的操作。不幸的是,您无法从路由或iptablesOpenSSH 服务器建立的连接中分辨出来。问题很棘手:OpenSSH 可能会打开连接,但也可能会产生一个外壳,该外壳可以产生其他也可以打开连接的进程。很难区分这两种情况。如果 OpenSSH 只设置一个标记或任何东西,那会容易得多,但事实并非如此。

    所以你的解决方案是有限的:

    • 使用允许您配置绑定地址的单独 SOCKS 服务器。

    • 配置您的内核,使其默认使用 xx.yy.zz.2 用于所有传出连接,或者用于使用的实际目标 IP(如果它们事先已知)。

      为了在没有源地址的情况下分配源地址,内核会查看已使用的目标地址的路由条目,如果它有首选源地址,它将使用它。否则它将选择一些最适合该任务的地址。无论它选择什么,都可以通过ip route get (destination)命令检查,在src令牌之后:

      $ ip route get 8.8.8.8 8.8.8.8 via (maybe your gateway) dev eth0 src xx.yy.zz.1 [...]

      您可以使用ip route命令修改路由表以添加首选源地址,ip route change [...] src xx.yy.zz.2您甚至可以添加更具体的路由,通过相同的网关,但使用不同的首选源地址。

    • 将 OpenSSH 放入只处理 xx.yy.zz.2 地址的网络命名空间。这个解决方案太过分了,可能会改变服务器上许多服务的配置,因为它基本上隔离了你的两个地址。此解决方案将涉及您的系统中的许多更改,特别是关于 sshd 守护进程和您的 socks 服务器的启动方式。


    与所有这些无关:“接口别名”(例如eth0:1)在 Linux 上已弃用。它们仍然可以向后兼容类似ifconfig. 停止使用ifconfig,route并改用ip addrand ip route。

    用于ip addr add ... dev eth0向eth0接口添加地址。您可以根据需要添加任意数量的地址。用于ip addr将它们全部列出。ip addr请参阅和的手册页ip route以获取更多信息。

    • 5

相关问题

  • Linux 主机到主机迁移

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 如何在 Linux 下监控每个进程的网络 I/O 使用情况?

  • 在 RHEL4 上修改 CUPS 中的现有打印机设置

  • 为本地网络中的名称解析添加自定义 dns 条目

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