加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

透明代理 – 如何将套接字传递给本地服务器而不进行修改?

发布时间:2020-12-13 19:07:30 所属栏目:Linux 来源:网络整理
导读:我有一个程序侦听端口443,然后根据检测到的协议重定向到SSH或HTTPS本地服务器. 该程序通过连接到本地服务器并通过其自己的进程来回代理所有数据来完成此操作. 但是,这会导致本地服务器上的原始主机记录为localhost. 有没有办法将套接字直接传递给本地服务器

我有一个程序侦听端口443,然后根据检测到的协议重定向到SSH或HTTPS本地服务器.

该程序通过连接到本地服务器并通过其自己的进程来回代理所有数据来完成此操作.

但是,这会导致本地服务器上的原始主机记录为localhost.

有没有办法将套接字直接传递给本地服务器进程(而不仅仅是建立一个新的TCP连接),以便保留sockaddr_in(或sockaddr_in6)的参数?

这个平台就是Linux.

最佳答案
这是从stunnel获取的代码片段(如果您想查看所有代码,则从local_bind函数中的client.c获取).

#ifdef IP_TRANSPARENT
int on=1;
if(c->opt->option.transparent) {
    if(setsockopt(c->fd,SOL_IP,IP_TRANSPARENT,&on,sizeof on))
        sockerror("setsockopt IP_TRANSPARENT");
    /* ignore the error to retain Linux 2.2 compatibility */
    /* the error will be handled by bind(),anyway */
}
#endif /* IP_TRANSPARENT */

memcpy(&addr,&c->bind_addr.addr[0],sizeof addr);
if(ntohs(addr.in.sin_port)>=1024) { /* security check */
    if(!bind(c->fd,&addr.sa,addr_len(addr))) {
        s_log(LOG_INFO,"local_bind succeeded on the original port");
        return; /* success */
    }
    if(get_last_socket_error()!=EADDRINUSE
#ifndef USE_WIN32
            || !c->opt->option.transparent
#endif /* USE_WIN32 */
            ) {
        sockerror("local_bind (original port)");
        longjmp(c->err,1);
    }
}

之前,使用以下代码将c-> bind_addr设置为连接对等体的地址:

    else if(c->opt->option.transparent)
    memcpy(&c->bind_addr,&c->peer_addr,sizeof(SOCKADDR_LIST));

stunnel文档包含了对最新Linux内核的建议:

Remote mode (either 2.2.x and >=2.6.28) requires stunnel to be executed as root. setuid option will also break this functionality.

Linux >=2.6.28 requires the following setup for iptables and routing (possibly in /etc/rc.local or equivalent file):

iptables -t mangle -N DIVERT
iptables -t mangle -A PREROUTING -p tcp -m socket -j DIVERT
iptables -t mangle -A DIVERT -j MARK --set-mark 1
iptables -t mangle -A DIVERT -j ACCEPT
ip rule add fwmark 1 lookup 100
ip route add local 0.0.0.0/0 dev lo table 100

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读