温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么使用Nginx实现端口转发TCP代理

发布时间:2021-12-24 09:28:11 来源:亿速云 阅读:340 作者:iii 栏目:开发技术

本篇内容介绍了“怎么使用Nginx实现端口转发TCP代理”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    需求产生背景

    最近同事在测试和生产环境中分别部署了一套应用,由于应用只能集成LDAP,而我们公司使用的是AD,于是我搭建了一个OpenLDAP服务,账号先通过lsc从AD同步到OpenLDAP,然后使用saslauthd传递身份验证到AD。在测试环境中我们的应用能够连接LDAP登录,但是在生产环境中却无法访问到OpenLDAP服务器,我不想重复的在生产环境重新安装维护一套OpenLDAP服务,这个过程比较繁琐,还需通过定时任务每天让AD的账号与OpenLDAP同步,于是我想这可以通过端口转发实现,节点之间的拓扑大概像下面这样。

    怎么使用Nginx实现端口转发TCP代理

    为什么要使用Nginx实现

    在百度上搜索端口转发,实现的方式有很多种,多数都是通过Iptables实现,但是我分别在Ubuntu和CentOS服务器上测试过都没生效,无奈选择Nginx来实现

    使用Nginx实现端口转发

    如果我们的操作系统比较新,可以直接直接通过软件源安装nginx,只要nginx版本大于1.9默认是支持TCP代理的。

    检查nginx是否支持TCP代理

    nginx -V

    当我们在输出的配置参数中包含--with-stream说明nginx是支TCP代理的

    安装依赖

    RHEL/CentOS/Fedora

    yum install -y pcre* openssl*

    Debian/Ubuntu

    apt-get install zlib1g-dev libpcre++-dev openssl

    下载依赖

    wget http://labs.frickle.com/files/ngx_cache_purge-2.3.tar.gz
    tar -zxvf ngx_cache_purge-2.3.tar.gz -C /usr/local/src

    下载并安装

    下载源码包

    wget http://nginx.org/download/nginx-1.9.9.tar.gz

    解压

    tar -zxf nginx-1.9.9.tar.gz

    编译安装

    cd nginx-1.9.9
    ./configure --prefix=/usr/local/nginx \
      --add-module=/usr/local/src/ngx_cache_purge-2.3 \
      --with-http_stub_status_module --with-stream
    make && make install;

    修改配置文件

    /usr/local/nginx/conf/nginx.conf

    events {
      ...
    }
    
    stream {
        upstream ldap {
            hash $remote_addr consistent;
            server 192.168.1.8:389;
        }
        server {
            listen 1389;
            proxy_connect_timeout 5s;
            proxy_timeout 5s;
            proxy_pass ldap;
        }
    }
    
    http {
      ...
    }

    这个示例我们将本地的1389端口转发到192.168.1.8的389端口上

    启动并检查服务是否正常

    启动nginx服务

    /usr/local/nginx/sbin/nginx

    检查nginx进程

    netstat -anput | grep nginx

    怎么使用Nginx实现端口转发TCP代理

    “怎么使用Nginx实现端口转发TCP代理”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI