fubuki是网状VPN实现,用于不同内网机器之间相互通信
当前支持的平台:
- Windows
- Linux
- macOS
- Android
受支持的协议类型:
- P2P: UDP
- 中继: UDP, TCP
工作模式:
它通过一台公网服务器来同步多个节点的地址映射与存活状态。每个节点启动之后会存在一个唯一的虚拟地址,节点加入网段服务端会向所有对等节点同步状态信息并协调节点之间打洞,如受NAT限制等原因通讯建立失败后会回退至服务端中继。
Usage: fubuki <COMMAND>
Commands:
server coordinator and data relay server
node fubuki node
help Print this message or the help of the given subcommand(s)
Options:
-h, --help Print help
-V, --version Print version
- 必须以管理员权限运行
- 需要wintun.dll(https://www.wintun.net) 与程序同目录或System32下
- 启用
allowed_ips
配置项时系统须支持NetNat
命令
- 必须以root权限运行
- 内核需支持tun模块
- 启用
allowed_ips
配置项时系统须支持iptables
- 必须以root权限运行
- 内核需支持tun模块
- 启用
allowed_ips
配置项时系统须支持pfctl
创建fubuki服务端的配置 server-config.json
{
"groups": [
{
"name": "mygroup",
"key": "123",
"listen_addr": "0.0.0.0:12345",
"address_range": "10.0.0.0/24"
}
]
}
- name: 组名为 "mygroup"
- key: 该组的预共享密钥
- listen_addr: fubuki server监听地址
- address_range: 配置的虚拟网段
启动 fubuki server
fubuki server daemon ./server-config.json
创建fubuki节点的配置 node-config.json
{
"groups": [
{
"node_name": "node1",
"server_addr": "{fubuki server address}",
"key": "123"
}
]
}
- node_name: 节点名
- server_addr: 服务器地址,格式为 IP:PORT
- key: 预共享密钥
启动 fubuki node
fubuki node daemon ./node-config.json
启动第二个节点
{
"groups": [
{
"node_name": "node2",
"server_addr": "{fubuki server address}",
"key": "123"
}
]
}
ping
node2节点,可以使用 {node_name}.{group_name}
形式
ping node2.mygroup
- Rust nightly toolchain
- Windows
- MSVC toolchain
cargo +nightly build --release
包含 Web UI
- Node.js >= 16.*
- Angular CLI
cargo +nightly build --release --features "web"
包含 GUI
cargo +nightly build --release --features "gui"
交叉编译Android动态库
export RUSTUP_TOOLCHAIN=nightly
cargo install cross --git https://github.com/cross-rs/cross
# 这里的目标平台是aarch64-linux-android, 有关于其他Rust支持的平台参阅 https://doc.rust-lang.org/nightly/rustc/platform-support.html
cross +nightly build --lib --release --no-default-features --target aarch64-linux-android