请教下怎样控制 Linux 的出口访问,只允许 Linux 访问指定域名? - V2EX
Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
xiaoz
1.03D
V2EX    Linux

请教下怎样控制 Linux 的出口访问,只允许 Linux 访问指定域名?

  •  
  •   xiaoz
    helloxz Mar 25, 2020 6605 views
    This topic created in 2238 days ago, the information mentioned may be changed or developed.

    iptables 可以控制出口流量,但是只能针对 IP 进行限制,无法针对域名。


    需求是这样的,限制了整个公网出口,只允许服务器去请求特定的一些域名,比如只允许请求百度,百度全国 CDN,拥有很多节点 IP,并且这些 IP 可能还会变化,因此将百度的 IP 全部加入 iptables 也不太现实,这里我也无法去收集到这些域名的 IP 或 IP 段,请问还有其它办法控制 Linux 的出口域名白名单吗?

    PS:这些域名可能启用了 CDN,CDN 的 IP 可能会不断的变化中。

    16 replies    2024-12-03 17:58:25 +08:00
    wdlth
        1
    wdlth  
       Mar 25, 2020   1
    可以自己建个 DNS
    zst
        2
    zst  
       Mar 25, 2020   1
    可以直接用 string 匹配域名吧
    wolonggl
        3
    wolonggl  
       Mar 25, 2020   2
    dnsmasq+ipset
    xiaoz
        4
    xiaoz  
    OP
       Mar 25, 2020
    @zst #2,感谢,我去看看 iptables 的 string 匹配。
    fengtons
        5
    fengtons  
       Mar 25, 2020 via Android   1
    最高效的应该是 3 楼说,参考一下各种翻墙教程
    2exploring
        6
    2exploring  
       Mar 25, 2020   1
    v2ray + 透明网关 应该也可
    jinliming2
        7
    jinliming2  
       Mar 26, 2020 via iPhone   1
    应该可以通过 HTTP header 中的 host 、HTTPS TLS 中的 SNI 来匹配访问的网站吧……
    v2ray 好像可以?然后用 iptables 的 redirect ?
    jim9606
        8
    jim9606  
       Mar 26, 2020   1
    通常的做法是全部流量都使用 HTTP Proxy,缺点就是只能支持 TCP 了。
    这种用户层的方法可以通过劫持 libc 实现,proxychains 用了这个方法,不过只适用于动态链接 libc 的程序

    dnsmasq+ipset 有些时候会有漏网之鱼,例如如果 a.comb.com 都 host 在同一个 CDN 主机 h.cdn.com 上,如果程序查询完白名单站点 a.com 的 DNS 后向 h.cdn.com 的 IP 发送 Host 为 b.com 的 HTTP(S)请求就会被放行
    w52
        9
    w52  
       Mar 26, 2020   1
    3 楼+1
    qakito
        10
    qakito  
       Mar 26, 2020   2
    一种做法:
    LAN 口针对 UDP dport=53 的报文做 redirect 到本地,本地的 DNS serve 就可以对黑名单里的域名进行干预(例如返回 No such domain)
    缺点是:
    如果本地通过 hosts 文件提前解析,你无能为力
    microlz
        11
    microlz  
       Mar 26, 2020   1
    可以不设置 dns 服务器 然后通过 hosts 解析
    araraloren
        12
    araraloren  
       Mar 26, 2020
    DNS 污染??(小声 (逃
    tomychen
        13
    tomychen  
       Mar 26, 2020
    10# +1
    iptables + L7 补丁,也可以做到协议 filter
    tvirus
        14
    tvirus  
       Mar 27, 2020
    用 adguard home 里 DNS 封锁试一试
    AQIVK1E0IV
        15
    AQIVK1E0IV  
       Dec 3, 2024
    现在也有相同的需求,想问大佬最后是怎么解决的?
    xiaoz
        16
    xiaoz  
    OP
       Dec 3, 2024 via Android
    @AQIVK1E0IV 没找到比较好的方案,我都记不得当时为啥有这个需求了。
    About     Help     Advertise     Blog     API     FAQ     Solana     1085 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 500ms UTC 22:57 PVG 06:57 LAX 15:57 JFK 18:57
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86