This commit is contained in:
wangyu- 2017-08-27 03:31:30 -05:00
commit bd1e7fbc2f
2 changed files with 35 additions and 13 deletions

View File

@ -71,7 +71,7 @@ To run on Android, check [Android_Guide](/doc/android_guide.md)
### Usage ### Usage
``` ```
udp2raw-tunnel udp2raw-tunnel
version: Aug 18 2017 00:29:11 version: Aug 26 2017 08:30:48
repository: https://github.com/wangyu-/udp2raw-tunnel repository: https://github.com/wangyu-/udp2raw-tunnel
usage: usage:
@ -84,14 +84,16 @@ common options,these options must be same on both side:
--cipher-mode <string> avaliable values:aes128cbc(default),xor,none --cipher-mode <string> avaliable values:aes128cbc(default),xor,none
--auth-mode <string> avaliable values:md5(default),crc32,simple,none --auth-mode <string> avaliable values:md5(default),crc32,simple,none
-a,--auto-rule auto add (and delete) iptables rule -a,--auto-rule auto add (and delete) iptables rule
-g,--gen-rule generate iptables rule then exit -g,--gen-rule generate iptables rule then exit,so that you can copy and
add it manually.overrides -a
--disable-anti-replay disable anti-replay,not suggested --disable-anti-replay disable anti-replay,not suggested
client options: client options:
--source-ip <ip> force source-ip for raw socket --source-ip <ip> force source-ip for raw socket
--source-port <port> force source-port for raw socket,tcp/udp only --source-port <port> force source-port for raw socket,tcp/udp only
this option disables port changing while re-connecting this option disables port changing while re-connecting
other options: other options:
--conf-file <string> read options from a configuration file instead of command line --conf-file <string> read options from a configuration file instead of command line.
check example.conf in repo for format
--log-level <number> 0:never 1:fatal 2:error 3:warn --log-level <number> 0:never 1:fatal 2:error 3:warn
4:info (default) 5:debug 6:trace 4:info (default) 5:debug 6:trace
--log-position enable file name,function name,line number in log --log-position enable file name,function name,line number in log
@ -101,11 +103,16 @@ other options:
--sock-buf <number> buf size for socket,>=10 and <=10240,unit:kbyte,default:1024 --sock-buf <number> buf size for socket,>=10 and <=10240,unit:kbyte,default:1024
--seqmode <number> seq increase mode for faketcp: --seqmode <number> seq increase mode for faketcp:
0:dont increase 0:dont increase
1:increase every packet 1:increase every packet(default)
2:increase randomly, about every 3 packets (default) 2:increase randomly, about every 3 packets
--lower-level <string> send packet at OSI level 2, format:'if_name#dest_mac_adress' --lower-level <string> send packets at OSI level 2, format:'if_name#dest_mac_adress'
ie:'eth0#00:23:45:67:89:b9'.Beta. ie:'eth0#00:23:45:67:89:b9'.or try '--lower-level auto' to obtain
the parameter automatically,specify it manually if 'auto' failed
--gen-add generate iptables rule and add it permanently,then exit.overrides -g
--keep-rule monitor iptables and auto re-add if necessary.implys -a
--clear clear any iptables rules added by this program.overrides everything
-h,--help print this help message -h,--help print this help message
``` ```
### Iptables rules,`-a` and `-g` ### Iptables rules,`-a` and `-g`

View File

@ -83,12 +83,14 @@ https://github.com/wangyu-/udp2raw-tunnel/releases
### 提醒 ### 提醒
如果要在anroid上运行请看[Android简明教程](/doc/android_guide.md) 如果要在anroid上运行请看[Android简明教程](/doc/android_guide.md)
如果要在梅林固件的路由器上使用,添加`--lower-level auto` `--keep-rule`
# 进阶操作说明 # 进阶操作说明
### 命令选项 ### 命令选项
``` ```
udp2raw-tunnel udp2raw-tunnel
version: Aug 18 2017 00:29:11 version: Aug 26 2017 08:30:48
repository: https://github.com/wangyu-/udp2raw-tunnel repository: https://github.com/wangyu-/udp2raw-tunnel
usage: usage:
@ -101,13 +103,16 @@ common options,these options must be same on both side:
--cipher-mode <string> avaliable values:aes128cbc(default),xor,none --cipher-mode <string> avaliable values:aes128cbc(default),xor,none
--auth-mode <string> avaliable values:md5(default),crc32,simple,none --auth-mode <string> avaliable values:md5(default),crc32,simple,none
-a,--auto-rule auto add (and delete) iptables rule -a,--auto-rule auto add (and delete) iptables rule
-g,--gen-rule generate iptables rule then exit -g,--gen-rule generate iptables rule then exit,so that you can copy and
add it manually.overrides -a
--disable-anti-replay disable anti-replay,not suggested --disable-anti-replay disable anti-replay,not suggested
client options: client options:
--source-ip <ip> force source-ip for raw socket --source-ip <ip> force source-ip for raw socket
--source-port <port> force source-port for raw socket,tcp/udp only --source-port <port> force source-port for raw socket,tcp/udp only
this option disables port changing while re-connecting this option disables port changing while re-connecting
other options: other options:
--conf-file <string> read options from a configuration file instead of command line.
check example.conf in repo for format
--log-level <number> 0:never 1:fatal 2:error 3:warn --log-level <number> 0:never 1:fatal 2:error 3:warn
4:info (default) 5:debug 6:trace 4:info (default) 5:debug 6:trace
--log-position enable file name,function name,line number in log --log-position enable file name,function name,line number in log
@ -117,11 +122,16 @@ other options:
--sock-buf <number> buf size for socket,>=10 and <=10240,unit:kbyte,default:1024 --sock-buf <number> buf size for socket,>=10 and <=10240,unit:kbyte,default:1024
--seqmode <number> seq increase mode for faketcp: --seqmode <number> seq increase mode for faketcp:
0:dont increase 0:dont increase
1:increase every packet 1:increase every packet(default)
2:increase randomly, about every 3 packets (default) 2:increase randomly, about every 3 packets
--lower-level <string> send packet at OSI level 2, format:'if_name#dest_mac_adress' --lower-level <string> send packets at OSI level 2, format:'if_name#dest_mac_adress'
ie:'eth0#00:23:45:67:89:b9'.Beta. ie:'eth0#00:23:45:67:89:b9'.or try '--lower-level auto' to obtain
the parameter automatically,specify it manually if 'auto' failed
--gen-add generate iptables rule and add it permanently,then exit.overrides -g
--keep-rule monitor iptables and auto re-add if necessary.implys -a
--clear clear any iptables rules added by this program.overrides everything
-h,--help print this help message -h,--help print this help message
``` ```
### iptables 规则,`-a``-g` ### iptables 规则,`-a``-g`
@ -134,12 +144,17 @@ other options:
### `--seq-mode` ### `--seq-mode`
facktcp模式并没有模拟tcp的全部。所以理论上有办法把faketcp和真正的tcp流量区分开来虽然大部分ISP不太可能做这种程度的包检测。seq-mode可以改变一些seq ack的行为。如果遇到了连接问题可以尝试更改。在我这边的移动线路用3种模式都没问题。 facktcp模式并没有模拟tcp的全部。所以理论上有办法把faketcp和真正的tcp流量区分开来虽然大部分ISP不太可能做这种程度的包检测。seq-mode可以改变一些seq ack的行为。如果遇到了连接问题可以尝试更改。在我这边的移动线路用3种模式都没问题。
### `--keep-rule`
定期主动检查iptables如果udp2raw添加的iptables规则丢了就重新添加。在一些iptables可能会被其他程序清空的情况下(比如梅林固件和openwrt的路由器)格外有用。
### `--lower-level` ### `--lower-level`
大部分udp2raw不能连通的情况都是设置了不兼容的iptables造成的。--lower-level选项允许绕过本地iptables。在一些iptables不好改动的情况下尤其有效比如你用的是梅林固件iptables全是固件自己生成的 大部分udp2raw不能连通的情况都是设置了不兼容的iptables造成的。--lower-level选项允许绕过本地iptables。在一些iptables不好改动的情况下尤其有效比如你用的是梅林固件iptables全是固件自己生成的
##### 格式 ##### 格式
`if_name#dest_mac_adress`,例如 `eth0#00:23:45:67:89:b9``eth0`换成你的出口网卡名。`00:23:45:67:89:b9`换成网关的mac地址如果client和server在同一个局域网内可能不需要网关这时候直接用对方主机的mac地址这个属于罕见的应用场景可以忽略 `if_name#dest_mac_adress`,例如 `eth0#00:23:45:67:89:b9``eth0`换成你的出口网卡名。`00:23:45:67:89:b9`换成网关的mac地址如果client和server在同一个局域网内可能不需要网关这时候直接用对方主机的mac地址这个属于罕见的应用场景可以忽略
可以用`--lower-level auto`自动获取参数,如果获取参数失败,再手动填写。
##### client端获得--lower-level参数的办法 ##### client端获得--lower-level参数的办法
在client 端,运行`traceroute <server_ip>`,记下第一跳的地址,这个就是`网关ip`。再运行`arp -s <网关ip>`可以同时查到出口网卡名和mac。 在client 端,运行`traceroute <server_ip>`,记下第一跳的地址,这个就是`网关ip`。再运行`arp -s <网关ip>`可以同时查到出口网卡名和mac。