【屠龙技】Socat TCP/UDP 端口转发
2018-09-27 本文已影响0人
星际大镖客
姓朱者学屠龙于支离益,单千金之家,三年技成,而无所用其巧。
战国·郑·列御寇《庄子·列御寇》
CentOS安装 socat
yum update -y & yum install socat -y
1、TCP端口转发
socat -d TCP4-LISTEN:80,reuseaddr,fork TCP4:127.0.0.1:8080
2、UDP端口转发
socat -T 600 UDP4-LISTEN:5353,reuseaddr,fork UDP4:114.114.114.114:5353
- 配合nohup使用
nohup socat -T 600 UDP4-LISTEN:5353,reuseaddr,fork UDP4:114.114.114.114:5353 >> socat.log 2>&1 &
3、文件传输
- 服务端:
socat -u open:FILENAME tcp-listen:12345
- 客户端
socat -u tcp:ServerIP:12345 open:LOCALFILE,create
【说明】
-u 表示数据单向传送,从第一个参数传递到第二个参数;
-U则表示从第二个参数传送到第一个参数。
open 表示使用系统调用open()打开文件,不能打开unix域socket。
tcp-listen 表示监听tcp端口。
create 表示如果文件不存在则创建。
传输结束后两端均退出。
4、读写分离
使用!!符号,左侧表示读,右侧表示写
socat open:hello.html\!\!open:log.txt,create,append tcp-listen:12345,reuseaddr,fork
- 说明
open:hello.html 表示读hello.html文件。
open:log.txt 表示收到的数据写入log.txt文件。
reuseaddr 见socket的SO_REUSEADDR。
fork 请求到达时,fork一个进程进行处理。
在bash下,需要用\对!进行转义。