您的位置:

Lanproxy:基于NIO的高性能内网穿透代理工具

一、Lanproxy的介绍

Lanproxy是一款基于NIO的高性能内网穿透代理工具,可以将内网服务代理到公网上,从而可以在外网访问内网服务。Lanproxy支持TCP/UDP协议,同时支持多路复用,可以在一个物理连接上实现多个虚拟连接。

Lanproxy的功能十分强大,可以帮助开发者快速搭建内网穿透代理环境,方便调试内网服务,并且可以避免将代码部署到公网上。Lanproxy使用简单,易于配置。

二、Lanproxy的安装与配置

1. 安装java环境

sudo apt-get install default-jre

2. 下载Lanproxy的jar包

wget https://github.com/ffay/lanproxy/releases/download/v0.1.0/lanproxy-server-0.1.0.jar

3. 修改配置文件

vim lanproxy-server-0.1.0.jar

修改配置文件中的proxy.server.bind的值,将其设为本机的IP地址。

4. 启动Lanproxy

java -jar lanproxy-server-0.1.0.jar

5. 验证是否启动成功

netstat -ntlp

Lanproxy默认监听的是9090端口,可以在config.properties文件中修改。

三、Lanproxy的使用

1. 编写内网服务

public class NettyServer {
    public static void main(String[] args) throws Exception {
        EventLoopGroup bossGroup = new NioEventLoopGroup();
        EventLoopGroup workerGroup = new NioEventLoopGroup();
        try {
            ServerBootstrap serverBootstrap = new ServerBootstrap();
            serverBootstrap.group(bossGroup, workerGroup)
                    .channel(NioServerSocketChannel.class)
                    .option(ChannelOption.SO_BACKLOG, 1024)
                    .childHandler(new ChannelInitializer
   () {
                        @Override
                        public void initChannel(SocketChannel channel) throws Exception {
                            channel.pipeline().addLast(new NettyServerHandler());
                        }
                    });

            ChannelFuture future = serverBootstrap.bind(8080).sync();
            System.out.println("NettyServer start success on port: " + 8080);

            future.channel().closeFuture().sync();
        } finally {
            bossGroup.shutdownGracefully();
            workerGroup.shutdownGracefully();
        }
    }
}

   

2. 启动内网服务

内网服务启动后,我们可以通过在内网环境中访问localhost:8080进行访问测试。

3. 配置Lanproxy代理

将内网服务代理到公网上,修改proxy-client.properties文件,在其中添加下列内容:

tunnel.server.host=your.server.com
tunnel.server.port=2090
token=your_token
listen=0.0.0.0:8080

其中,your.server.com为服务器所在的IP地址,2090为Lanproxy服务器端口号,your_token为自定义token,0.0.0.0:8080为需要代理的服务监听的端口号。

4. 启动Lanproxy客户端

java -jar lanproxy-client-0.1.0.jar

5. 验证内网服务是否可被公网访问

在公网环境下,访问my.server.com:8080即可访问到内网服务。

四、Lanproxy的优势

1. 高性能

Lanproxy使用NIO技术,支持多路复用,可以在一个物理连接上实现多个虚拟连接,同时,Lanproxy支持HTTP/HTTPS的加密和压缩,可以加快数据传输速度。

2. 易于使用

Lanproxy的使用简单,只需要简单的配置即可实现内网穿透代理,可以节省开发者宝贵的时间。

3. 安全可靠

Lanproxy使用token方式进行连接认证,同时支持加密和压缩传输,安全可靠。

五、Lanproxy的未来发展

1. Lanproxy目前仍然处于开发阶段,在性能和功能方面还有很大的提升空间。

2. Lanproxy可以支持更多的协议类型,以满足不同开发者的需求。

3. Lanproxy可以支持更加灵活的代理配置,以更好的适应不同场景的需求。

总的来说,Lanproxy是一个非常优秀的内网穿透代理工具,无论是开发调试,还是测试环境搭建,都是一个非常好的选择。