searchusermenu
  • 发布文章
  • 消息中心
点赞
收藏
评论
分享
原创

ip_transparent

2024-06-17 07:05:46
15
0

实现代理非本地ip的服务,比如192.168.0.7:1234
a. 启动tcp连接0.0.0.0:1234
b. ip route add local 192.168.0.7 dev lo table local
通常回复syn-ack的时候将收到的daddr作为srcip去发送,在查找路由的时候会判断srcip是否为本地ip或者在local表中有本地路由
ip_route_output(){
  if (fl4->saddr) {
        //如果没有设置IP_TRANSPARENT
        if (!(fl4->flowi4_flags & FLOWI_FLAG_ANYSRC)) {
                        /* It is equivalent to inet_addr_type(saddr) == RTN_LOCAL */
                        if (!__ip_dev_find(net, fl4->saddr, false))
                                goto out;
        }   
  }
}
struct net_device *__ip_dev_find(struct net *net, __be32 addr, bool devref)
{
        //是否为本地ip
        hlist_for_each_entry_rcu(ifa, &inet_addr_lst[hash], hash) {
                if (ifa->ifa_local == addr) {
                        struct net_device *dev = ifa->ifa_dev->dev;
                        result = dev;
                        break;
                }   
        }   
        //或者有本地路由
        if (!result) {
                struct flowi4 fl4 = { .daddr = addr };
                struct fib_result res = { 0 };
                struct fib_table *local;

                /* Fallback to FIB local table so that communication
                 * over loopback subnets work.
                 */  
                local = fib_get_table(net, RT_TABLE_LOCAL);
                if (local &&
                    !fib_table_lookup(local, &fl4, &res, FIB_LOOKUP_NOREF) &&
                    res.type == RTN_LOCAL)
                        result = FIB_RES_DEV(res);
        }   

如果是多个ip通过ip rule实现
ip rule add iff eth0 table proxy
iptables -t mangle -A PREROUTING xxx -j mark --set-mark xx
ip rule add fwmark xx iff eth0 table proxy
ip route add local default dev lo table proxy

0条评论
作者已关闭评论
w****n
15文章数
0粉丝数
w****n
15 文章 | 0 粉丝
w****n
15文章数
0粉丝数
w****n
15 文章 | 0 粉丝
原创

ip_transparent

2024-06-17 07:05:46
15
0

实现代理非本地ip的服务,比如192.168.0.7:1234
a. 启动tcp连接0.0.0.0:1234
b. ip route add local 192.168.0.7 dev lo table local
通常回复syn-ack的时候将收到的daddr作为srcip去发送,在查找路由的时候会判断srcip是否为本地ip或者在local表中有本地路由
ip_route_output(){
  if (fl4->saddr) {
        //如果没有设置IP_TRANSPARENT
        if (!(fl4->flowi4_flags & FLOWI_FLAG_ANYSRC)) {
                        /* It is equivalent to inet_addr_type(saddr) == RTN_LOCAL */
                        if (!__ip_dev_find(net, fl4->saddr, false))
                                goto out;
        }   
  }
}
struct net_device *__ip_dev_find(struct net *net, __be32 addr, bool devref)
{
        //是否为本地ip
        hlist_for_each_entry_rcu(ifa, &inet_addr_lst[hash], hash) {
                if (ifa->ifa_local == addr) {
                        struct net_device *dev = ifa->ifa_dev->dev;
                        result = dev;
                        break;
                }   
        }   
        //或者有本地路由
        if (!result) {
                struct flowi4 fl4 = { .daddr = addr };
                struct fib_result res = { 0 };
                struct fib_table *local;

                /* Fallback to FIB local table so that communication
                 * over loopback subnets work.
                 */  
                local = fib_get_table(net, RT_TABLE_LOCAL);
                if (local &&
                    !fib_table_lookup(local, &fl4, &res, FIB_LOOKUP_NOREF) &&
                    res.type == RTN_LOCAL)
                        result = FIB_RES_DEV(res);
        }   

如果是多个ip通过ip rule实现
ip rule add iff eth0 table proxy
iptables -t mangle -A PREROUTING xxx -j mark --set-mark xx
ip rule add fwmark xx iff eth0 table proxy
ip route add local default dev lo table proxy

文章来自个人专栏
完成任务
15 文章 | 1 订阅
0条评论
作者已关闭评论
作者已关闭评论
0
0