8000 GitHub - cxixc/goports: ipv6 转发内网 ipv4
[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Skip to content

cxixc/goports

 
 

Repository files navigation

goports

一个主要功能和socat类似,主要实现公网ipv6 tcp/udp 转发至 内网ipv4 tcp/udp 的端口转发小工具.

特性

  • 后端golang,前端vue3
  • 支持Windows、Linux系统,支持x86、ARM、MIPS、MIPSLE等架构
  • 支持界面化(web后台)管理转发规则,单条转发规则支持设置多个转发端口,一键开关指定转发规则
  • 单条规则支持黑白名单安全模式切换,白名单模式可以让没有安全验证的内网服务端口稍微安全一丢丢暴露到公网
  • Web后台支持查看最新100条日志
  • 另有精简版不带后台,支持命令行快捷设置转发规则,有利于空间有限的嵌入式设备运行.

使用

  • 百度网盘下载地址 百度网盘版本可能会更新比较频繁, github release更新 只发布未经upx压缩的版本,精简版和upx压缩版会放上百度网盘

  • 默认后台管理地址 http://<运行设备IP>:16601 默认登录账号: 666 默认登录密码: 666

  • 常规使用请用 -c <配置文件路径> 指定配置文件的路由方式运行 , -p <后台端口> 可以指定后台管理端口

    #仅指定配置文件路径(如果配置文件不存在会自动创建),建议使用绝对路径
    goports -c 666.conf
    #同时指定后台端口 8899
    goports -c 666.conf -p 8899
  • 命令行直接运行转发规则,注意后台无法编辑修改命令行启动的转发规则,主要用在不带后台的精简版

    #指定后台端口8899 
    goports -p 8899 <转发规则1> <转发规则2> <转发规则3>...<<转发规则N>

转发规则格式

例子1
tcp6@:22222to192.168.31.1:22
监听 tcp6 类型的22222端口转发至192.168.31.1的22端口

例子2
udp@:1194to192.168.31.36
监听 udp(同时包含udp4和udp6)类型的1194端口转发至192.168.31.36的相同端口(1194)

例子3
tcp6,udp6@:53to192.168.31.1:53
监听 tcp6和udp6类型的53端口转发至192.168.31.1的53端口

如果你还是没法理解格式,那么可以通过web管理后台添加转发规则后直接在规则列表中一键复制自动生成的命令行配置
需要注意的是这种方式导入的规则不包含规则中的其它参数部分,命令行模式的规则只支持通过设置启动参数共用相同的额外参数(一般使用影响不大,不需要理会)

其它启动参数

使用后台管理的用户不需要理会这部分内容

-pcl <num>  
全局代理数量限制(默认128),每个端口转发对应一个代理,这个参数主要是为了防止用户误写规则,生成过多代理造成程序奔溃或占用资源过多,一般不需要动. 

-gpmc <num>
全局最大并发连接数(默认10240),设计这个参数是为防止由于未知原因被人恶意高并发访问搞挂运行设备或程序,请根据需求调整.

-smc <num>
单个代理(端口)的最大并发数

-ups <num>
UDP包最大长度,默认1500,一般使用情景不需要理会,有特殊使用情景再自行调整,比如内网小包性能测试.

-upm <bool>
UDP代理性能模式开关,打开后,多核CPU环境下有利于改善UDP小包转发性能,默认已打开.

-udpshort <bool>
UDP short模式,如果需要用到dns转发打开这个开关有助于节省资源.

后台界面

规则设置 规则列表

#开发编译 带后台版本编译

```bash
go build -v -tags "adminweb nomsgpack" -ldflags="-s -w"
```

不带后台版本
```bash
go build -v -tags "nomsgpack" -ldflags="-s -w"
```

使用注意与常见问题

  • 如果在mips架构CPU下运行有问题请使用未压缩(UPS压缩版本),

  • 已知upx3.96版压缩后的程序在mipsle下可能无法运行,虽然已经更换了upx版本,暂时未再发现异常.

  • 不同于防火墙端口转发规则,不要设置没有用上的端口,会增加内存的使用.

  • 小米路由 ipv4 类型的80和443端口被占用,但只设置监听tcp6(ipv6)的80/443端口转发规则完全没问题.

  • 如果需要使用白名单模式,请根据自身需求打开外网访问后台管理页面开关.

  • 转发规则启用异常,端口转发没有生效时请登录后台查看日志.

About

ipv6 转发内网 ipv4

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 56.2%
  • Vue 36.4%
  • JavaScript 4.8%
  • CSS 1.1%
  • TypeScript 1.0%
  • SCSS 0.3%
  • Other 0.2%
0